:root {
  --bg: #1b2740;
  --bg-soft: #2a3a57;
  --panel: rgba(35, 50, 78, 0.58);
  --panel-strong: #2a3b59;
  --line: rgba(238, 242, 247, 0.12);
  --line-strong: rgba(238, 242, 247, 0.2);
  --text: #eef2f7;
  --muted: #c7d3e3;
  --dim: #9baecc;
  --accent: #8bdcff;
  --accent-soft: rgba(139, 220, 255, 0.2);
  --accent-2: #7dd3fc;
  --success: #8bdcff;
  --danger: #ff9f9f;
  --shadow: 0 22px 56px rgba(7, 13, 26, 0.28);
  --radius-sm: 14px;
  --radius-md: 24px;
  --radius-lg: 36px;
  --wrap: 1280px;
  --header-h: 68px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scrollbar-gutter: stable;
}

body {
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(139, 220, 255, 0.2), transparent 28%),
    radial-gradient(circle at 84% 8%, rgba(139, 220, 255, 0.08), transparent 22%),
    linear-gradient(180deg, #294060 0%, #1b2740 44%, #152033 100%);
  font-family: 'Noto Sans SC', sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.05;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
  background-size: 26px 26px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.7), transparent 92%);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input {
  font: inherit;
}

button {
  border: 0;
  cursor: pointer;
}

img {
  display: block;
  max-width: 100%;
}

.wrap {
  width: min(var(--wrap), calc(100% - 40px));
  margin: 0 auto;
}

.simple-hero {
  padding: 64px 0 34px;
}

.simple-hero .lead {
  max-width: 760px;
}

.page-campaign {
  position: relative;
  padding: 84px 0 34px;
  overflow: hidden;
}

.page-campaign::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 12% 16%, rgba(139, 220, 255, 0.18), transparent 24%),
    radial-gradient(circle at 88% 18%, rgba(139, 220, 255, 0.08), transparent 18%);
  pointer-events: none;
}

.page-campaign-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 0.72fr 1.28fr;
  gap: 38px;
  align-items: center;
}

.page-campaign-copy {
  max-width: 410px;
}

.page-campaign-title {
  margin-top: 22px;
  font-size: clamp(30px, 3.3vw, 54px);
  line-height: 0.96;
  letter-spacing: 0.02em;
}

.page-campaign-lead {
  max-width: 390px;
  margin-top: 16px;
  text-transform: none;
  letter-spacing: 0.02em;
  line-height: 1.8;
  font-size: 13px;
  color: rgba(238, 242, 247, 0.72);
}

.page-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 22px;
}

.page-chip-row span {
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(238, 242, 247, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.page-campaign-visual {
  position: relative;
  min-height: 300px;
  overflow: hidden;
  border-radius: 32px;
  border: 1px solid rgba(238, 242, 247, 0.1);
  background-color: rgba(26, 38, 58, 0.76);
  background-size: cover;
  background-position: center;
  box-shadow: var(--shadow);
}

.page-campaign-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(10, 16, 28, 0.4)),
    linear-gradient(135deg, rgba(139, 220, 255, 0.12), transparent 52%);
}

.page-campaign-visual-copy {
  position: absolute;
  inset: auto 28px 28px 28px;
  z-index: 1;
}

.page-campaign-visual-copy span {
  color: rgba(255, 255, 255, 0.88);
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.home-hero {
  position: relative;
  padding: 72px 0 48px;
  overflow: hidden;
}

.home-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 8% 18%, rgba(139, 220, 255, 0.24), transparent 20%),
    radial-gradient(circle at 86% 16%, rgba(139, 220, 255, 0.1), transparent 18%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), transparent 55%);
  pointer-events: none;
}

.simple-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.lead-ribbon {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 32px;
}

.lead-ribbon span {
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(20, 32, 51, 0.08);
  background: rgba(255, 255, 255, 0.74);
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.cases-hero {
  position: relative;
  padding: 82px 0 34px;
  overflow: hidden;
}

.cases-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 18%, rgba(139, 220, 255, 0.16), transparent 22%),
    radial-gradient(circle at 88% 22%, rgba(139, 220, 255, 0.06), transparent 18%);
  pointer-events: none;
}

.cases-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 0.86fr 1.14fr;
  gap: 44px;
  align-items: end;
}

.cases-signature {
  display: grid;
  gap: 10px;
  margin-top: 22px;
}

.cases-signature strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(38px, 4.5vw, 72px);
  line-height: 0.94;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.cases-signature span {
  color: rgba(84, 103, 125, 0.82);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.case-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 32px;
  align-items: start;
}

.case-sidebar {
  position: sticky;
  top: calc(var(--header-h) + 18px);
}

.case-video {
  width: 100%;
  aspect-ratio: 16 / 10;
  border-radius: 22px;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 20%, rgba(125, 211, 252, 0.14), transparent 22%),
    radial-gradient(circle at 78% 22%, rgba(139, 220, 255, 0.08), transparent 22%),
    rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(238, 242, 247, 0.08);
}

.case-video video,
.case-video iframe,
.case-video img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.case-empty {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--dim);
  padding: 24px;
  line-height: 1.8;
}

.prompt-box {
  margin-top: 18px;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background: rgba(255, 255, 255, 0.025);
}

.prompt-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
}

.prompt-state {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(125, 211, 252, 0.18);
  background: rgba(125, 211, 252, 0.1);
  color: var(--accent);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.prompt-state.is-locked {
  border-color: rgba(238, 242, 247, 0.12);
  background: rgba(255, 255, 255, 0.04);
  color: var(--dim);
}

.prompt-box pre {
  margin: 0;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--muted);
  font-family: inherit;
  line-height: 1.9;
}

.prompt-locked {
  color: var(--dim);
  line-height: 1.8;
}

.prompt-open-btn,
.prompt-locked-card {
  margin-top: 14px;
  min-height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(125, 211, 252, 0.18);
  background: rgba(125, 211, 252, 0.08);
  color: var(--accent);
  font: inherit;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
}

.prompt-open-btn {
  width: 100%;
  cursor: pointer;
  transition: transform 0.24s ease, background 0.24s ease, border-color 0.24s ease;
}

.prompt-open-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(125, 211, 252, 0.32);
  background: rgba(125, 211, 252, 0.14);
}

.prompt-locked-card {
  position: relative;
  display: flex;
  min-height: 126px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 18px;
  border-color: rgba(238, 242, 247, 0.1);
  background: rgba(255, 255, 255, 0.035);
  color: var(--dim);
  text-align: center;
}

.prompt-locked-card::before {
  content: '';
  position: absolute;
  inset: 14px;
  border-radius: 20px;
  background:
    repeating-linear-gradient(180deg, rgba(238, 242, 247, 0.13) 0 7px, rgba(238, 242, 247, 0.035) 7px 15px);
  filter: blur(5px);
  opacity: 0.34;
}

.prompt-locked-card .paid-blur {
  margin-bottom: 14px;
}

.prompt-unlock-btn {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(125, 211, 252, 0.22);
  background: rgba(125, 211, 252, 0.12);
  color: var(--accent);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  transition: transform 0.24s ease, background 0.24s ease, border-color 0.24s ease;
}

.prompt-unlock-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(125, 211, 252, 0.36);
  background: rgba(125, 211, 252, 0.18);
}

.prompt-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(6, 11, 20, 0.68);
  backdrop-filter: blur(18px);
}

.prompt-modal.is-open {
  display: flex;
}

.prompt-modal-shell {
  position: relative;
  width: min(760px, 100%);
  max-height: min(78vh, 760px);
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(238, 242, 247, 0.12);
  background:
    linear-gradient(145deg, rgba(42, 59, 86, 0.96), rgba(16, 25, 40, 0.98));
  box-shadow: 0 32px 90px rgba(3, 7, 16, 0.42);
}

.prompt-modal-head {
  padding: 28px 30px 16px;
  border-bottom: 1px solid rgba(238, 242, 247, 0.08);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.prompt-modal-head h2 {
  margin: 10px 40px 0 0;
  font-size: 24px;
  letter-spacing: 0.02em;
}

.prompt-copy-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(125, 211, 252, 0.22);
  background: rgba(125, 211, 252, 0.1);
  color: var(--accent);
  font: inherit;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  cursor: pointer;
  transition: background 0.24s ease, border-color 0.24s ease, transform 0.24s ease;
}

.prompt-copy-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(125, 211, 252, 0.34);
  background: rgba(125, 211, 252, 0.16);
}

.prompt-copy-btn:active {
  transform: translateY(0);
}

.prompt-modal pre {
  margin: 0;
  max-height: calc(min(78vh, 760px) - 118px);
  overflow: auto;
  padding: 24px 30px 30px;
  color: rgba(238, 242, 247, 0.78);
  font-family: inherit;
  font-size: 14px;
  line-height: 1.9;
  white-space: pre-wrap;
  word-break: break-word;
}

.course-library-hero {
  padding: 92px 0 42px;
}

.course-library-hero-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.82fr) minmax(320px, 1fr);
  gap: 34px;
  align-items: stretch;
}

.course-library-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 360px;
}

.course-library-copy h1 {
  margin: 14px 0 16px;
  max-width: 620px;
  font-size: clamp(34px, 5vw, 70px);
  line-height: 0.98;
  letter-spacing: -0.06em;
}

.course-library-copy p,
.course-toolbar p,
.course-summary,
.course-free-body {
  color: var(--muted);
  line-height: 1.85;
}

.course-library-visual {
  min-height: 360px;
  border-radius: 30px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background-size: cover;
  background-position: center;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 28px;
  overflow: hidden;
  position: relative;
}

.course-library-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(11, 19, 32, 0.08), rgba(11, 19, 32, 0.76));
}

.course-library-visual span,
.course-library-visual strong {
  position: relative;
  z-index: 1;
}

.course-library-visual span {
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.18em;
}

.course-library-visual strong {
  margin-top: 8px;
  color: var(--text);
  font-size: 28px;
  letter-spacing: 0.04em;
}

.course-library-section {
  padding-top: 34px;
}

.course-toolbar {
  margin-bottom: 24px;
  padding: 20px;
  border-radius: 24px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background: rgba(31, 45, 69, 0.56);
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
}

.course-filter-stack {
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.course-list {
  display: grid;
  gap: 22px;
}

.course-lesson-card {
  display: grid;
  grid-template-columns: minmax(260px, 0.86fr) minmax(320px, 1.14fr);
  gap: 0;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02)),
    rgba(31, 45, 69, 0.62);
}

.course-lesson-media {
  min-height: 360px;
  background: rgba(7, 13, 26, 0.4);
}

.course-lesson-media video,
.course-lesson-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.course-lesson-body {
  padding: 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.course-lesson-body h2 {
  font-size: clamp(24px, 3vw, 42px);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.course-summary {
  font-size: 14px;
}

.course-free-body {
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(238, 242, 247, 0.07);
  background: rgba(255, 255, 255, 0.025);
  font-size: 13px;
}

.course-paid-box {
  position: relative;
  min-height: 168px;
  padding: 20px;
  border-radius: 20px;
  border: 1px solid rgba(125, 211, 252, 0.16);
  background: rgba(125, 211, 252, 0.06);
  overflow: hidden;
}

.course-paid-box pre {
  margin: 10px 0 0;
  white-space: pre-wrap;
  word-break: break-word;
  color: rgba(238, 242, 247, 0.82);
  font-family: inherit;
  line-height: 1.85;
}

.course-paid-box.is-locked {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.course-paid-box.is-locked::before {
  content: '';
  position: absolute;
  inset: 16px;
  border-radius: 16px;
  background:
    repeating-linear-gradient(180deg, rgba(238, 242, 247, 0.16) 0 8px, rgba(238, 242, 247, 0.04) 8px 16px);
  filter: blur(5px);
  opacity: 0.38;
}

.paid-blur {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.paid-blur p {
  margin: 0;
  color: var(--text);
  font-weight: 700;
}

.paid-blur span {
  color: var(--dim);
  font-size: 12px;
}

.course-paid-box.is-locked .primary-btn {
  position: relative;
  z-index: 1;
  align-self: center;
}

.membership-hero {
  min-height: calc(100vh - var(--header-h));
  display: flex;
  align-items: center;
  padding: 80px 0;
}

.membership-panel {
  padding: 52px;
  border-radius: 34px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background:
    radial-gradient(circle at 80% 20%, rgba(125, 211, 252, 0.16), transparent 34%),
    rgba(31, 45, 69, 0.68);
}

.membership-panel h1 {
  max-width: 720px;
  margin: 14px 0;
  font-size: clamp(42px, 7vw, 92px);
  line-height: 0.95;
  letter-spacing: -0.07em;
}

.membership-panel p {
  max-width: 620px;
  color: var(--muted);
  line-height: 1.85;
}

.membership-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 26px;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  height: var(--header-h);
  backdrop-filter: blur(22px);
  background:
    linear-gradient(180deg, rgba(40, 56, 84, 0.74), rgba(31, 45, 69, 0.58));
  border-bottom: 1px solid rgba(238, 242, 247, 0.025);
  transition: background 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease;
}

.site-header.is-scrolled {
  background:
    linear-gradient(180deg, rgba(36, 50, 76, 0.88), rgba(29, 42, 64, 0.8));
  border-color: rgba(238, 242, 247, 0.04);
  box-shadow: 0 10px 22px rgba(7, 13, 26, 0.08);
}

.site-header .wrap {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.brand-mark {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background:
    linear-gradient(135deg, rgba(139, 220, 255, 0.14), rgba(139, 220, 255, 0.04)),
    rgba(255, 255, 255, 0.025);
  display: grid;
  place-items: center;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: var(--text);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 8px 18px rgba(7, 13, 26, 0.08);
}

.brand-copy {
  min-width: 0;
}

.brand-copy strong {
  display: block;
  font-size: 15px;
  letter-spacing: 0.16em;
}

.brand-copy span {
  display: block;
  margin-top: 2px;
  color: var(--dim);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.nav-shell {
  display: flex;
  align-items: center;
  gap: 12px;
}

.nav-menu {
  display: flex;
  align-items: center;
  gap: 4px;
}

.nav-menu a {
  padding: 9px 13px;
  border-radius: 999px;
  color: rgba(238, 242, 247, 0.58);
  font-size: 12px;
  transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.nav-menu a:hover,
.nav-menu a.is-active {
  color: rgba(238, 242, 247, 0.84);
  background: rgba(255, 255, 255, 0.035);
}

.nav-menu a.is-active {
  color: rgba(238, 242, 247, 0.86);
  box-shadow: inset 0 0 0 1px rgba(238, 242, 247, 0.05);
}

.nav-cta,
.primary-btn,
.ghost-btn,
.tiny-btn,
.footer-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 999px;
  transition: transform 0.22s ease, background 0.22s ease, color 0.22s ease, border-color 0.22s ease;
}

.nav-cta,
.primary-btn {
  padding: 13px 22px;
  background: var(--accent);
  color: #08111e;
  font-weight: 700;
}

.nav-cta {
  padding: 10px 15px;
  font-size: 12px;
  box-shadow: 0 10px 24px rgba(139, 220, 255, 0.14);
}

.nav-cta:hover,
.primary-btn:hover {
  transform: translateY(-1px);
  background: #b2e9ff;
}

.home-hero .primary-btn {
  box-shadow: 0 14px 32px rgba(125, 211, 252, 0.22);
}

.home-hero .ghost-btn {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(238, 242, 247, 0.14);
}

.home-hero .ghost-btn:hover {
  background: rgba(255, 255, 255, 0.1);
}

.ghost-btn {
  padding: 13px 22px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  border: 1px solid var(--line);
}

.ghost-btn:hover {
  background: rgba(255, 255, 255, 0.08);
}

.mobile-toggle {
  display: none;
  width: 38px;
  height: 38px;
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(238, 242, 247, 0.08);
  color: var(--text);
}

.mobile-panel {
  display: none;
  position: fixed;
  top: calc(var(--header-h) + 12px);
  left: 20px;
  right: 20px;
  z-index: 39;
  padding: 16px;
  border-radius: 24px;
  border: 1px solid var(--line);
  background: rgba(19, 28, 45, 0.96);
  box-shadow: var(--shadow);
}

.mobile-panel.is-open {
  display: grid;
  gap: 8px;
}

.mobile-panel a,
.mobile-panel button {
  width: 100%;
  justify-content: flex-start;
  padding: 14px 16px;
  border-radius: 16px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.04);
}

.hero {
  position: relative;
  padding: 72px 0 48px;
  overflow: hidden;
}

.hero::after {
  content: '';
  position: absolute;
  right: -120px;
  top: 32px;
  width: 420px;
  height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(125, 211, 252, 0.18), transparent 68%);
  filter: blur(18px);
  pointer-events: none;
}

.hero-grid,
.split-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 36px;
  align-items: center;
}

.hero-copy {
  position: relative;
  z-index: 1;
  max-width: 360px;
  transform: translateY(-8px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.hero-signature {
  display: grid;
  gap: 6px;
  margin-top: 16px;
  width: 100%;
}

.hero-signature strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(32px, 3.5vw, 54px);
  line-height: 0.98;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--text);
  text-shadow: 0 8px 26px rgba(7, 13, 26, 0.28);
  width: 100%;
}

.hero-signature span {
  color: rgba(238, 242, 247, 0.68);
  font-size: 11px;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  padding-left: 2px;
}

.hero-whisper,
.cases-hero-note {
  margin-top: 12px;
  color: rgba(238, 242, 247, 0.68);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.campaign-hero-grid {
  display: grid;
  grid-template-columns: 0.64fr 1.36fr;
  gap: 42px;
  align-items: center;
}

.home-hero .campaign-hero-grid {
  align-items: start;
}

.hero-actions {
  margin-top: 18px;
  gap: 9px;
}

.home-hero .primary-btn,
.home-hero .ghost-btn {
  padding: 10px 16px;
  font-size: 12px;
}

.hero-copy .eyebrow {
  min-width: 158px;
  justify-content: center;
}

.hero-copy .hero-whisper {
  width: 100%;
  padding-left: 2px;
}

.hero-copy .hero-actions {
  width: 100%;
  justify-content: flex-start;
  padding-left: 2px;
}

.hero-showcase {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 12px;
}

.campaign-mosaic {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  grid-template-rows: repeat(3, minmax(140px, 1fr));
  gap: 14px;
  min-height: 700px;
}

.mosaic-panel {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background-color: rgba(34, 49, 74, 0.62);
  background-size: cover;
  background-position: center center;
  box-shadow: var(--shadow);
  transition: transform 0.45s ease, border-color 0.45s ease, box-shadow 0.45s ease;
}

.mosaic-panel::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(10, 16, 28, 0.18)),
    linear-gradient(135deg, rgba(139, 220, 255, 0.08), transparent 52%);
}

.mosaic-panel:hover {
  transform: translateY(-6px) scale(1.01);
  border-color: rgba(125, 211, 252, 0.24);
  box-shadow: 0 18px 44px rgba(7, 13, 26, 0.18);
}

.mosaic-panel-tall {
  grid-row: span 2;
}

.mosaic-panel-wide {
  grid-column: span 2;
}

.mosaic-overlay {
  position: absolute;
  inset: 22px;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.mosaic-overlay-bottom {
  justify-content: flex-end;
}

.mosaic-title {
  margin-top: auto;
  font-size: clamp(18px, 1.8vw, 28px);
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-hero .showcase-meta,
.home-hero .showcase-tags span {
  color: rgba(238, 248, 255, 0.92);
}

.showcase-frame,
.showcase-card,
.story-card,
.industry-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    rgba(17, 24, 39, 0.88);
  box-shadow: var(--shadow);
}

.campaign-band {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 24px;
  padding: 0;
}

.campaign-band-copy {
  font-size: 11px;
  line-height: 1;
  letter-spacing: 0.26em;
  color: rgba(238, 242, 247, 0.52);
  text-transform: uppercase;
}

.campaign-band-mark {
  color: var(--dim);
  font-size: 10px;
  letter-spacing: 0.36em;
  text-transform: uppercase;
}

.campaign-panel-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.campaign-panel {
  min-height: 180px;
  padding: 24px;
  border-radius: 34px;
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.025)),
    rgba(27, 39, 60, 0.7);
  box-shadow: var(--shadow);
}

.campaign-silence {
  position: relative;
  min-height: 300px;
  overflow: hidden;
  border-radius: 32px;
  border: 1px solid rgba(238, 242, 247, 0.1);
  background-color: rgba(26, 38, 58, 0.76);
  background-size: cover;
  background-position: center center;
  box-shadow: var(--shadow);
}

.campaign-silence::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.025), rgba(10, 16, 28, 0.34)),
    linear-gradient(135deg, rgba(139, 220, 255, 0.08), transparent 52%);
}

.campaign-silence-copy {
  position: absolute;
  inset: auto 28px 28px 28px;
  z-index: 1;
}

.campaign-silence-copy span {
  color: rgba(255, 255, 255, 0.84);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.campaign-panel h3 {
  margin: 18px 0 0;
  font-size: 16px;
  line-height: 1.3;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.campaign-panel-cta {
  display: grid;
  place-items: end start;
}

.campaign-poster-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.campaign-poster {
  position: relative;
  min-height: 280px;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(238, 242, 247, 0.1);
  background-color: rgba(26, 38, 58, 0.76);
  background-size: cover;
  background-position: center center;
  box-shadow: var(--shadow);
  transition: transform 0.45s ease, border-color 0.45s ease;
}

.campaign-poster::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.025), rgba(10, 16, 28, 0.32)),
    linear-gradient(135deg, rgba(139, 220, 255, 0.08), transparent 52%);
}

.campaign-poster:hover {
  transform: translateY(-8px);
  border-color: rgba(125, 211, 252, 0.28);
}

.campaign-poster:nth-child(2) {
  margin-top: 14px;
}

.campaign-poster-copy {
  position: absolute;
  inset: auto 28px 28px 28px;
  z-index: 1;
  display: grid;
  gap: 10px;
}

.campaign-poster-copy span {
  color: rgba(255, 255, 255, 0.86);
  font-size: 11px;
  letter-spacing: 0.26em;
}

.campaign-poster-copy strong {
  font-size: clamp(12px, 1vw, 15px);
  line-height: 1;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #fff;
}

.entry-marquee {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  padding: 10px 0;
}

.entry-marquee span {
  color: var(--text);
  font-size: clamp(16px, 1.4vw, 22px);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.entry-marquee span::after {
  content: '/';
  margin-left: 18px;
  color: rgba(84, 103, 125, 0.24);
}

.showcase-frame {
  min-height: 560px;
  padding: 34px;
  border-radius: 42px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.showcase-frame::before {
  content: '';
  position: absolute;
  inset: 22px;
  border-radius: 32px;
  background:
    radial-gradient(circle at 24% 24%, rgba(125, 211, 252, 0.24), transparent 24%),
    radial-gradient(circle at 74% 32%, rgba(163, 230, 53, 0.18), transparent 22%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015));
  border: 1px solid rgba(238, 242, 247, 0.08);
}

.showcase-frame::after {
  content: '';
  position: absolute;
  inset: auto 0 0;
  height: 48%;
  background: linear-gradient(180deg, transparent, rgba(9, 14, 25, 0.82));
}

.showcase-frame > * {
  position: relative;
  z-index: 1;
}

.showcase-meta,
.showcase-kicker,
.industry-index {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.showcase-meta,
.showcase-kicker {
  color: var(--accent);
}

.showcase-title {
  margin-top: 22px;
  max-width: 420px;
  font-size: clamp(42px, 4.6vw, 64px);
  line-height: 0.98;
  font-weight: 700;
  letter-spacing: -0.04em;
}

.showcase-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.showcase-line {
  width: 100%;
  max-width: 180px;
  height: 1px;
  margin-top: 18px;
  background: linear-gradient(90deg, rgba(125, 211, 252, 0.9), rgba(125, 211, 252, 0));
}

.showcase-tags span {
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(238, 242, 247, 0.12);
  background: rgba(9, 14, 25, 0.5);
  color: var(--text);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.showcase-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.film-strip {
  display: flex;
  gap: 18px;
  overflow: hidden;
  padding: 12px 18px;
  border-radius: 999px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background: rgba(255, 255, 255, 0.03);
  color: var(--dim);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  white-space: nowrap;
}

.film-strip span {
  position: relative;
}

.film-strip span::after {
  content: '•';
  margin-left: 18px;
  color: rgba(238, 242, 247, 0.2);
}

.showcase-card {
  min-height: 170px;
  padding: 24px;
  border-radius: 28px;
}

.showcase-card strong {
  display: block;
  margin-top: 14px;
  font-size: 26px;
  letter-spacing: -0.03em;
}

.showcase-card p {
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.75;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  border-radius: 999px;
  color: #d6f2ff;
  border: 1px solid rgba(125, 211, 252, 0.26);
  background: rgba(125, 211, 252, 0.12);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.eyebrow-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 6px rgba(125, 211, 252, 0.14);
}

.display-title,
.page-title,
.section-title {
  font-family: 'Noto Sans SC', sans-serif;
  letter-spacing: -0.04em;
  font-weight: 700;
  margin: 0;
}

.display-title {
  margin-top: 22px;
  font-size: clamp(24px, 2.2vw, 34px);
  line-height: 0.98;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.page-title {
  margin-top: 18px;
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.section-title {
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1;
}

.lead,
.page-lead,
.section-copy,
.card-copy,
.meta-copy {
  color: var(--muted);
  line-height: 1.8;
}

.lead,
.page-lead {
  max-width: 520px;
  margin-top: 20px;
  font-size: 12px;
  line-height: 1.7;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.hero-actions,
.section-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 28px;
}

.hero-note {
  margin-top: 16px;
  color: var(--dim);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.home-stats {
  background:
    linear-gradient(120deg, rgba(125, 211, 252, 0.1), rgba(163, 230, 53, 0.08)),
    rgba(17, 24, 39, 0.9);
}

.signature-band {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  padding: 18px 0 12px;
  color: var(--dim);
  font-size: 12px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.signature-band span {
  position: relative;
}

.signature-band span::after {
  content: '/';
  margin-left: 18px;
  color: rgba(238, 242, 247, 0.16);
}

.manifesto-shell {
  display: grid;
  grid-template-columns: 1.25fr repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.manifesto-panel {
  min-height: 280px;
  padding: 32px;
  border-radius: 34px;
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    rgba(17, 24, 39, 0.88);
  box-shadow: var(--shadow);
}

.manifesto-panel-lg {
  min-height: 420px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background:
    radial-gradient(circle at 18% 22%, rgba(125, 211, 252, 0.14), transparent 24%),
    radial-gradient(circle at 80% 74%, rgba(163, 230, 53, 0.1), transparent 18%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    rgba(17, 24, 39, 0.92);
}

.manifesto-title {
  margin: 18px 0 0;
  font-size: clamp(40px, 4vw, 66px);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.manifesto-copy {
  max-width: 430px;
  margin-top: 18px;
  color: var(--muted);
  line-height: 1.85;
}

.manifesto-index {
  color: var(--accent);
  font-size: 12px;
  letter-spacing: 0.18em;
}

.manifesto-panel h3 {
  margin: 20px 0 0;
  font-size: 28px;
  letter-spacing: -0.04em;
}

.manifesto-panel p {
  margin-top: 14px;
  color: var(--muted);
  line-height: 1.85;
}

.story-quote-block {
  max-width: 960px;
  padding: 54px 0 8px;
}

.story-quote-block p {
  margin: 0;
  font-size: clamp(34px, 4.4vw, 62px);
  line-height: 1.08;
  letter-spacing: -0.05em;
  color: var(--text);
}

.story-quote-block p + p {
  margin-top: 22px;
  color: var(--muted);
}

.spacious-grid .entry-card {
  min-height: 260px;
}

.airy-board .industry-card {
  min-height: 260px;
}

.airy-board .industry-card-wide {
  min-height: 540px;
}

.hero-actions-spaced {
  margin-top: 54px;
}

.signature-panel {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 22px;
  padding: 30px;
  border-radius: 34px;
  border: 1px solid var(--line);
  background:
    linear-gradient(125deg, rgba(125, 211, 252, 0.08), rgba(163, 230, 53, 0.06)),
    rgba(17, 24, 39, 0.9);
  box-shadow: var(--shadow);
}

.signature-grid {
  display: grid;
  gap: 14px;
}

.signature-item {
  padding: 18px 20px;
  border-radius: 22px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.signature-item strong {
  display: block;
  font-size: 18px;
}

.signature-item span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  line-height: 1.8;
  font-size: 14px;
}

.hero-card,
.glass-panel,
.feature-card,
.data-card,
.content-card,
.sidebar-card,
.auth-shell,
.footer-panel,
.stats-strip,
.pill-group {
  border: 1px solid var(--line);
  background: var(--panel);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow);
}

.hero-card,
.glass-panel,
.auth-shell {
  border-radius: var(--radius-lg);
}

.hero-card {
  padding: 26px;
  position: relative;
  overflow: hidden;
}

.hero-card::before {
  content: '';
  position: absolute;
  inset: auto auto 0 0;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(124, 180, 166, 0.18), transparent 72%);
  transform: translate(-30%, 35%);
}

.hero-mosaic {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 14px;
  min-height: 420px;
}

.hero-block,
.metric-tile,
.mini-card,
.quote-card,
.step-card,
.content-card,
.sidebar-card,
.resource-card,
.tutorial-card,
.mockup-card,
.tool-card {
  border-radius: 26px;
  overflow: hidden;
}

.hero-block {
  padding: 22px;
  position: relative;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01)),
    rgba(12, 19, 32, 0.82);
  border: 1px solid rgba(238, 242, 247, 0.08);
}

.hero-block.large {
  min-height: 320px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.hero-block.large::before {
  content: '';
  position: absolute;
  inset: 18px;
  border-radius: 20px;
  background:
    radial-gradient(circle at 20% 18%, rgba(239, 140, 47, 0.22), transparent 26%),
    radial-gradient(circle at 78% 28%, rgba(124, 180, 166, 0.18), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 100%);
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.hero-block.large > * {
  position: relative;
  z-index: 1;
}

.hero-block h3,
.mini-card h3,
.feature-card h3,
.data-card h3,
.content-card h3,
.tool-card h3,
.sidebar-card h3 {
  margin: 0;
  font-size: 18px;
}

.hero-block p,
.mini-card p,
.feature-card p,
.data-card p,
.content-card p,
.tool-card p,
.sidebar-card p {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.7;
  font-size: 14px;
}

.mosaic-side {
  display: grid;
  gap: 14px;
}

.mini-card {
  padding: 20px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(238, 242, 247, 0.08);
}

.mini-label {
  color: var(--accent-2);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
}

.metric-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.metric-tile {
  min-width: 150px;
  padding: 18px 20px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(238, 242, 247, 0.08);
}

.metric-tile strong {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: 42px;
  line-height: 0.95;
}

.metric-tile span {
  display: block;
  margin-top: 8px;
  color: var(--dim);
  font-size: 13px;
}

.section {
  padding: 52px 0;
}

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 42px;
  margin-bottom: 46px;
}

.story-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr 1fr;
  gap: 20px;
}

.story-card {
  min-height: 100%;
  padding: 28px;
  border-radius: 28px;
}

.story-card h3 {
  margin: 18px 0 0;
  font-size: 24px;
  letter-spacing: -0.03em;
}

.story-card p {
  margin: 14px 0 0;
  color: var(--muted);
  line-height: 1.9;
}

.story-card-quote {
  background:
    linear-gradient(140deg, rgba(125, 211, 252, 0.1), rgba(163, 230, 53, 0.06)),
    rgba(17, 24, 39, 0.92);
}

.story-quote {
  margin: 26px 0 0;
  font-size: 24px;
  line-height: 1.75;
  letter-spacing: -0.02em;
  color: var(--text);
}

.entry-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.entry-card {
  min-height: 220px;
}

.industry-board {
  display: grid;
  grid-template-columns: 1.2fr repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.industry-card {
  min-height: 220px;
  padding: 24px;
  border-radius: 28px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.industry-card-wide {
  grid-row: span 2;
  min-height: 458px;
  background:
    radial-gradient(circle at 18% 22%, rgba(125, 211, 252, 0.18), transparent 22%),
    radial-gradient(circle at 78% 72%, rgba(163, 230, 53, 0.12), transparent 20%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    rgba(17, 24, 39, 0.94);
}

.industry-index {
  color: var(--accent);
}

.industry-card h3 {
  margin: 18px 0 0;
  font-size: 26px;
  line-height: 1.15;
  letter-spacing: -0.04em;
}

.industry-card p {
  margin: 12px 0 0;
  color: var(--muted);
  line-height: 1.8;
}

.home-cta {
  align-items: flex-end;
}

.cases-hero-panel {
  display: grid;
  gap: 22px;
}

.cases-hero-banner {
  position: relative;
  min-height: 400px;
  overflow: hidden;
  border-radius: 32px;
  border: 1px solid rgba(238, 242, 247, 0.1);
  background-color: rgba(26, 38, 58, 0.76);
  background-size: cover;
  background-position: center center;
  box-shadow: var(--shadow);
}

.cases-hero-banner::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.025), rgba(10, 16, 28, 0.32)),
    linear-gradient(135deg, rgba(139, 220, 255, 0.08), transparent 48%);
}

.cases-hero-banner-copy {
  position: absolute;
  inset: auto 28px 28px 28px;
  z-index: 1;
  display: grid;
  gap: 14px;
}

.cases-hero-banner-copy span {
  color: rgba(255, 255, 255, 0.88);
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.cases-hero-banner-copy strong {
  font-size: 0;
}

.cases-hero-card,
.case-rail {
  padding: 28px;
  border-radius: 32px;
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.025)),
    rgba(27, 39, 60, 0.72);
  box-shadow: var(--shadow);
}

.cases-hero-card strong {
  display: block;
  margin-top: 16px;
  font-size: 30px;
  line-height: 1.08;
  letter-spacing: -0.04em;
}

.cases-hero-card p {
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.8;
}

.case-sidebar-premium {
  background:
    linear-gradient(180deg, rgba(125, 211, 252, 0.06), rgba(255, 255, 255, 0.015)),
    rgba(27, 39, 60, 0.74);
}

.case-sidebar-copy {
  display: grid;
  gap: 12px;
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 1px solid rgba(238, 242, 247, 0.08);
}

.case-sidebar-copy p {
  margin: 0;
  color: rgba(238, 242, 247, 0.62);
  font-size: 12px;
  line-height: 1.8;
}

.case-main {
  display: grid;
  gap: 18px;
}

.case-rail {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: end;
}

.case-rail-copy h2 {
  margin: 12px 0 0;
  font-size: 16px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.case-rail-meta {
  max-width: 320px;
  color: var(--muted);
  line-height: 1.8;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.case-card {
  padding: 20px;
  border-radius: 24px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02)),
    rgba(31, 45, 69, 0.68);
  transition: transform 0.4s ease, border-color 0.4s ease, box-shadow 0.4s ease;
}

.case-card:hover {
  transform: translateY(-4px);
  border-color: rgba(139, 220, 255, 0.18);
  box-shadow: 0 20px 48px rgba(7, 13, 26, 0.2);
}

.case-card-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 8px;
}

.case-card-index {
  color: var(--accent);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.case-card .card-topline h3 {
  font-size: 17px;
  line-height: 1.22;
  letter-spacing: 0.01em;
  text-transform: none;
}

.case-card .card-copy {
  max-width: 80%;
  min-height: auto;
  margin-top: 7px;
  font-size: 11px;
  line-height: 1.75;
  color: rgba(238, 242, 247, 0.54);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.case-card .case-video {
  margin-top: 14px;
  border-radius: 20px;
}

.case-insights .insight-item {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
    rgba(27, 39, 60, 0.7);
  min-height: 88px;
  display: flex;
  align-items: flex-end;
}

.case-card .tag-row {
  margin-top: 14px;
}

.brand-section-tight {
  padding-top: 0;
}

.brand-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 24px;
}

.brand-grid-course {
  grid-template-columns: 1.08fr 0.92fr;
}

.brand-panel {
  min-height: 210px;
  padding: 28px;
  border-radius: 28px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02)),
    rgba(31, 45, 69, 0.68);
  box-shadow: var(--shadow);
}

.brand-panel h3 {
  margin: 16px 0 0;
  font-size: 24px;
  line-height: 1.18;
  letter-spacing: -0.04em;
}

.brand-panel p {
  margin: 12px 0 0;
  max-width: 500px;
  color: rgba(238, 242, 247, 0.64);
  line-height: 1.8;
  font-size: 13px;
}

.brand-panel-wide {
  min-height: 300px;
}

.brand-panel-visual {
  position: relative;
  min-height: 438px;
  overflow: hidden;
  background-color: rgba(26, 38, 58, 0.76);
  background-size: cover;
  background-position: center center;
  border-radius: 28px;
}

.brand-panel-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.025), rgba(10, 16, 28, 0.28)),
    linear-gradient(135deg, rgba(139, 220, 255, 0.07), transparent 52%);
}

.brand-panel-overlay {
  position: absolute;
  inset: auto 26px 26px 26px;
  z-index: 1;
  display: grid;
  gap: 8px;
}

.brand-panel-overlay span {
  color: rgba(255, 255, 255, 0.82);
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.brand-panel-overlay strong {
  font-size: clamp(24px, 2.8vw, 40px);
  line-height: 0.98;
  letter-spacing: 0.04em;
}

.contact-grid {
  display: grid;
  grid-template-columns: 0.88fr 1.12fr;
  gap: 24px;
}

.contact-stack {
  display: grid;
  gap: 24px;
}

.brand-panel-contact {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.contact-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 24px;
}

.contact-mini-item {
  padding: 16px 16px 18px;
  border-radius: 22px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background: rgba(255, 255, 255, 0.04);
}

.contact-mini-item span {
  display: block;
  color: var(--dim);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.contact-mini-item strong {
  display: block;
  margin-top: 8px;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 600;
}

.section-kicker {
  color: var(--accent);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.feature-card,
.data-card,
.content-card,
.resource-card,
.tutorial-card,
.mockup-card,
.tool-card,
.sidebar-card {
  padding: 32px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.025)),
    rgba(27, 39, 60, 0.7);
  border: 1px solid var(--line);
}

.feature-index,
.card-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 11px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.pill-group {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
  padding: 12px;
  border-radius: 24px;
}

.pill,
.filter-btn,
.tab-btn,
.tool-nav-item,
.search-chip,
.page-btn {
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.07);
  color: var(--muted);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.pill,
.filter-btn,
.tab-btn,
.tool-nav-item,
.search-chip {
  padding: 8px 13px;
  font-size: 12px;
}

.pill.is-active,
.filter-btn.is-active,
.tab-btn.is-active,
.tool-nav-item.is-active,
.search-chip:hover,
.page-btn.is-active {
  color: #08111e;
  background: var(--accent);
  border-color: rgba(125, 211, 252, 0.4);
}

.timeline {
  display: grid;
  gap: 16px;
}

.step-card {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 18px;
  padding: 22px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.03);
}

.step-card strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: 34px;
  color: var(--accent);
}

.stats-strip {
  margin-top: 24px;
  padding: 28px;
  border-radius: 36px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.stats-strip .stat {
  padding: 10px 12px;
}

.stats-strip .stat strong {
  display: block;
  font-size: 30px;
  font-family: 'Cormorant Garamond', serif;
}

.stats-strip .stat span {
  display: block;
  color: var(--dim);
  font-size: 13px;
}

.page-hero {
  padding: 42px 0 16px;
}

.page-shell {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 20px;
  align-items: start;
}

.sidebar-card {
  position: sticky;
  top: calc(var(--header-h) + 20px);
}

.sidebar-stack,
.tool-nav,
.filter-stack {
  display: grid;
  gap: 10px;
}

.search-shell {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.search-input {
  width: 100%;
  padding: 13px 15px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
  font-size: 12px;
}

.search-input:focus {
  outline: none;
  border-color: rgba(125, 211, 252, 0.4);
}

.collection-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 30px;
}

.resource-card,
.tutorial-card,
.mockup-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.card-visual {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: 22px;
  overflow: hidden;
  background:
    radial-gradient(circle at 20% 18%, rgba(125, 211, 252, 0.16), transparent 26%),
    radial-gradient(circle at 78% 28%, rgba(139, 220, 255, 0.08), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01));
  border: 1px solid rgba(238, 242, 247, 0.08);
}

.card-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card-visual::after {
  content: '';
  position: absolute;
  inset: auto 0 0;
  height: 42%;
  background: linear-gradient(180deg, transparent, rgba(10, 16, 28, 0.56));
}

.card-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 1;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(17, 24, 39, 0.88);
  border: 1px solid rgba(238, 242, 247, 0.12);
  color: var(--text);
  font-size: 11px;
  letter-spacing: 0.08em;
}

.card-body {
  display: grid;
  gap: 14px;
  padding-top: 18px;
}

.card-topline {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
}

.card-topline h3 {
  margin: 0;
  font-size: 18px;
  line-height: 1.4;
}

.card-action {
  color: var(--accent);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tag-row span {
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(238, 242, 247, 0.06);
  color: rgba(238, 242, 247, 0.68);
  font-size: 9px;
  letter-spacing: 0.04em;
}

.card-locked {
  position: absolute;
  inset: auto 14px 14px 14px;
  z-index: 1;
  padding: 11px 14px;
  border-radius: 16px;
  background: rgba(12, 19, 32, 0.84);
  border: 1px solid rgba(125, 211, 252, 0.22);
  color: var(--text);
  font-size: 13px;
}

.pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-top: 28px;
}

.page-btn {
  min-width: 38px;
  height: 38px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}

.page-btn:disabled {
  opacity: 0.38;
  cursor: not-allowed;
}

.dual-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 20px;
}

.tool-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.tool-card {
  display: grid;
  gap: 14px;
}

.tool-top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.tool-logo {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  border: 1px solid rgba(238, 242, 247, 0.08);
  background:
    linear-gradient(135deg, rgba(125, 211, 252, 0.16), rgba(163, 230, 53, 0.12)),
    rgba(255, 255, 255, 0.04);
  display: grid;
  place-items: center;
  color: var(--text);
  font-weight: 700;
}

.tool-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.insight-list {
  display: grid;
  gap: 12px;
}

.insight-item {
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(238, 242, 247, 0.08);
}

.cta-band {
  padding: 34px;
  border-radius: 30px;
  background:
    linear-gradient(120deg, rgba(125, 211, 252, 0.16), rgba(163, 230, 53, 0.12)),
    rgba(17, 24, 39, 0.88);
  border: 1px solid rgba(238, 242, 247, 0.12);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}

.footer {
  padding: 18px 0 38px;
}

.footer-panel {
  padding: 24px;
  border-radius: 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.footer-copy {
  color: var(--dim);
  font-size: 12px;
  line-height: 1.8;
}

.case-sidebar .card-label {
  font-size: 11px;
  letter-spacing: 0.22em;
}

.filter-btn {
  font-size: 12px;
}

.footer-links {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.footer-btn {
  padding: 10px 14px;
  font-size: 13px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.07);
  color: var(--muted);
}

.cookie-bar {
  position: fixed;
  left: 20px;
  right: 20px;
  bottom: 20px;
  z-index: 45;
  padding: 14px 16px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: rgba(22, 33, 51, 0.9);
  box-shadow: var(--shadow);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
}

.cookie-bar.is-hidden {
  display: none;
}

.tiny-btn {
  padding: 10px 14px;
  background: var(--accent);
  color: #08111e;
  font-weight: 700;
}

.auth-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: none;
  place-items: center;
  padding: 24px;
  background: rgba(8, 12, 21, 0.74);
  backdrop-filter: blur(14px);
}

.auth-modal.is-open {
  display: grid;
}

.auth-shell {
  width: min(960px, 100%);
  display: grid;
  grid-template-columns: 1fr 380px;
  overflow: hidden;
}

.auth-brand {
  padding: 42px;
  background:
    radial-gradient(circle at 18% 16%, rgba(125, 211, 252, 0.22), transparent 26%),
    radial-gradient(circle at 82% 26%, rgba(163, 230, 53, 0.15), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01));
  border-right: 1px solid var(--line);
}

.auth-brand h2 {
  margin: 18px 0 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: 58px;
  line-height: 0.92;
}

.auth-brand p {
  margin-top: 18px;
  max-width: 420px;
  color: var(--muted);
  line-height: 1.85;
}

.auth-points {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}

.auth-points div {
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(238, 242, 247, 0.08);
  color: var(--muted);
}

.auth-form {
  padding: 42px 32px;
  display: grid;
  align-content: center;
  gap: 14px;
}

.auth-form h3 {
  margin: 0;
  font-size: 24px;
}

.auth-form p {
  margin: 0 0 6px;
  color: var(--dim);
  line-height: 1.7;
}

.field {
  display: grid;
  gap: 8px;
}

.field label {
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.field input {
  width: 100%;
  padding: 15px 16px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
}

.field input:focus {
  outline: none;
  border-color: rgba(125, 211, 252, 0.45);
}

.error-text {
  min-height: 22px;
  color: var(--danger);
  font-size: 13px;
}

.modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--line);
}

[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1080px) {
  .page-campaign-grid,
  .campaign-hero-grid,
  .hero-grid,
  .split-grid,
  .dual-grid,
  .page-shell {
    grid-template-columns: 1fr;
  }

  .cases-hero-grid,
  .campaign-panel-grid,
  .campaign-poster-grid,
  .brand-grid,
  .contact-grid,
  .manifesto-shell,
  .signature-panel {
    grid-template-columns: 1fr;
  }

  .campaign-panel-full {
    min-height: 320px;
    flex-direction: column;
    align-items: start;
    justify-content: end;
  }

  .campaign-mosaic {
    min-height: auto;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: repeat(3, 180px);
  }

  .story-grid {
    grid-template-columns: 1fr;
  }

  .entry-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .industry-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .industry-card-wide {
    grid-column: 1 / -1;
    grid-row: auto;
    min-height: 280px;
  }

  .case-rail {
    flex-direction: column;
    align-items: start;
  }

  .case-layout {
    grid-template-columns: 1fr;
  }

  .card-grid,
  .collection-grid,
  .tool-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .stats-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sidebar-card {
    position: static;
  }

  .case-sidebar {
    position: static;
  }
}

@media (max-width: 820px) {
  .site-header .nav-menu,
  .site-header .nav-cta {
    display: none;
  }

  .mobile-toggle {
    display: inline-grid;
    place-items: center;
  }

  .display-title {
    font-size: 40px;
  }

  .auth-shell {
    grid-template-columns: 1fr;
  }

  .auth-brand {
    display: none;
  }

  .cta-band,
  .section-head,
  .footer-panel {
    align-items: start;
    flex-direction: column;
  }

  .showcase-strip {
    grid-template-columns: 1fr;
  }

  .cases-hero {
    padding-top: 70px;
  }

  .campaign-band {
    flex-direction: column;
    align-items: start;
  }
}

@media (max-width: 640px) {
  .wrap {
    width: min(var(--wrap), calc(100% - 24px));
  }

  .hero,
  .home-hero,
  .page-campaign,
  .section {
    padding-top: 56px;
    padding-bottom: 56px;
  }

  .display-title {
    font-size: 32px;
  }

  .page-title {
    font-size: 28px;
  }

  .hero-card,
  .feature-card,
  .data-card,
  .content-card,
  .sidebar-card,
  .brand-panel,
  .resource-card,
  .tutorial-card,
  .mockup-card,
  .tool-card {
    padding: 18px;
  }

  .hero-mosaic,
  .card-grid,
  .collection-grid,
  .tool-grid,
  .simple-grid,
  .contact-mini-grid,
  .stats-strip,
  .entry-grid,
  .industry-board,
  .showcase-strip,
  .campaign-panel-grid,
  .campaign-poster-grid {
    grid-template-columns: 1fr;
  }

  .campaign-mosaic {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }

  .campaign-poster:nth-child(2) {
    margin-top: 0;
  }

  .mosaic-panel,
  .mosaic-panel-tall,
  .mosaic-panel-wide,
  .campaign-poster,
  .cases-hero-banner {
    min-height: 280px;
    grid-column: auto;
    grid-row: auto;
  }

  .lead-ribbon {
    gap: 8px;
  }

  .lead-ribbon span {
    font-size: 11px;
  }

  .showcase-frame {
    min-height: 320px;
    padding: 20px;
  }

  .showcase-title {
    font-size: 34px;
  }

  .campaign-title,
  .mosaic-title,
  .campaign-poster-copy strong,
  .cases-hero-banner-copy strong {
    font-size: 32px;
  }

  .story-card,
  .industry-card,
  .cases-hero-card,
  .case-rail,
  .signature-panel,
  .campaign-panel,
  .manifesto-panel {
    padding: 20px;
  }

  .story-quote {
    font-size: 20px;
  }

  .case-card .card-topline h3,
  .cases-hero-card strong,
  .case-rail-copy h2 {
    font-size: 24px;
  }

  .metric-row {
    display: grid;
    grid-template-columns: 1fr;
  }

  .step-card {
    grid-template-columns: 1fr;
  }

  .cookie-bar {
    left: 12px;
    right: 12px;
    bottom: 12px;
    flex-direction: column;
    align-items: stretch;
  }

  .prompt-modal {
    padding: 0;
    align-items: flex-end;
  }

  .prompt-modal-shell {
    width: 100%;
    max-height: min(90vh, 760px);
    border-radius: 22px 22px 0 0;
    border-bottom: 0;
  }

  .prompt-modal-head {
    padding: 18px 16px 12px;
    gap: 12px;
    flex-direction: column;
    align-items: stretch;
  }

  .prompt-modal-head h2 {
    margin: 8px 0 0;
    font-size: 20px;
    line-height: 1.35;
  }

  .prompt-copy-btn {
    width: 100%;
    min-height: 42px;
    justify-content: center;
  }

  .prompt-modal pre {
    max-height: calc(min(90vh, 760px) - 126px);
    padding: 16px 16px 24px;
    font-size: 13px;
    line-height: 1.8;
  }

  .course-library-hero {
    padding: 62px 0 28px;
  }

  .course-library-hero-grid,
  .course-lesson-card {
    grid-template-columns: 1fr;
  }

  .course-library-copy,
  .course-library-visual,
  .course-lesson-media {
    min-height: 260px;
  }

  .course-toolbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .course-filter-stack {
    justify-content: flex-start;
  }

  .course-lesson-body {
    padding: 18px;
  }

  .membership-panel {
    padding: 28px;
  }
}

body.home-rebuild {
  color: #2f2442;
  background:
    radial-gradient(circle at 50% -4%, rgba(183, 160, 255, 0.26), transparent 30%),
    radial-gradient(circle at 14% 34%, rgba(236, 219, 255, 0.68), transparent 24%),
    radial-gradient(circle at 84% 54%, rgba(234, 225, 255, 0.76), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, #fffdff 22%, #fdfaff 52%, #fffefe 100%);
}

body.home-rebuild::before {
  display: none;
}

.site-header-light {
  background: rgba(255, 255, 255, 0.62);
  border-bottom: 1px solid rgba(167, 143, 215, 0.14);
  backdrop-filter: blur(18px);
}

.site-header-light.is-scrolled {
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 18px 42px rgba(189, 171, 225, 0.18);
}

.brand-light .brand-mark {
  background: linear-gradient(135deg, #2f2442, #7d5be7);
  color: #fff;
}

.brand-light .brand-copy strong,
.nav-menu-light a,
.mobile-toggle-light {
  color: #302444;
}

.brand-light .brand-copy span,
.footer-copy-light,
.nav-menu-light a:not(.is-active) {
  color: rgba(48, 36, 68, 0.62);
}

.nav-menu-light a.is-active {
  color: #7f5de6;
}

.nav-cta-light {
  border-color: rgba(125, 93, 230, 0.16);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(245, 239, 255, 0.96));
  color: #6d49db;
  box-shadow: 0 12px 28px rgba(188, 164, 235, 0.2);
}

.mobile-panel-light {
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(170, 144, 225, 0.16);
}

.mobile-panel-light a,
.mobile-panel-light button {
  color: #302444;
}

.home-page {
  overflow: visible;
}

.home-narrow {
  width: min(1120px, calc(100% - 28px));
}

.home-hero-v2,
.home-cta {
  position: relative;
  overflow: hidden;
}

.home-hero-v2 {
  padding: 110px 0 48px;
  text-align: center;
}

.hero-halo {
  position: absolute;
  pointer-events: none;
  border-radius: 999px;
  filter: blur(4px);
}

.hero-halo-top {
  inset: 18px 50% auto;
  width: min(90vw, 620px);
  height: min(90vw, 620px);
  transform: translateX(-50%);
  border: 1px solid rgba(197, 169, 245, 0.24);
  background:
    radial-gradient(circle at center, rgba(230, 210, 255, 0.52) 0, rgba(244, 236, 255, 0.22) 38%, transparent 68%);
}

.hero-halo-left {
  left: -110px;
  top: 420px;
  width: 280px;
  height: 280px;
  background: radial-gradient(circle at center, rgba(217, 197, 255, 0.46), transparent 66%);
}

.hero-halo-bottom {
  inset: auto 50% -180px;
  width: min(88vw, 680px);
  height: min(88vw, 680px);
  transform: translateX(-50%);
  border: 1px solid rgba(200, 172, 248, 0.18);
  background:
    radial-gradient(circle at center, rgba(228, 205, 255, 0.44) 0, rgba(246, 238, 255, 0.14) 44%, transparent 72%);
}

.hero-phone-status {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 360px;
  margin: 0 auto 18px;
  color: rgba(49, 37, 71, 0.78);
  font-size: 11px;
  letter-spacing: 0.08em;
}

.hero-phone-icons {
  letter-spacing: 0.16em;
}

.hero-mark,
.cta-mark {
  color: rgba(140, 119, 196, 0.88);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.22em;
}

.home-hero-v2 h1,
.home-cta h2 {
  margin: 14px auto 0;
  max-width: 12ch;
  font-size: clamp(44px, 9vw, 78px);
  line-height: 1.04;
  letter-spacing: 0.18em;
  color: #241834;
}

.hero-subtitle {
  margin: 12px auto 0;
  color: rgba(55, 42, 83, 0.74);
  font-size: clamp(14px, 2.8vw, 20px);
  letter-spacing: 0.1em;
}

.hero-actions {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 22px;
}

.hero-pill {
  display: inline-flex;
  min-width: 110px;
  min-height: 38px;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(134, 106, 210, 0.12);
  background: rgba(255, 255, 255, 0.82);
  color: #7f5de6;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  box-shadow: 0 10px 24px rgba(214, 193, 245, 0.28);
}

.hero-pill.is-dark {
  background: #14101e;
  border-color: #14101e;
  color: #fff;
}

.home-section {
  padding: 28px 0;
}

.section-intro {
  text-align: center;
  margin-bottom: 22px;
}

.section-intro h2 {
  margin: 0;
  font-size: clamp(20px, 4vw, 30px);
  color: #261b38;
  letter-spacing: 0.04em;
}

.section-intro p {
  margin: 6px 0 0;
  color: rgba(58, 43, 86, 0.58);
}

.feature-card-grid,
.path-grid,
.showcase-grid,
.mission-grid,
.pain-section {
  display: grid;
  gap: 16px;
}

.feature-card-grid,
.path-grid,
.showcase-grid {
  grid-template-columns: 1fr;
}

.pastel-card,
.path-card,
.light-case-card {
  border-radius: 26px;
  border: 1px solid rgba(194, 174, 238, 0.24);
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 20px 40px rgba(215, 195, 245, 0.22);
}

.feature-card {
  padding: 18px 16px 16px;
}

.feature-card-art {
  height: 124px;
  margin-bottom: 14px;
  border-radius: 22px;
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #f7efff, #ffffff);
}

.feature-card-art::before,
.feature-card-art::after {
  content: '';
  position: absolute;
}

.art-book::before {
  inset: 20px auto auto 18px;
  width: 66px;
  height: 82px;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffddea, #ffffff);
  box-shadow: 12px 0 0 rgba(255, 230, 238, 0.7);
}

.art-book::after {
  right: 20px;
  top: 26px;
  width: 52px;
  height: 52px;
  border-radius: 18px;
  background: radial-gradient(circle at 34% 34%, #fff, #d6c7ff);
}

.art-window::before {
  inset: 22px 22px auto;
  height: 74px;
  border-radius: 20px;
  background: linear-gradient(180deg, #ede4ff, #ffffff);
  box-shadow: 0 18px 32px rgba(194, 174, 238, 0.24);
}

.art-window::after {
  left: 34px;
  top: 38px;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: linear-gradient(135deg, #8ea6ff, #cbb7ff);
  box-shadow: 62px 14px 0 -8px rgba(175, 211, 255, 0.82), 122px 0 0 -10px rgba(255, 221, 234, 0.9);
}

.art-squares::before {
  inset: 22px;
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 226, 238, 0.9), rgba(255, 255, 255, 0)),
    linear-gradient(225deg, rgba(193, 225, 255, 0.92), rgba(255, 255, 255, 0));
}

.art-squares::after {
  left: 36px;
  top: 38px;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: #ffffff;
  box-shadow: 66px 0 0 #ffffff, 132px 0 0 #ffffff, 0 50px 0 #ffffff, 66px 50px 0 #ffffff, 132px 50px 0 #ffffff;
}

.feature-card strong,
.path-card strong,
.light-case-card strong,
.showcase-body strong {
  display: block;
  font-size: 16px;
  color: #2d2140;
}

.feature-card p,
.path-card p,
.light-case-card span,
.showcase-body span,
.pain-copy p {
  margin: 8px 0 0;
  color: rgba(57, 43, 82, 0.66);
  line-height: 1.8;
  font-size: 13px;
}

.mission-grid {
  align-items: center;
}

.mission-copy {
  text-align: left;
}

.mission-copy h2,
.pain-copy h2 {
  margin: 0 0 14px;
  font-size: clamp(24px, 5vw, 36px);
  color: #291d3d;
}

.mission-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 12px;
}

.mission-list li {
  position: relative;
  padding-left: 22px;
  color: rgba(55, 42, 82, 0.7);
  line-height: 1.8;
}

.mission-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: 1px solid rgba(126, 91, 230, 0.36);
}

.mission-note {
  margin-top: 18px;
  padding: 10px 14px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(213, 190, 255, 0.94), rgba(196, 175, 255, 0.82));
  color: #52348c;
  text-align: center;
  font-size: 12px;
}

.mission-visual {
  position: relative;
  min-height: 300px;
  display: grid;
  place-items: center;
}

.mission-orb {
  position: absolute;
  width: min(72vw, 320px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 34% 32%, rgba(255, 255, 255, 0.92), rgba(226, 211, 255, 0.9) 34%, rgba(174, 156, 230, 0.26) 72%, rgba(255, 255, 255, 0) 74%);
  box-shadow: inset 0 -18px 40px rgba(126, 100, 198, 0.18);
}

.mission-phone {
  position: relative;
  z-index: 1;
  width: 164px;
  min-height: 232px;
  padding: 12px 10px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(232, 225, 255, 0.92));
  border: 1px solid rgba(191, 172, 235, 0.44);
  box-shadow: 0 26px 54px rgba(170, 144, 225, 0.3);
  transform: rotate(6deg);
}

.mission-phone-head {
  width: 54px;
  height: 6px;
  border-radius: 999px;
  margin: 0 auto 12px;
  background: rgba(78, 59, 116, 0.16);
}

.mission-phone-screen {
  padding: 10px;
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff, #f5f0ff);
}

.stat-chip {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 216, 224, 0.9);
  color: #cb5875;
  font-size: 11px;
  font-weight: 700;
}

.screen-card {
  height: 42px;
  margin-top: 10px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(204, 227, 255, 0.92), rgba(255, 255, 255, 0.98));
}

.screen-card.is-wide {
  height: 60px;
  background: linear-gradient(135deg, rgba(255, 231, 239, 0.98), rgba(255, 255, 255, 0.98));
}

.screen-dots {
  display: flex;
  gap: 8px;
  margin-top: 14px;
}

.screen-dots span {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: rgba(119, 164, 255, 0.84);
}

.mission-float {
  position: absolute;
  border-radius: 18px;
  box-shadow: 0 18px 32px rgba(171, 148, 230, 0.24);
}

.mission-float.is-cube {
  left: calc(50% - 130px);
  top: 22px;
  width: 32px;
  height: 32px;
  background: linear-gradient(135deg, #dff2ff, #b0c0ff);
}

.mission-float.is-ball {
  right: calc(50% - 120px);
  top: 16px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, #d486fb, #ff9bc8);
}

.mission-float.is-coin {
  right: calc(50% - 148px);
  top: 88px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ffffff, #a8beff);
}

.pain-section {
  align-items: center;
}

.pain-visual {
  position: relative;
  min-height: 300px;
}

.pain-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(239, 229, 255, 0.96) 0 46%, rgba(230, 218, 255, 0.68) 46% 62%, rgba(255, 255, 255, 0) 62%);
}

.pain-illustration {
  position: absolute;
  inset: 26px;
}

.board {
  position: absolute;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(236, 242, 255, 0.96));
  box-shadow: 0 18px 32px rgba(205, 190, 242, 0.26);
}

.board-main {
  inset: 28px 46px 42px 34px;
}

.board-side {
  width: 78px;
  height: 56px;
  right: 26px;
  top: 72px;
}

.person {
  position: absolute;
  left: 88px;
  bottom: 32px;
  width: 120px;
  height: 140px;
}

.person span {
  position: absolute;
  display: block;
}

.person .head {
  left: 20px;
  top: 6px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #2c2748;
}

.person .body {
  left: 10px;
  top: 34px;
  width: 72px;
  height: 70px;
  border-radius: 18px;
  background: linear-gradient(180deg, #5e92ff, #4d75ff);
  transform: skewX(-10deg);
}

.person .leg {
  width: 18px;
  height: 66px;
  bottom: 0;
  border-radius: 999px;
  background: #1f1a31;
}

.person .leg-left {
  left: 34px;
  transform: rotate(10deg);
}

.person .leg-right {
  left: 60px;
  transform: rotate(-14deg);
}

.pain-list {
  display: grid;
  gap: 14px;
}

.pain-list article {
  padding-left: 18px;
  border-left: 1px solid rgba(201, 183, 240, 0.38);
}

.pain-tag {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 14px;
  border-radius: 999px;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.pain-tag.is-lilac {
  background: linear-gradient(90deg, #b693f5, #d2b2ff);
}

.pain-tag.is-green {
  background: linear-gradient(90deg, #47c782, #79de8e);
}

.pain-tag.is-blue {
  background: linear-gradient(90deg, #69abff, #7dbbff);
}

.pain-tag.is-indigo {
  background: linear-gradient(90deg, #738cff, #a592ff);
}

.path-card {
  padding: 20px 18px;
  text-align: center;
}

.path-icon {
  width: 52px;
  height: 52px;
  margin: 0 auto 12px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(204, 186, 255, 0.74), rgba(255, 255, 255, 0.98));
  box-shadow: inset 0 10px 22px rgba(255, 255, 255, 0.88);
}

.path-icon.is-alt {
  background: linear-gradient(180deg, rgba(197, 214, 255, 0.78), rgba(255, 255, 255, 0.98));
}

.path-icon.is-soft {
  background: linear-gradient(180deg, rgba(255, 218, 236, 0.78), rgba(255, 255, 255, 0.98));
}

.section-dark {
  margin-top: 18px;
  background: #07060c;
}

.section-intro-dark h2,
.section-intro-dark p {
  color: #fff;
}

.showcase-grid-dark .showcase-card {
  background: linear-gradient(180deg, rgba(34, 28, 49, 0.98), rgba(15, 12, 22, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: none;
}

.showcase-card {
  overflow: hidden;
  border-radius: 24px;
}

.showcase-cover,
.light-case-cover {
  background-size: cover;
  background-position: center;
}

.showcase-cover {
  height: 180px;
}

.showcase-body {
  padding: 16px;
}

.showcase-grid-dark .showcase-body strong {
  color: #fff;
}

.showcase-grid-dark .showcase-body span {
  color: rgba(255, 255, 255, 0.62);
}

.light-case-card {
  padding: 12px;
}

.light-case-cover {
  height: 180px;
  border-radius: 18px;
  margin-bottom: 12px;
}

.home-cta {
  padding: 54px 0 78px;
  text-align: center;
}

.footer-light {
  padding: 0 0 34px;
  background: transparent;
}

.footer-copy-light {
  text-align: center;
  font-size: 12px;
}

@media (min-width: 768px) {
  .home-narrow {
    width: min(1120px, calc(100% - 52px));
  }

  .home-hero-v2 {
    padding-top: 128px;
  }

  .feature-card-grid,
  .path-grid,
  .showcase-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .mission-grid,
  .pain-section {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 34px;
  }

  .showcase-grid-dark {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .showcase-grid:not(.showcase-grid-dark) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .site-header-light .nav-menu,
  .site-header-light .nav-cta {
    display: none;
  }

  .site-header-light .mobile-toggle {
    display: inline-flex;
  }

  .home-hero-v2 h1,
  .home-cta h2 {
    letter-spacing: 0.12em;
  }

  .mission-note {
    font-size: 11px;
  }
}

body.poster-site {
  margin: 0;
  min-height: 100vh;
  color: #1f1730;
  background:
    radial-gradient(circle at 50% -12%, rgba(203, 178, 255, 0.34), transparent 24%),
    linear-gradient(180deg, #f8f4ff 0%, #f3ecff 100%);
  font-family: 'Noto Sans SC', sans-serif;
}

body.poster-site::before {
  display: none;
}

.poster-header {
  position: sticky;
  top: 0;
  z-index: 40;
  padding: 16px 18px;
  backdrop-filter: blur(18px);
  background: rgba(248, 244, 255, 0.84);
  border-bottom: 1px solid rgba(166, 136, 225, 0.14);
}

.poster-header-inner {
  width: min(1280px, calc(100% - 8px));
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.poster-brand {
  flex-shrink: 0;
  color: #2d2140;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.poster-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.poster-nav a {
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  border-radius: 999px;
  color: rgba(45, 33, 64, 0.72);
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid rgba(181, 157, 235, 0.16);
  box-shadow: 0 10px 24px rgba(184, 164, 228, 0.12);
  font-size: 13px;
  font-weight: 600;
}

.poster-nav a.is-active {
  color: #fff;
  background: linear-gradient(135deg, #181120, #8a62ea);
  border-color: transparent;
}

.poster-main {
  padding: 22px 14px 40px;
}

.poster-shell {
  width: min(1280px, 100%);
  margin: 0 auto;
  padding: 18px;
  border-radius: 34px;
  background: rgba(255, 255, 255, 0.46);
  border: 1px solid rgba(192, 172, 235, 0.18);
  box-shadow: 0 28px 64px rgba(174, 145, 236, 0.14);
}

.poster-art {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 22px;
  box-shadow: 0 26px 72px rgba(99, 74, 162, 0.12);
}

@media (max-width: 860px) {
  .poster-header-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .poster-nav {
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .poster-header {
    padding: 12px;
  }

  .poster-nav {
    gap: 6px;
  }

  .poster-nav a {
    min-height: 34px;
    padding: 0 12px;
    font-size: 12px;
  }

  .poster-main {
    padding: 14px 8px 28px;
  }

  .poster-shell {
    padding: 10px;
    border-radius: 20px;
  }

  .poster-art {
    border-radius: 12px;
  }
}

body.site-native {
  margin: 0;
  color: #261d38;
  background:
    radial-gradient(circle at 50% -8%, rgba(205, 181, 255, 0.34), transparent 22%),
    radial-gradient(circle at 12% 34%, rgba(245, 231, 255, 0.9), transparent 24%),
    radial-gradient(circle at 86% 54%, rgba(235, 244, 255, 0.82), transparent 22%),
    linear-gradient(180deg, #fffefe 0%, #fbf7ff 44%, #f6f0ff 100%);
  font-family: 'Noto Sans SC', sans-serif;
}

body.site-native::before {
  display: none;
}

body.site-native {
  --native-header-bg: rgba(255, 252, 255, 0.84);
  --native-header-border: rgba(186, 164, 228, 0.14);
  --native-header-blur: blur(20px);
  --native-brand-color: #5b526f;
  --native-brand-glow-opacity: 1;
  --native-nav-color: rgba(108, 92, 162, 0.88);
  --native-nav-active: #8f79ec;
  --native-login-bg: linear-gradient(180deg, #ab94ff, #8f77f5);
  --native-login-text: #fff;
  --native-login-border: rgba(151, 124, 245, 0.2);
  --native-login-shadow: 0 10px 24px rgba(151, 124, 245, 0.22);
}

.native-header {
  position: sticky;
  top: 0;
  z-index: 30;
  padding: 18px 18px;
  background: var(--native-header-bg);
  border-bottom: 1px solid var(--native-header-border);
  backdrop-filter: var(--native-header-blur);
}

.native-header-inner,
.native-wrap {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
}

.native-header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 22px;
  min-height: 42px;
}

.native-brand {
  position: relative;
  padding-left: 32px;
  color: var(--native-brand-color);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.native-brand::before,
.native-brand::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  width: 15px;
  height: 17px;
  border-radius: 16px 16px 4px 16px;
  transform: translateY(-50%) rotate(-18deg);
  background: linear-gradient(180deg, rgba(238, 211, 255, 0.96), rgba(173, 140, 255, 0.96));
  box-shadow: 0 8px 18px rgba(173, 140, 255, 0.36);
  opacity: var(--native-brand-glow-opacity);
}

.native-brand::after {
  left: 10px;
  transform: translateY(-50%) rotate(18deg);
}

.native-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
}

.native-nav a,
.native-nav-login,
.native-nav-logout {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 13px;
  border-radius: 12px;
  background: transparent;
  border: 1px solid transparent;
  box-shadow: none;
  color: var(--native-nav-color);
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
  line-height: 1;
}

.native-nav a.is-active {
  color: var(--native-nav-active);
}

.native-nav-login {
  background: var(--native-login-bg);
  color: var(--native-login-text);
  border-color: var(--native-login-border);
  box-shadow: var(--native-login-shadow);
  min-width: 92px;
  height: 38px;
  padding: 0 16px;
}

.native-nav-login,
.native-nav-logout {
  cursor: pointer;
}

.native-nav-logout {
  color: rgba(95, 87, 124, 0.9);
  border-color: rgba(186, 164, 228, 0.2);
  background: rgba(255, 255, 255, 0.42);
}

.native-main {
  padding: 18px 0 56px;
}

.home-page .native-header-inner,
.course-gallery-page .native-header-inner,
.cases-gallery-page .native-header-inner,
.course-detail-page .native-header-inner,
.cases-detail-page .native-header-inner,
.contact-page .native-header-inner,
.membership-page .native-header-inner {
  width: min(1436px, calc(100% - 196px));
}

.native-hero,
.native-page-hero,
.native-section {
  padding: 34px 0;
}

.native-hero-grid,
.native-page-hero-grid,
.native-detail-layout,
.native-contact-grid,
.native-login-layout {
  display: grid;
  gap: 22px;
}

.native-hero-home {
  position: relative;
  padding-top: 24px;
}

.native-hero-home::before {
  content: '';
  position: absolute;
  left: 50%;
  top: -36px;
  width: min(86vw, 920px);
  aspect-ratio: 1;
  transform: translateX(-50%);
  border-radius: 50%;
  border: 1px solid rgba(213, 188, 255, 0.44);
  background:
    radial-gradient(circle at center, rgba(250, 241, 255, 0.86) 0, rgba(244, 227, 255, 0.28) 34%, rgba(255,255,255,0) 70%);
  pointer-events: none;
}

.native-hero-home-shell {
  display: grid;
  gap: 18px;
}

.native-hero-grid,
.native-page-hero-grid {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 460px);
  align-items: center;
}

.native-hero-grid-home {
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 420px);
  min-height: 560px;
  padding: 52px 64px 68px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 72% 38%, rgba(255, 191, 170, 0.56), transparent 24%),
    radial-gradient(circle at 88% 58%, rgba(255, 216, 128, 0.74), transparent 18%),
    radial-gradient(circle at 66% 24%, rgba(214, 187, 255, 0.64), transparent 20%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,250,255,0.92));
  box-shadow: 0 26px 60px rgba(200, 182, 233, 0.18);
  position: relative;
  overflow: hidden;
}

.native-hero-grid-home::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% -14%, rgba(199, 176, 255, 0.26), transparent 40%),
    linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(248,242,255,0.28) 100%);
  pointer-events: none;
}

.native-kicker {
  color: #8a72c8;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.native-hero h1,
.native-page-hero h1,
.native-cta-panel h2,
.native-detail-copy h1,
.native-login-copy h1 {
  margin: 10px 0 0;
  font-size: clamp(34px, 6vw, 62px);
  line-height: 1.08;
  color: #251b38;
}

.native-copy-center {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}

.native-copy-home {
  position: relative;
  z-index: 1;
  max-width: 540px;
}

.native-subtitle {
  margin-top: 10px;
  font-size: clamp(20px, 2.6vw, 32px);
  color: rgba(52, 40, 80, 0.86);
  font-weight: 500;
}

.native-body {
  margin-top: 14px;
  color: rgba(58, 44, 87, 0.68);
  line-height: 1.9;
}

.native-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
  justify-content: flex-start;
}

.native-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(157, 130, 223, 0.18);
  background: rgba(255, 255, 255, 0.76);
  color: #7d5be7;
  box-shadow: 0 12px 30px rgba(191, 174, 234, 0.2);
  font-size: 13px;
  font-weight: 700;
}

.native-btn.is-dark {
  background: #15101f;
  border-color: #15101f;
  color: #fff;
}

.native-btn-block {
  width: 100%;
}

.native-poster-card,
.native-mini-poster,
.native-card,
.native-side-card,
.native-form-card,
.native-cta-panel,
.native-detail-media,
.native-detail-copy,
.native-feature-card,
.native-path-card,
.native-learning-card {
  border-radius: 24px;
  border: 1px solid rgba(191, 171, 234, 0.18);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 22px 48px rgba(178, 156, 225, 0.18);
}

.native-poster-card,
.native-mini-poster {
  overflow: hidden;
  padding: 12px;
}

.native-poster-home {
  width: min(100%, 860px);
  margin: 0 auto;
  padding: 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(250,246,255,.92)),
    url('/download/BG@1x.png') center/cover no-repeat;
}

.native-poster-home img {
  max-height: 520px;
  object-fit: cover;
  object-position: top center;
}

.native-poster-card img,
.native-mini-poster img,
.native-detail-media img,
.native-card-media img,
.native-side-preview,
.native-hero-card img,
.native-illustration img,
.native-learning-media img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 18px;
}

.native-hero-visual {
  position: relative;
  min-height: 360px;
  z-index: 1;
}

.native-hero-glow {
  position: absolute;
  inset: 50px 0 0 40px;
  background:
    radial-gradient(circle at 50% 50%, rgba(156, 122, 255, 0.46), rgba(156, 122, 255, 0.12) 36%, transparent 68%);
  filter: blur(10px);
}

.native-hero-ring {
  position: absolute;
  inset: -160px -80px auto auto;
  width: 460px;
  height: 460px;
  border-radius: 50%;
  border: 1px solid rgba(201, 175, 246, 0.34);
}

.native-hero-card {
  position: absolute;
  overflow: hidden;
  border-radius: 20px;
  box-shadow: 0 28px 48px rgba(53, 31, 90, 0.24);
}

.native-hero-card-back {
  top: 10px;
  right: 8px;
  width: 180px;
  transform: rotate(0.5deg);
}

.native-hero-card-front {
  left: 6px;
  bottom: 22px;
  width: 228px;
}

.native-section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 12px;
  margin-bottom: 16px;
}

.native-section-home {
  position: relative;
}

.native-section-home::before {
  content: '';
  position: absolute;
  inset: 30px 0 auto;
  height: 280px;
  background: radial-gradient(circle at 50% 20%, rgba(228, 205, 255, 0.26), transparent 52%);
  pointer-events: none;
}

.native-section-head h2 {
  margin: 8px 0 0;
  font-size: 28px;
  line-height: 1.24;
}

.native-link {
  color: #7d5be7;
  font-weight: 700;
}

.native-home-intro {
  max-width: 640px;
  margin: 0 auto 24px;
  text-align: center;
}

.native-home-intro-lead,
.native-section-mini {
  margin: 0;
  color: #7e6cae;
  font-size: 12px;
  font-weight: 700;
}

.native-home-intro h2 {
  margin: 10px 0 0;
  font-size: clamp(26px, 4vw, 50px);
  line-height: 1.24;
}

.native-home-intro-compact {
  margin-bottom: 22px;
}

.native-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.native-feature-card {
  padding: 28px 24px;
  text-align: center;
  background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(248,243,255,0.92));
}

.native-feature-card-poster {
  text-align: left;
  padding: 16px 16px 18px;
  border-radius: 22px;
}

.native-feature-poster {
  aspect-ratio: 1.18 / 1;
  margin-bottom: 14px;
  border-radius: 18px;
  background-size: cover;
  background-position: center;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.42);
}

.native-feature-card.is-pink .native-feature-poster {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.18), rgba(255,255,255,0) 40%),
    url('/download/BG@1x.png') center/cover no-repeat;
}

.native-feature-card.is-purple .native-feature-poster {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.18), rgba(255,255,255,0) 40%),
    url('/download/BG@1x-2.png') center/cover no-repeat;
}

.native-feature-card.is-violet .native-feature-poster {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.18), rgba(255,255,255,0) 40%),
    url('/download/BG@1x-3.png') center/cover no-repeat;
}

.native-feature-poster-a::after,
.native-feature-poster-b::after,
.native-feature-poster-c::after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.native-feature-poster-a::after {
  background-image: url('/download/切图 1.png');
}

.native-feature-poster-b::after {
  background-image: url('/download/切图 2.png');
}

.native-feature-poster-c::after {
  background-image: url('/download/切图 4.png');
}

.native-feature-card h3,
.native-path-card h3,
.native-pain-item h3,
.native-learning-copy h3,
.native-showcase-copy h3 {
  margin: 0;
  font-size: 18px;
}

.native-feature-card p,
.native-path-card p,
.native-learning-copy p,
.native-showcase-copy p,
.native-pain-item p {
  margin: 10px 0 0;
  color: rgba(58, 44, 87, 0.68);
  line-height: 1.78;
  font-size: 13px;
}

.native-split {
  display: grid;
  gap: 28px;
  align-items: center;
}

.native-split-what {
  grid-template-columns: minmax(0, 0.78fr) minmax(320px, 420px);
}

.native-split-pain {
  grid-template-columns: minmax(340px, 460px) minmax(0, 1fr);
}

.native-split-copy h2 {
  margin: 0;
  font-size: clamp(26px, 3.8vw, 42px);
}

.native-check-list {
  display: grid;
  gap: 14px;
  padding: 0;
  margin: 26px 0 0;
  list-style: none;
}

.native-check-list li {
  position: relative;
  padding-left: 26px;
  color: rgba(58, 44, 87, 0.82);
  font-weight: 500;
}

.native-check-list li::before {
  content: '◉';
  position: absolute;
  left: 0;
  top: 0;
  color: #7f6fba;
  font-size: 12px;
}

.native-note-bar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  margin-top: 24px;
  padding: 0 18px;
  border-radius: 999px;
  background: linear-gradient(180deg, #dcc7ff, #c6adff);
  color: #5f4f89;
  font-size: 12px;
  font-weight: 600;
}

.native-logo-band {
  padding: 18px 0;
  background: linear-gradient(180deg, #1a1528, #0f0c18);
}

.native-logo-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px 18px;
  color: rgba(255,255,255,0.72);
  font-size: 12px;
  font-weight: 700;
}

.native-logo-grid span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 24px;
}

.native-logo-grid span::before {
  content: '';
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #f7f0ff, #9d84ff 70%);
  box-shadow: 0 0 18px rgba(157, 132, 255, 0.42);
}

.native-illustration {
  position: relative;
}

.native-illustration-what img {
  max-width: 360px;
  margin-left: auto;
}

.native-illustration-shell {
  position: relative;
  max-width: 430px;
  margin: 0 auto;
}

.native-illustration-shell::before {
  content: '';
  position: absolute;
  inset: -18px;
  border-radius: 50%;
  border: 1px solid rgba(213, 188, 255, 0.36);
}

.native-split-copy-pain {
  max-width: 520px;
}

.native-pain-list {
  display: grid;
  gap: 14px;
  margin-top: 22px;
}

.native-pain-item {
  padding: 14px 18px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid rgba(189, 167, 232, 0.14);
  box-shadow: 0 14px 32px rgba(187, 166, 229, 0.14);
}

.native-pain-item.is-lilac h3 {
  color: #8d71da;
}

.native-pain-item.is-green h3 {
  color: #36a763;
}

.native-pain-item.is-cyan h3 {
  color: #4b9dc2;
}

.native-pain-item.is-blue h3 {
  color: #6888f0;
}

.native-section-path {
  background:
    linear-gradient(180deg, rgba(248, 242, 255, 0.86), rgba(244, 237, 255, 0.92)),
    url('/download/BG@1x-2.png') center/cover no-repeat;
}

.native-path-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.native-path-card {
  padding: 24px 20px;
  text-align: center;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(246,241,255,.92));
}

.native-path-orb {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 66px;
  margin: 0 auto 16px;
  border-radius: 28px;
  background: linear-gradient(180deg, #f5eeff, #e8d8ff);
  overflow: hidden;
}

.native-path-orb img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  display: block;
}

.native-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.native-card {
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(249,244,255,.86));
  border-radius: 26px;
}

.native-card-media {
  display: block;
  padding: 14px 14px 0;
}

.native-card-media img {
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 22px;
}

.native-card-body {
  padding: 12px 14px 16px;
}

.native-card-body h3 {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
}

.native-card-body h3 a {
  color: #2b2140;
}

.native-card-body p {
  margin: 8px 0 0;
  color: rgba(58, 44, 87, 0.68);
  line-height: 1.65;
  font-size: 11px;
  min-height: 32px;
}

.native-section-head-light .native-section-mini {
  color: rgba(255,255,255,0.62);
}

.native-showcase-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.native-showcase-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 20px 44px rgba(6, 4, 12, 0.28);
}

.native-showcase-media img {
  width: 100%;
  aspect-ratio: 1.45 / 1;
  object-fit: cover;
  border-radius: 16px;
}

.native-showcase-copy {
  padding: 0 4px 2px;
}

.native-showcase-label,
.native-learning-label {
  margin: 0 0 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: rgba(196, 177, 255, 0.74);
  text-transform: uppercase;
}

.native-showcase-copy h3 a {
  color: #fff;
}

.native-showcase-copy p {
  color: rgba(255,255,255,0.62);
}

.native-showcase-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 14px;
  color: rgba(255,255,255,0.72);
  font-size: 13px;
  font-weight: 600;
  transition: color 0.2s;
}

.native-showcase-link:hover {
  color: #fff;
}

.native-text-gradient {
  background: linear-gradient(90deg, #c084fc, #f97316);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.native-showcase-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 22px;
  flex-wrap: wrap;
}

.native-showcase-tab {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.62);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
  font-family: inherit;
}

.native-showcase-tab.is-active {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.28);
  color: #fff;
}

.native-showcase-carousel {
  position: relative;
}

.native-showcase-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 22px;
}

.native-showcase-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.72);
  font-size: 18px;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
  font-family: inherit;
}

.native-showcase-arrow:hover {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.26);
}

.native-showcase-arrow:disabled {
  opacity: 0.32;
  cursor: default;
}

.native-relation-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.native-relation-card {
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(191, 171, 234, 0.18);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,242,255,.92));
  box-shadow: 0 18px 38px rgba(182, 160, 226, 0.16);
}

.native-relation-top {
  display: flex;
  align-items: center;
  gap: 12px;
}

.native-relation-top strong {
  display: block;
  font-size: 16px;
}

.native-relation-top p {
  margin: 4px 0 0;
  color: rgba(58, 44, 87, 0.62);
  font-size: 12px;
}

.native-relation-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  color: #fff;
  font-size: 16px;
  font-weight: 800;
}

.native-relation-avatar.is-purple {
  background: linear-gradient(180deg, #a789ff, #835cf1);
}

.native-relation-avatar.is-cyan {
  background: linear-gradient(180deg, #7ac9ff, #4d8eff);
}

.native-relation-visual {
  height: 104px;
  margin-top: 16px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 30% 40%, rgba(251, 205, 255, 0.74), transparent 24%),
    radial-gradient(circle at 70% 55%, rgba(199, 185, 255, 0.82), transparent 22%),
    linear-gradient(180deg, rgba(245, 238, 255, 0.98), rgba(255,255,255,0.92));
  position: relative;
  overflow: hidden;
}

.native-relation-visual::before,
.native-relation-visual::after {
  content: '';
  position: absolute;
  top: 20px;
  width: 84px;
  height: 64px;
  border-radius: 16px;
  background: rgba(255,255,255,0.7);
}

.native-relation-visual::before {
  left: 18px;
}

.native-relation-visual::after {
  right: 18px;
}

.native-relation-visual.is-soft {
  background:
    radial-gradient(circle at 24% 42%, rgba(194, 236, 255, 0.8), transparent 24%),
    radial-gradient(circle at 76% 58%, rgba(222, 201, 255, 0.8), transparent 22%),
    linear-gradient(180deg, rgba(245, 244, 255, 0.98), rgba(255,255,255,0.92));
}

.native-creator-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.native-creator-card {
  padding: 36px 28px 28px;
  border-radius: 24px;
  border: 1px solid rgba(191, 171, 234, 0.18);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,242,255,.92));
  box-shadow: 0 22px 48px rgba(178, 156, 225, 0.18);
  text-align: center;
}

.native-creator-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 16px;
  background: linear-gradient(180deg, #dcc7ff, #b096ef);
}

.native-creator-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.native-creator-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(125, 91, 231, 0.08);
  color: #7d5be7;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 12px;
}

.native-creator-name {
  margin: 0 0 10px;
  font-size: 18px;
  color: #251b38;
}

.native-creator-bio {
  margin: 0 0 18px;
  font-size: 13px;
  color: rgba(58, 44, 87, 0.62);
  line-height: 1.8;
}

.native-creator-join {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #7d5be7;
  font-size: 13px;
  font-weight: 700;
}

.native-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.native-tags span,
.native-chip {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(173, 149, 227, 0.18);
  background: rgba(255, 255, 255, 0.84);
  color: #7c58e4;
  font-size: 12px;
}

.native-tags-large {
  margin-top: 16px;
}

.native-source-row {
  margin-top: 10px;
}

.native-source-pill {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  max-width: 100%;
  padding: 0 10px;
  border-radius: 999px;
  background: linear-gradient(180deg, #f6f3fb, #ece8f5);
  color: rgba(52, 40, 80, 0.66);
  font-size: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border: 1px solid rgba(187, 171, 220, 0.18);
}

.native-tool-row {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

.native-tool-dot {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  box-shadow: inset 0 0 0 2px rgba(13, 9, 20, 0.08);
}

.native-tool-dot.is-a { background: linear-gradient(135deg,#0f0d14,#3bb9ff); }
.native-tool-dot.is-b { background: linear-gradient(135deg,#0f0d14,#7b65ff); }
.native-tool-dot.is-c { background: linear-gradient(135deg,#0f0d14,#b7ff4d); }
.native-tool-dot.is-d { background: linear-gradient(135deg,#ffffff,#ff66c5); }

.native-section-soft {
  background: linear-gradient(180deg, rgba(250, 246, 255, 0.78), rgba(244, 238, 255, 0.82));
}

.native-section-darkband {
  position: relative;
  margin-top: 8px;
  background:
    linear-gradient(180deg, rgba(16,12,25,.98), rgba(11,9,16,.98)),
    url('/download/BG@1x-3.png') center/cover no-repeat;
}

.native-section-darkband .native-section-head h2,
.native-section-darkband .native-link,
.native-section-darkband .native-kicker {
  color: #fff;
}

.native-section-darkband .native-kicker {
  opacity: .72;
}

.native-section-darkband .native-card {
  background: linear-gradient(180deg, rgba(31,24,47,.98), rgba(16,12,25,.98));
  border-color: rgba(255,255,255,.08);
}

.native-section-darkband .native-card-body h3 a {
  color: #fff;
}

.native-section-darkband .native-card-body p {
  color: rgba(255,255,255,.62);
}

.native-section-darkband .native-tags span {
  background: rgba(255,255,255,.06);
  color: #d4c7ff;
  border-color: rgba(255,255,255,.08);
}

.native-course-preview,
.native-learning-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.native-learning-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,242,255,.9));
}

.native-learning-media img {
  aspect-ratio: 1.35 / 1;
  object-fit: cover;
}

.native-learning-copy {
  padding: 0 4px 4px;
}

.native-learning-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 16px;
}

.native-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.native-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.native-chip {
  cursor: pointer;
}

.native-chip.is-active {
  background: linear-gradient(135deg, #f1ebff, #e3d8ff);
  color: #5433af;
}

.native-page-hero-cases,
.native-page-hero-course {
  padding-top: 34px;
}

.native-page-hero-cases .native-copy,
.native-page-hero-course .native-copy {
  max-width: 540px;
}

.native-mini-poster-frame {
  padding: 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(249,243,255,.92)),
    url('/download/BG@1x-2.png') center/cover no-repeat;
}

.native-mini-poster-frame img {
  max-height: 360px;
  object-fit: cover;
  object-position: top center;
}

.native-search {
  min-width: min(100%, 280px);
  height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(191, 171, 234, 0.24);
  background: rgba(255, 255, 255, 0.78);
  color: #261d38;
}

.native-page-hero-cases + .native-section .native-wrap,
.native-page-hero-course + .native-section .native-wrap {
  padding: 22px;
  border-radius: 34px;
  background: rgba(255,255,255,.42);
  border: 1px solid rgba(191,171,234,.16);
  box-shadow: 0 22px 48px rgba(178,156,225,.12);
}

.native-empty {
  padding: 32px;
  border-radius: 20px;
  text-align: center;
  color: rgba(58, 44, 87, 0.6);
  background: rgba(255, 255, 255, 0.66);
}

.native-detail-layout {
  grid-template-columns: minmax(0, 1.2fr) 320px;
  align-items: start;
}

.native-detail-main {
  display: grid;
  gap: 18px;
}

.native-detail-media {
  overflow: hidden;
  padding: 12px;
}

.native-detail-media video {
  width: 100%;
  border-radius: 18px;
  display: block;
}

.native-detail-copy,
.native-side-card,
.native-form-card,
.native-cta-panel {
  padding: 20px;
}

.native-cta-panel {
  align-items: center;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.86), rgba(247,241,255,.92)),
    url('/download/BG@1x.png') center/cover no-repeat;
}

.native-home-cta {
  padding: 38px 40px;
}

.native-home-cta-copy {
  max-width: 520px;
}

.native-richtext {
  margin-top: 18px;
  line-height: 1.95;
  white-space: pre-wrap;
  color: rgba(43, 33, 64, 0.78);
}

.native-contact-grid,
.native-login-layout {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.native-contact-list {
  display: grid;
  gap: 14px;
  margin-top: 16px;
}

.native-contact-list div span {
  display: block;
  color: #8a72c8;
  font-size: 12px;
}

.native-contact-list div strong {
  display: block;
  margin-top: 6px;
}

.native-form-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
}

.native-form-tabs button {
  flex: 1;
  min-height: 38px;
  border-radius: 999px;
  border: 1px solid rgba(191, 171, 234, 0.18);
  background: rgba(255, 255, 255, 0.78);
  color: rgba(45, 33, 64, 0.66);
}

.native-form-tabs button.is-active {
  background: linear-gradient(135deg, #161120, #7d5be7);
  color: #fff;
}

.native-form-group {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}

.native-form-group label {
  font-size: 13px;
  color: #8a72c8;
}

.native-form-group input {
  height: 46px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid rgba(191, 171, 234, 0.24);
  background: rgba(255, 255, 255, 0.78);
  color: #261d38;
}

.native-form-error {
  min-height: 20px;
  color: #cf4f7c;
  font-size: 13px;
}

.native-auth-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(16, 12, 25, 0.6);
  backdrop-filter: blur(12px);
  z-index: 60;
}

.native-auth-modal.is-open {
  display: flex;
}

.native-auth-dialog {
  position: relative;
  width: min(100%, 960px);
  min-height: 500px;
  display: grid;
  grid-template-columns: 1fr 360px;
  align-items: stretch;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 40px 80px rgba(40, 16, 80, 0.52);
  background:
    repeating-linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.05) 0px, rgba(255, 255, 255, 0.05) 1px,
      transparent 1px, transparent 56px
    ),
    linear-gradient(120deg, #3a2db8 0%, #6247e0 30%, #9a6be8 55%, #c670d4 75%, #e96aaa 100%);
}

.native-auth-form-side {
  padding: 48px 44px 40px;
  background: rgba(255, 255, 255, 0.11);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-right: 1px solid rgba(255, 255, 255, 0.13);
}

.native-auth-form-side h2 {
  margin: 0 0 28px;
  color: #fff;
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -0.01em;
}

.native-auth-brand {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 48px 40px;
}

.native-auth-brand-title {
  margin: 0;
  color: #fff;
  font-size: 48px;
  font-weight: 900;
  line-height: 1.15;
  letter-spacing: -0.02em;
}

.native-auth-brand-sub {
  margin: 18px 0 0;
  color: rgba(255, 255, 255, 0.68);
  font-size: 16px;
  line-height: 1.65;
}

.native-auth-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.9);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition: background 0.15s;
}

.native-auth-close:hover {
  background: rgba(255, 255, 255, 0.26);
}

.native-auth-form {
  display: grid;
  gap: 14px;
}

.native-auth-field {
  display: grid;
  gap: 8px;
}

.native-auth-field label {
  color: rgba(255, 255, 255, 0.78);
  font-size: 13px;
  font-weight: 600;
}

.native-auth-field input,
.native-auth-form > input[type="password"] {
  height: 48px;
  padding: 0 16px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
  font: inherit;
  font-size: 15px;
  transition: border-color 0.18s, background 0.18s;
}

.native-auth-field input::placeholder,
.native-auth-form > input::placeholder {
  color: rgba(255, 255, 255, 0.35);
}

.native-auth-field input:focus,
.native-auth-form > input:focus {
  outline: none;
  border-color: rgba(255, 255, 255, 0.52);
  background: rgba(255, 255, 255, 0.15);
}

.native-auth-field input:-webkit-autofill,
.native-auth-form > input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px rgba(80, 50, 160, 0.5) inset;
  -webkit-text-fill-color: #fff;
  caret-color: #fff;
  transition: background-color 5000s ease-in-out 0s;
  border-color: rgba(255, 255, 255, 0.18);
}

.native-auth-code-wrap {
  display: flex;
  gap: 10px;
}

.native-auth-code-wrap input {
  flex: 1;
  min-width: 0;
}

.native-auth-code-btn {
  flex-shrink: 0;
  height: 48px;
  padding: 0 40px;
  border: 0;
  border-radius: 14px;
  background: linear-gradient(90deg, #ffb3b3, #ffcba4);
  color: #5a1a2a;
  font: inherit;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}

.native-auth-error {
  min-height: 18px;
  color: #ffb3c6;
  font-size: 13px;
}

.native-auth-submit {
  height: 52px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #ffb3b3 0%, #ffd4b3 100%);
  color: #4a1825;
  font: inherit;
  font-size: 16px;
  font-weight: 800;
  cursor: pointer;
  letter-spacing: 0.04em;
  transition: opacity 0.16s, transform 0.12s;
}

.native-auth-submit:hover {
  opacity: 0.92;
  transform: translateY(-1px);
}

.native-auth-submit:active {
  transform: translateY(0);
  opacity: 1;
}

.native-auth-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.native-auth-social {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255, 255, 255, 0.58);
  font-size: 14px;
}

.native-auth-wechat {
  width: 32px;
  height: 32px;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.native-auth-toggle {
  border: 0;
  background: transparent;
  color: rgba(255, 255, 255, 0.72);
  font: inherit;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  text-align: center;
}

.native-auth-toggle:hover {
  color: #fff;
}

@media (max-width: 680px) {
  .native-auth-dialog {
    grid-template-columns: 1fr;
  }
  .native-auth-brand {
    display: none;
  }
  .native-auth-form-side {
    border-right: none;
    padding: 36px 24px 28px;
  }
}

@media (max-width: 1024px) {
  .native-card-grid,
  .native-feature-grid,
  .native-path-grid,
  .native-showcase-grid,
  .native-learning-grid,
  .native-relation-grid,
  .native-logo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .native-detail-layout,
  .native-contact-grid,
  .native-login-layout,
  .native-hero-grid,
  .native-page-hero-grid,
  .native-split-what,
  .native-split-pain,
  .native-course-preview,
  .native-learning-grid {
    grid-template-columns: 1fr;
  }

  .native-cta-panel {
    flex-direction: column;
    align-items: flex-start;
  }

  .native-hero-grid-home {
    min-height: auto;
    padding: 38px 28px 36px;
  }

  .native-hero-visual {
    min-height: 300px;
  }
}

@media (max-width: 640px) {
  .native-header {
    padding: 12px;
  }

  .native-header-inner,
  .native-wrap {
    width: min(1180px, calc(100% - 18px));
  }

  .native-header-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .native-nav {
    gap: 8px;
  }

  .native-nav a,
  .native-nav-login,
  .native-nav-logout {
    min-height: 34px;
    padding: 0 10px;
    font-size: 11px;
    border-radius: 10px;
  }

  .native-nav-login {
    min-width: 84px;
    height: 34px;
  }

  .native-card-grid,
  .native-feature-grid,
  .native-path-grid,
  .native-course-preview,
  .native-learning-grid,
  .native-showcase-grid,
  .native-relation-grid,
  .native-logo-grid {
    grid-template-columns: 1fr;
  }

  .native-hero-grid-home {
    padding: 26px 18px 28px;
  }

  .native-copy-home,
  .native-home-intro,
  .native-split-copy,
  .native-section-head {
    text-align: center;
  }

  .native-actions,
  .native-section-head {
    justify-content: center;
  }

  .native-section-head {
    align-items: center;
  }

  .native-split-pain {
    gap: 18px;
  }

  .native-illustration-what img,
  .native-illustration-shell {
    max-width: 280px;
    margin: 0 auto;
  }

  .native-logo-band {
    padding: 16px 0 18px;
  }

  .native-logo-grid {
    gap: 10px;
  }

  .native-showcase-card,
  .native-relation-card {
    padding: 14px;
  }

  .native-hero-card-back {
    top: 18px;
    right: 0;
    width: 132px;
  }

  .native-hero-card-front {
    left: 4px;
    bottom: 14px;
    width: 172px;
  }

  .native-feature-card,
  .native-path-card,
  .native-card,
  .native-home-cta,
  .native-learning-card,
  .native-showcase-card,
  .native-relation-card {
    border-radius: 20px;
  }

  .native-note-bar {
    width: 100%;
    text-align: center;
    padding: 10px 14px;
    min-height: auto;
  }
}

body.home-page {
  background:
    radial-gradient(circle at 78% 6%, rgba(250, 205, 196, 0.46), transparent 18%),
    radial-gradient(circle at 70% 10%, rgba(196, 183, 255, 0.38), transparent 16%),
    radial-gradient(circle at 22% 43%, rgba(255, 202, 178, 0.2), transparent 12%),
    linear-gradient(180deg, #ffffff 0%, #fffdfd 100%);
}

.home-main {
  padding-bottom: 0;
}

.home-shell {
  width: min(1240px, calc(100% - 132px));
  margin: 0 auto;
}

.home-grid-surface {
  background:
    linear-gradient(180deg, rgba(244, 247, 251, 0.96), rgba(243, 246, 250, 0.96)),
    linear-gradient(90deg, rgba(181, 191, 212, 0.18) 1px, transparent 1px),
    linear-gradient(180deg, rgba(181, 191, 212, 0.18) 1px, transparent 1px);
  background-size: auto, 160px 100%, 100% 160px;
}

.home-center-head {
  text-align: center;
}

.home-center-head h2 {
  margin: 0;
  color: #101840;
  font-size: 32px;
  line-height: 1.22;
  letter-spacing: -0.02em;
}

.home-center-head p {
  margin: 12px 0 0;
  color: rgba(20, 24, 50, 0.66);
  font-size: 16px;
}

.home-center-head span {
  color: #b095ff;
}

.home-hero {
  padding: 34px 0 88px;
}

.home-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(420px, 510px);
  align-items: center;
  gap: 18px;
  min-height: 540px;
}

.home-hero-copy h1 {
  margin: 0;
  color: #101949;
  font-size: 62px;
  line-height: 1.04;
  letter-spacing: -0.03em;
}

.home-hero-copy h2 {
  margin: 16px 0 0;
  color: #212c5b;
  font-size: 31px;
  line-height: 1.24;
  font-weight: 500;
}

.home-hero-copy p {
  max-width: 560px;
  margin: 24px 0 0;
  color: rgba(43, 55, 98, 0.62);
  font-size: 17px;
  line-height: 1.68;
}

.home-hero-actions {
  display: flex;
  gap: 14px;
  margin-top: 30px;
}

.home-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 104px;
  height: 40px;
  padding: 0 20px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 700;
}

.home-btn-primary {
  background: #8f7df1;
  color: #fff;
  box-shadow: 0 14px 30px rgba(143, 125, 241, 0.24);
}

.home-btn-secondary {
  border: 1px solid #9e8ff4;
  color: #7667df;
  background: rgba(255, 255, 255, 0.76);
}

.home-hero-art {
  position: relative;
}

.home-hero-art::before {
  content: '';
  position: absolute;
  inset: -74px -36px -54px -68px;
  background:
    radial-gradient(circle at 52% 44%, rgba(184, 162, 255, 0.34), transparent 34%),
    radial-gradient(circle at 78% 50%, rgba(255, 218, 135, 0.56), transparent 30%),
    radial-gradient(circle at 58% 54%, rgba(243, 175, 155, 0.3), transparent 28%);
  filter: blur(18px);
}

.home-hero-art img {
  position: relative;
  z-index: 1;
  width: 100%;
  margin-left: auto;
  display: block;
}

.home-value {
  padding: 88px 0 96px;
}

.home-value-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  margin-top: 46px;
}

.home-value-card {
  min-height: 300px;
  padding: 30px 28px 26px;
  border-radius: 32px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 24px 48px rgba(185, 196, 219, 0.16);
  text-align: center;
}

.home-value-icon {
  width: 114px;
  height: 114px;
  margin: 0 auto 22px;
  border-radius: 50%;
  background: linear-gradient(180deg, #f07bd8, #9f81ff);
  box-shadow: 0 16px 28px rgba(169, 141, 245, 0.28);
  display: flex;
  align-items: center;
  justify-content: center;
}

.home-value-icon img {
  width: 100%;
  height: auto;
}

.home-value-card h3 {
  margin: 0;
  color: #151515;
  font-size: 16px;
  line-height: 1.45;
}

.home-value-card p {
  margin: 16px 0 0;
  color: rgba(34, 34, 34, 0.56);
  font-size: 14px;
  line-height: 1.86;
}

.home-what {
  padding: 88px 0 44px;
}

.home-what-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.7fr) minmax(560px, 1fr);
  align-items: start;
}

.home-eyebrow {
  margin: 0 0 18px;
  color: #9a8cff;
  font-size: 20px;
  font-weight: 700;
}

.home-what-copy h2 {
  margin: 0;
  font-size: 68px;
  line-height: 1.06;
  color: #000;
}

.home-what-copy ul {
  display: grid;
  gap: 16px;
  padding: 0;
  margin: 42px 0 0;
  list-style: none;
}

.home-what-copy li {
  position: relative;
  padding-left: 28px;
  font-size: 24px;
  color: rgba(42, 42, 42, 0.78);
}

.home-what-copy li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 2px;
  width: 18px;
  height: 18px;
  background-image: url('/download/shut.png');
}

.home-what-copy li:last-child {
  color: rgba(42, 42, 42, 0.95);
  font-weight: 700;
}

.home-what-copy li:last-child:before {
  background-image: url('/download/down.png');
}

.home-note-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 420px;
  height: 42px;
  padding: 0 22px;
  margin-top: 34px;
  border-radius: 999px;
  background: linear-gradient(90deg, #8d7ae8, #a786ff);
  color: #fff;
  font-size: 16px;
}

.home-what-art img {
  width: 100%;
  display: block;
}

.home-logo-strip {
  padding: 72px 0 84px;
  background: #120a2f;
}

.home-logo-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 78px 56px;
}

.home-logo-grid span {
  position: relative;
  padding-left: 52px;
  color: #fff;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.home-logo-grid span::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 34px;
  height: 34px;
  border: 3px solid rgba(255, 255, 255, 0.96);
  border-radius: 50%;
  transform: translateY(-50%);
}

.home-pain {
  padding: 96px 0 104px;
  background:
    radial-gradient(circle at 88% 16%, rgba(199, 192, 255, 0.34), transparent 22%),
    linear-gradient(180deg, #ffffff, #ffffff);
}

.home-pain-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 0.9fr);
  gap: 48px;
  align-items: center;
  margin-top: 46px;
}

.home-pain-stage {
  position: relative;
  min-height: 720px;
}

.home-pain-circle {
  position: absolute;
  inset: 70px 10px 20px 20px;
  border: 1px solid rgba(203, 203, 203, 0.54);
  border-radius: 50%;
}

.home-pain-core {
  position: absolute;
  left: 140px;
  top: 170px;
  width: 420px;
  height: 520px;
  border: 14px solid #9ce6ff;
  border-radius: 40px;
  background: linear-gradient(180deg, #f07ad5, #9c7dff);
  box-shadow: 0 28px 60px rgba(176, 185, 216, 0.16);
}

.home-pain-butterfly {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 42% 48%, rgba(255,255,255,0.6), transparent 11%),
    radial-gradient(circle at 58% 48%, rgba(255,255,255,0.6), transparent 11%),
    radial-gradient(circle at 44% 58%, rgba(255,255,255,0.56), transparent 8%),
    radial-gradient(circle at 56% 58%, rgba(255,255,255,0.56), transparent 8%);
}

.home-pain-msg {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 360px;
  padding: 22px 28px;
  border-radius: 34px;
  background: #fff;
  box-shadow: 0 26px 54px rgba(196, 201, 217, 0.36);
}

.home-pain-msg img {
  width: 78px;
  height: 78px;
  border-radius: 50%;
  object-fit: cover;
}

.home-pain-msg strong {
  display: block;
  color: #19163d;
  font-size: 28px;
  font-weight: 800;
}

.home-pain-msg p {
  margin: 12px 0 0;
  color: #19163d;
  font-size: 18px;
  font-weight: 700;
}

.home-pain-msg-top {
  top: 40px;
  left: 290px;
}

.home-pain-msg-bottom {
  left: 0;
  bottom: 12px;
}

.home-pain-list {
  display: grid;
  gap: 44px;
}

.home-pain-item {
  position: relative;
  padding-left: 56px;
}

.home-pain-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 24px;
  width: 38px;
  height: 1px;
  background: rgba(158, 158, 158, 0.36);
}

.home-pain-item h3 {
  display: inline-flex;
  align-items: center;
  min-width: 236px;
  height: 60px;
  padding: 0 28px;
  border-radius: 999px;
  color: #1c163a;
  font-size: 18px;
  background: #d7c6ff;
}

.home-pain-item p {
  margin: 16px 0 0;
  color: rgba(39, 39, 39, 0.6);
  font-size: 15px;
  line-height: 1.78;
}

.home-pain-item.is-purple h3 { background: #d8c2ff; }
.home-pain-item.is-green h3 { background: #76ef8b; }
.home-pain-item.is-cyan h3 { background: #ade0ff; }
.home-pain-item.is-blue h3 { background: #8fa8ff; }

.home-path {
  padding: 88px 0 102px;
}

.home-path-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 38px;
  margin-top: 50px;
}

.home-path-card {
  min-height: 404px;
  padding: 38px 28px 26px;
  border-radius: 148px;
  background: rgba(255, 255, 255, 0.96);
  text-align: center;
  box-shadow: 0 26px 50px rgba(194, 199, 217, 0.18);
}

.home-path-icon {
  width: 84px;
  height: 120px;
  margin: 0 auto 24px;
}

.home-path-icon img {
  width: 100%;
  display: block;
}

.home-path-card h3 {
  margin: 0;
  font-size: 18px;
  color: #111;
}

.home-path-card p {
  margin: 16px 0 0;
  color: rgba(34, 34, 34, 0.56);
  font-size: 14px;
  line-height: 1.82;
}

.home-cases {
  padding: 108px 0 62px;
  background: #000;
}

.home-cases .home-center-head-light p {
  color: #fff;
}

.home-cases .home-shell {
  width: min(1260px, calc(100% - 140px));
}

.home-center-head-light h2,
.home-center-head-light p {
  color: #fff;
}

.home-center-head-light h2 {
  font-size: 54px;
  line-height: 1.14;
  letter-spacing: -0.03em;
  font-weight: 700;
}

.home-center-head-light p {
  margin-top: 18px;
  font-size: 22px;
  color: rgba(255,255,255,0.9);
}

.home-center-head-light span {
  color: #a78dff;
}

.home-cases-tabs {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 34px;
  width: 100%;
  max-width: 1040px;
  margin: 58px auto 0;
}

.home-cases-tabs span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.76);
  font-size: 21px;
  line-height: 1;
  min-width: 0;
  letter-spacing: -0.02em;
  white-space: nowrap;
}

.home-cases-tabs button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 138px;
  height: 66px;
  padding: 0 26px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: rgba(255, 255, 255, 0.72);
  font-size: 21px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.02em;
  white-space: nowrap;
  cursor: pointer;
  transition: color 0.18s ease, opacity 0.18s ease, border-color 0.18s ease;
}

.home-cases-tabs button:hover {
  color: rgba(255, 255, 255, 0.9);
}

.home-cases-tabs .is-active {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 148px;
  height: 66px;
  border-radius: 999px;
  border: 5px solid #7c61e8;
  color: #fff;
  background: rgba(124, 97, 232, 0.03);
  font-weight: 700;
}

.home-cases-stage {
  display: grid;
  grid-template-columns: 78px max-content 78px;
  justify-content: center;
  align-items: center;
  gap: 32px;
  margin-top: 54px;
}

.home-cases-grid {
  display: grid;
  grid-template-columns: 429px 429px;
  gap: 48px;
}

.home-case-card {
  overflow: hidden;
  border-radius: 34px;
  background: #cacaca;
  box-shadow: 0 12px 0 rgba(61, 61, 73, 0.86);
}

.home-case-card-figure {
  background: transparent;
  box-shadow: none;
  border-radius: 34px;
}

.home-case-card-figure img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 34px;
}

.home-case-media {
  width: 100%;
  height: 424px;
  display: block;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.home-case-media.is-one {
  background-image: url('/download/切图 46.png');
}

.home-case-media.is-two {
  background-image: url('/download/首页@1x.png');
  background-size: 1920px auto;
  background-position: -1048px -6170px;
}

.home-case-copy {
  min-height: 172px;
  padding: 26px 28px 24px;
}

.home-case-copy h3 {
  margin: 0;
  color: #fff;
  font-size: 23px;
  line-height: 1.42;
  font-weight: 700;
}

.home-case-copy p {
  margin: 22px 0 0;
  color: rgba(255,255,255,0.68);
  font-size: 15px;
  line-height: 1.7;
}

.home-cases-arrow {
  width: 66px;
  height: 66px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
  font-size: 42px;
  border: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.home-cases-arrow.is-right {
  background: #bd96ff;
}

.home-cases-footer {
  position: relative;
  width: 906px;
  margin: 34px auto 0;
}

.home-cases-footer .link {
  text-align: right;
  margin-bottom: 35px;
}

.home-cases-more {
  color: #af92ff;
  font-size: 16px;
}

.home-cases-cta {
  max-width: 360px;
  margin: 0 auto;
  text-align: center;
}

.home-cases-cta p {
  margin: 0 0 24px;
  color: rgba(255,255,255,0.82);
  font-size: 16px;
}

.home-cases-cta a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  height: 64px;
  border-radius: 999px;
  background: #fff;
  color: #1c163a;
  font-size: 22px;
  font-weight: 700;
}

.home-cases-cta a img {
  margin-right: 10px;
}

.home-join {
  padding: 88px 0 86px;
}

.home-join-visual {
  margin-top: 42px;
}

.home-join-visual img {
  width: 100%;
  display: block;
  border-radius: 46px;
}

.home-final-cta {
  position: relative;
  padding: 78px 0 94px;
  overflow: hidden;
  background:
    radial-gradient(circle at 24% 48%, rgba(255, 190, 237, 0.72), transparent 10%),
    radial-gradient(circle at 34% 42%, rgba(183, 209, 255, 0.78), transparent 11%),
    radial-gradient(circle at 74% 62%, rgba(166, 191, 255, 0.72), transparent 11%),
    linear-gradient(180deg, #ffffff, #ffffff);
}

.home-final-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 0, rgba(204, 190, 255, 0.18), transparent 30%);
}

.home-final-cta-inner {
  position: relative;
  z-index: 1;
  text-align: center;
}

.home-final-brand {
  color: #2e2e2e;
  font-size: 52px;
  font-weight: 400;
}

.home-final-cta h2 {
  margin: 24px 0 0;
  font-size: 62px;
  line-height: 1.14;
  letter-spacing: -0.03em;
  color: #000;
}

.home-final-cta a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 208px;
  height: 60px;
  margin-top: 28px;
  border-radius: 999px;
  background: #000;
  color: #fff;
  font-size: 20px;
  font-weight: 700;
}

@media (max-width: 1024px) {
  .home-shell {
    width: min(1280px, calc(100% - 40px));
  }

  .home-hero-grid,
  .home-what-grid,
  .home-pain-grid,
  .home-cases-stage {
    grid-template-columns: 1fr;
  }

  .home-value-grid,
  .home-path-grid,
  .home-cases-grid,
  .home-logo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-cases-stage {
    gap: 22px;
  }

  .home-cases-arrow {
    display: none;
  }

  .home-what-copy h2,
  .home-final-cta h2 {
    font-size: 48px;
  }

  .home-pain-stage {
    min-height: 640px;
  }

  .home-pain-core {
    left: 90px;
  }
}

@media (max-width: 640px) {
  .home-shell {
    width: calc(100% - 24px);
  }

  .home-hero {
    padding: 20px 0 34px;
  }

  .home-hero-grid,
  .home-value-grid,
  .home-path-grid,
  .home-cases-grid,
  .home-logo-grid {
    grid-template-columns: 1fr;
  }

  .home-hero-copy {
    text-align: center;
  }

  .home-hero-copy h1 {
    font-size: 34px;
  }

  .home-hero-copy h2 {
    font-size: 20px;
    margin-top: 10px;
  }

  .home-hero-copy p,
  .home-center-head p,
  .home-value-card p,
  .home-pain-item p,
  .home-path-card p {
    font-size: 13px;
  }

  .home-hero-actions {
    justify-content: center;
    margin-top: 18px;
  }

  .home-value,
  .home-pain,
  .home-path,
  .home-cases,
  .home-join,
  .home-final-cta {
    padding-top: 42px;
    padding-bottom: 42px;
  }

  .home-center-head h2,
  .home-what-copy h2,
  .home-final-cta h2 {
    font-size: 28px;
  }

  .home-value-card {
    min-height: auto;
    padding: 24px 20px;
    border-radius: 24px;
  }

  .home-what {
    padding: 42px 0 18px;
  }

  .home-what-copy {
    text-align: center;
  }

  .home-eyebrow {
    font-size: 14px;
  }

  .home-what-copy ul {
    margin-top: 20px;
    gap: 10px;
  }

  .home-what-copy li {
    font-size: 15px;
    text-align: left;
  }

  .home-note-pill {
    min-width: 0;
    width: 100%;
    height: auto;
    padding: 10px 16px;
    font-size: 12px;
  }

  .home-logo-strip {
    padding: 28px 0 34px;
  }

  .home-logo-grid {
    gap: 14px;
  }

  .home-logo-grid span {
    padding-left: 26px;
    font-size: 14px;
  }

  .home-logo-grid span::before {
    width: 16px;
    height: 16px;
    border-width: 2px;
  }

  .home-pain-grid {
    gap: 20px;
  }

  .home-pain-stage {
    min-height: 350px;
  }

  .home-pain-circle {
    inset: 18px 10px 10px 10px;
  }

  .home-pain-core {
    left: 50%;
    top: 92px;
    width: 180px;
    height: 220px;
    border-width: 8px;
    transform: translateX(-50%);
  }

  .home-pain-msg {
    min-width: 0;
    width: 200px;
    padding: 10px 14px;
    border-radius: 22px;
    gap: 10px;
  }

  .home-pain-msg img {
    width: 40px;
    height: 40px;
  }

  .home-pain-msg strong {
    font-size: 16px;
  }

  .home-pain-msg p {
    margin-top: 4px;
    font-size: 12px;
  }

  .home-pain-msg-top {
    left: auto;
    right: 8px;
    top: 16px;
  }

  .home-pain-msg-bottom {
    left: 0;
    bottom: 0;
  }

  .home-pain-list {
    gap: 16px;
  }

  .home-pain-item {
    padding-left: 0;
  }

  .home-pain-item::before {
    display: none;
  }

  .home-pain-item h3 {
    min-width: 0;
    width: 100%;
    height: 42px;
    padding: 0 16px;
    font-size: 14px;
  }

  .home-path-card {
    min-height: auto;
    padding: 28px 20px;
    border-radius: 28px;
  }

  .home-path-icon {
    width: 54px;
    height: 76px;
    margin-bottom: 16px;
  }

  .home-cases-tabs {
    flex-wrap: wrap;
    gap: 12px 18px;
    margin-top: 18px;
    width: 100%;
    justify-content: center;
  }

  .home-cases-tabs span {
    font-size: 13px;
    min-width: 0;
  }

  .home-cases-tabs .is-active {
    width: 74px;
    height: 34px;
    border-width: 2px;
  }

  .home-center-head-light h2 {
    font-size: 28px;
  }

  .home-center-head-light p {
    font-size: 14px;
    margin-top: 10px;
  }

  .home-case-media {
    height: 160px;
  }

  .home-case-copy {
    padding: 14px;
    min-height: auto;
  }

  .home-case-card-figure img {
    border-radius: 24px;
  }

  .home-case-copy h3 {
    font-size: 14px;
  }

  .home-case-copy p {
    font-size: 12px;
    margin-top: 10px;
  }

  .home-cases-footer {
    margin-top: 18px;
    min-height: auto;
  }

  .home-cases-more {
    position: static;
    display: block;
    margin-bottom: 18px;
    text-align: right;
    font-size: 13px;
  }

  .home-cases-cta p {
    font-size: 13px;
  }

  .home-cases-cta a {
    min-width: 124px;
    height: 42px;
    font-size: 14px;
  }

  .home-join-visual img {
    border-radius: 20px;
  }

  .home-final-brand {
    font-size: 36px;
  }

  .home-final-cta a {
    min-width: 164px;
    height: 46px;
    font-size: 15px;
    margin-top: 20px;
  }
}

/* MasterGo home page alignment: source frame 1920 x 7504. */
.home-page .native-header {
  padding: 24px 18px 20px;
  background: #fff;
  border-bottom: 0;
  backdrop-filter: none;
}

.home-page .native-header-inner {
  width: min(1176px, calc(100% - 64px));
  min-height: 44px;
}

.home-page .native-brand {
  display: block;
  flex: 0 0 105px;
  width: 105px;
  height: 31px;
  padding-left: 0;
  overflow: hidden;
  color: transparent;
  font-size: 0;
  line-height: 0;
  letter-spacing: 0;
  background: url('/download/切图 135.png') center / contain no-repeat;
}

.home-page .native-brand::before,
.home-page .native-brand::after {
  display: none;
}

.home-page .native-nav {
  gap: 31px;
  align-items: center;
}

.home-page .native-nav a,
.home-page .native-nav-login,
.home-page .native-nav-logout {
  min-height: 30px;
  padding: 0;
  border-radius: 4px;
  color: #8f79ec;
  font-size: 14px;
  font-weight: 800;
}

.home-page .native-nav-login {
  width: 96px;
  height: 28px;
  min-width: 96px;
  padding: 0;
  color: #fff;
  background: #8f79ec;
  box-shadow: none;
}

body.home-page {
  background: #fff;
}

.home-shell {
  width: min(1176px, calc(100% - 64px));
}

.home-hero {
  height: 706px;
  padding: 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 78.5% 40%, rgba(255, 204, 132, 0.56), transparent 17%),
    radial-gradient(circle at 67% 46%, rgba(194, 180, 255, 0.34), transparent 18%),
    radial-gradient(circle at 75% 25%, rgba(255, 207, 219, 0.28), transparent 17%),
    #fff;
}

.home-hero-grid {
  grid-template-columns: 720px 427px;
  gap: 23px;
  min-height: 706px;
  padding-top: 150px;
  align-items: start;
}

.home-hero-copy h1 {
  font-size: 64px;
  line-height: 1.05;
  font-weight: 800;
  letter-spacing: -0.045em;
}

.home-hero-copy h2 {
  margin-top: 18px;
  font-size: 42px;
  line-height: 1.18;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #1c254f;
}

.home-hero-copy p {
  max-width: 600px;
  margin-top: 35px;
  font-size: 20px;
  line-height: 1.65;
  color: #8188a4;
}

.home-hero-actions {
  gap: 13px;
  margin-top: 34px;
}

.home-btn {
  min-width: 136px;
  height: 32px;
  padding: 0 22px;
  border-radius: 3px;
  font-size: 14px;
  font-weight: 800;
}

.home-btn-primary {
  background: #8e7aeb;
  box-shadow: none;
}

.home-btn-secondary {
  border-color: #9583ed;
  color: #7f6ee4;
}

.home-hero-art::before {
  inset: -80px -110px -90px -130px;
  opacity: 0;
}

.home-grid-surface {
  /* background:
    linear-gradient(180deg, rgba(244, 247, 251, 0.96), rgba(244, 247, 251, 0.96)),
    linear-gradient(90deg, rgba(181, 191, 212, 0.23) 1px, transparent 1px); */
  /* background-size: auto, 250px 100%; */
  background: rgba(244, 247, 251, 0.96) url('/download/surface-bg.png') bottom left no-repeat;
}

.home-value {
  height: 722px;
  padding: 104px 0 0;
}

.home-center-head h2 {
  font-size: 40px;
  line-height: 1.18;
  font-weight: 800;
  letter-spacing: -0.03em;
}

.home-center-head p {
  margin-top: 16px;
  font-size: 17px;
  color: #3a4161;
}

.home-value-grid {
  grid-template-columns: repeat(3, 310px);
  justify-content: center;
  gap: 34px;
  margin-top: 58px;
}

.home-value-card {
  width: 310px;
  min-height: 405px;
  padding: 40px 42px 30px;
  border-radius: 38px;
}

.home-value-icon {
  width: 100px;
  height: 100px;
  margin-bottom: 30px;
}

.home-value-card h3 {
  font-size: 21px;
  line-height: 1.42;
  font-weight: 800;
}

.home-value-card p {
  margin-top: 26px;
  font-size: 15px;
  line-height: 2;
  color: rgba(34, 34, 34, 0.48);
}

.home-what {
  position: relative;
  height: 948px;
  padding: 101px 0 0;
  overflow: hidden;
  background: #fff;
}

.home-what-grid {
  position: relative;
  display: block;
  height: 100%;
}

.home-what-copy {
  position: relative;
  z-index: 2;
  width: 600px;
}

.home-eyebrow {
  margin-bottom: 24px;
  font-size: 16px;
  line-height: 1;
}

.home-what-copy h2 {
  font-size: 54px;
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.home-what-copy ul {
  gap: 20px;
  margin-top: 56px;
}

.home-what-copy li {
  padding-left: 28px;
  font-size: 18px;
  line-height: 1.2;
  color: #575757;
}


.home-note-pill {
  min-width: 494px;
  height: 33px;
  margin-top: 36px;
  font-size: 15px;
  font-weight: 700;
}

.home-what-art {
  position: absolute;
  z-index: 1;
  left: -90px;
  bottom: 28px;
  width: 1301px;
  pointer-events: none;
}

.home-what-art img {
  width: 1301px;
  max-width: none;
}

.home-logo-strip {
  height: 552px;
  padding: 146px 0 0;
  background: #0e0729;
}

.home-logo-strip .home-shell {
  width: min(1588px, calc(100% - 160px));
}

.home-logo-grid {
  grid-template-columns: repeat(4, 250px);
  justify-content: center;
  align-items: center;
  gap: 132px 196px;
}

.home-logo-grid span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 76px;
  padding-left: 0;
}

.home-logo-grid span::before {
  display: none;
}

.home-logo-grid img {
  display: block;
  width: auto;
  max-width: none;
  height: auto;
}

.home-pain {
  height: 1298px;
  min-height: 1298px;
  padding: 126px 0 0;
}

.home-pain-grid {
  grid-template-columns: 650px 525px;
  gap: 1px;
  align-items: start;
  margin-top: 86px;
}

.home-pain-stage {
  min-height: 1000px;
}

.home-pain-stage > :not(.home-pain-visual-img) {
  display: none;
}

.home-pain-visual-img {
  position: absolute;
  left: -242px;
  top: -69px;
  width: 890px;
  height: 1000px;
  max-width: none;
  object-fit: contain;
  pointer-events: none;
}

.home-pain-circle {
  inset: 32px 22px 40px -58px;
}

.home-pain-core {
  left: 16px;
  top: 194px;
  width: 500px;
  height: 640px;
  border-width: 16px;
  border-radius: 42px;
}

.home-pain-msg {
  min-width: 460px;
  padding: 30px 36px;
  border-radius: 42px;
}

.home-pain-msg-top {
  top: 0;
  left: 236px;
}

.home-pain-msg-bottom {
  left: -132px;
  bottom: 0;
}

.home-pain-list {
  gap: 58px;
  padding-top: 0;
}

.home-pain-item {
  padding-left: 72px;
}

.home-pain-item h3 {
  min-width: 255px;
  height: 55px;
  padding: 0 28px;
  font-size: 19px;
  font-weight: 800;
}

.home-pain-item p {
  max-width: 455px;
  margin-top: 19px;
  font-size: 15px;
  line-height: 1.75;
}

.home-path {
  height: 872px;
  padding: 125px 0 0;
  background:
    radial-gradient(ellipse 520px 280px at 17% 100%, rgba(151, 86, 255, 0.7), transparent 72%),
    radial-gradient(ellipse 540px 300px at 40% 101%, rgba(92, 171, 255, 0.62), transparent 74%),
    radial-gradient(ellipse 520px 300px at 73% 100%, rgba(255, 196, 92, 0.58), transparent 76%),
    radial-gradient(ellipse 520px 300px at 89% 100%, rgba(255, 133, 126, 0.56), transparent 76%),
    linear-gradient(180deg, rgba(244, 247, 251, 0.96), rgba(244, 247, 251, 0.96)),
    linear-gradient(90deg, rgba(181, 191, 212, 0.23) 1px, transparent 1px);
  background-size: auto, auto, auto, auto, auto, 250px 100%;
}

.home-path-grid {
  grid-template-columns: repeat(3, 316px);
  justify-content: center;
  gap: 103px;
  margin-top: 92px;
}

.home-path-card {
  width: 316px;
  min-height: 472px;
  padding: 90px 39px 30px;
  border-radius: 167px;
}

.home-path-icon {
  width: 84px;
  height: 120px;
  margin-bottom: 62px;
}

.home-path-card h3 {
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
}

.home-path-card p {
  margin-top: 35px;
  font-size: 15px;
  line-height: 1.31;
}

.home-cases {
  height: auto;
  min-height: 1120px;
  padding: 77px 0 73px;
  overflow: hidden;
}

.home-cases .home-shell {
  width: min(1176px, calc(100% - 64px));
}

.home-center-head-light h2 {
  font-size: 41px;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.home-center-head-light p {
  margin-top: 18px;
  font-size: 19px;
}

.home-cases-tabs {
  max-width: 790px;
  gap: 58px;
  margin-top: 56px;
}

.home-cases-tabs span,
.home-cases-tabs button {
  min-width: 80px;
  height: 44px;
  padding: 0;
  font-size: 18px;
  font-weight: 500;
}

.home-cases-tabs .is-active {
  width: 126px;
  height: 44px;
  border-width: 4px;
  font-size: 18px;
}

.home-cases-stage {
  grid-template-columns: 66px max-content 66px;
  gap: 105px;
  margin-top: 42px;
}

.home-cases-grid {
  grid-template-columns: 429px 429px;
  gap: 74px;
}

.home-cases-arrow {
  width: 66px;
  height: 66px;
  font-size: 48px;
}

.home-cases-footer {
  width: 932px;
  margin-top: 30px;
}

.home-cases-more {
  top: 2px;
  right: 0;
  font-size: 17px;
}

.home-cases-cta p {
  margin-bottom: 22px;
  font-size: 16px;
}

.home-cases-cta a {
  min-width: 196px;
  height: 50px;
  font-size: 19px;
}

.home-join {
  position: relative;
  height: 722px;
  padding: 0;
  overflow: hidden;
  background: #f4f5f9;
}

.home-join .home-shell {
  position: static;
  z-index: 2;
  width: min(1176px, calc(100% - 64px));
}

.home-join .home-center-head {
  position: relative;
  z-index: 2;
  padding-top: 84px;
}

.home-join-visual {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 50%;
  width: 1920px;
  max-width: none;
  margin: 0;
  transform: translateX(-50%);
}

.home-join-visual img {
  width: 1920px;
  max-width: none;
  border-radius: 0;
}

.home-final-cta {
  height: 466px;
  padding: 88px 0 0;
}

.home-final-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 31px;
  padding-left: 0;
  font-size: 0;
  line-height: 0;
}

.home-final-brand::before,
.home-final-brand::after {
  display: none;
}

.home-final-brand img {
  display: block;
  width: 105px;
  height: 31px;
  object-fit: contain;
}

.home-final-cta h2 {
  margin-top: 61px;
  font-size: 64px;
  font-weight: 500;
  letter-spacing: 0.1em;
}

.home-final-cta a {
  min-width: 250px;
  height: 56px;
  margin-top: 45px;
  font-size: 18px;
}

@media (max-width: 1280px) {
  .home-page .native-header-inner,
  .home-shell,
  .home-cases .home-shell {
    width: min(1176px, calc(100% - 40px));
  }

  .home-hero-grid {
    grid-template-columns: minmax(0, 1fr) minmax(420px, 553px);
  }

  .home-cases-stage {
    gap: 30px;
  }
}

@media (max-width: 1024px) {
  .home-page .native-header {
    padding: 16px 14px;
  }

  .home-page .native-header-inner {
    width: calc(100% - 28px);
  }

  .home-page .native-brand {
    font-size: 18px;
    padding-left: 38px;
  }

  .home-page .native-brand::before,
  .home-page .native-brand::after {
    width: 20px;
    height: 22px;
  }

  .home-page .native-brand::after {
    left: 13px;
  }

  .home-page .native-nav {
    gap: 12px;
  }

  .home-hero,
  .home-value,
  .home-what,
  .home-logo-strip,
  .home-pain,
  .home-path,
  .home-cases,
  .home-join,
  .home-final-cta {
    height: auto;
    min-height: 0;
    padding-top: 56px;
    padding-bottom: 56px;
  }

  .home-hero-grid,
  .home-what-grid,
  .home-pain-grid,
  .home-cases-stage {
    display: grid;
    grid-template-columns: 1fr;
    min-height: 0;
    padding-top: 0;
  }

  .home-what-art {
    position: static;
    width: 100%;
    margin-top: 28px;
  }

  .home-what-art img,
  .home-join-visual,
  .home-join-visual img {
    width: 100%;
    max-width: 100%;
  }

  .home-value-grid,
  .home-path-grid,
  .home-cases-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-value-card,
  .home-path-card {
    width: auto;
  }
}

@media (max-width: 640px) {
  .home-page .native-header-inner {
    width: calc(100% - 8px);
  }

  .home-page .native-nav {
    gap: 8px;
  }

  .home-page .native-nav a,
  .home-page .native-nav-login,
  .home-page .native-nav-logout {
    font-size: 11px;
  }

  .home-page .native-nav-login {
    width: 84px;
    min-width: 84px;
  }

  .home-shell,
  .home-cases .home-shell,
  .home-logo-strip .home-shell {
    width: calc(100% - 24px);
  }

  .home-hero-copy h1,
  .home-what-copy h2,
  .home-final-cta h2 {
    font-size: 34px;
  }

  .home-hero-copy h2,
  .home-center-head h2,
  .home-center-head-light h2 {
    font-size: 26px;
  }

  .home-value-grid,
  .home-path-grid,
  .home-cases-grid,
  .home-logo-grid {
    grid-template-columns: 1fr;
  }
}

.course-gallery-page {
  background: #fff;
}

.course-gallery-main {
  position: relative;
  overflow: hidden;
  padding-bottom: 138px;
  background:
    radial-gradient(circle at 50% 18%, rgba(193, 219, 255, 0.28), transparent 18%),
    linear-gradient(180deg, #ffffff 0%, #fcfbff 54%, #f7f6ff 100%);
}

.course-gallery-shell {
  width: min(1436px, calc(100% - 196px));
  margin: 0 auto;
}

.course-gallery-hero {
  padding: 116px 0 44px;
}

.course-gallery-hero h1 {
  margin: 0;
  text-align: center;
  color: #0d0d10;
  font-size: 58px;
  line-height: 1.24;
  letter-spacing: -0.06em;
  font-weight: 800;
}

.course-gallery-tabs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 32px;
  margin: 78px auto 0;
  max-width: 1420px;
  padding: 18px 30px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 22px 54px rgba(194, 186, 234, 0.22);
}

.course-gallery-tabs button {
  height: 46px;
  padding: 0 22px;
  border: 0;
  border-radius: 999px;
  background: #edf0f5;
  color: rgba(28, 28, 32, 0.72);
  font: inherit;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: -0.02em;
}

.course-gallery-tabs .is-active {
  background: linear-gradient(90deg, rgba(217, 208, 255, 0.96), rgba(237, 218, 255, 0.96));
  box-shadow: inset 0 0 0 1px rgba(152, 112, 255, 0.78);
  color: #0e0d13;
  font-weight: 700;
}

.course-gallery-section {
  padding-top: 42px;
}

.course-gallery-grid-shell {
  position: relative;
}

.course-gallery-grid-shell::before {
  content: '';
  position: absolute;
  left: 50%;
  top: -10px;
  width: 1110px;
  height: 1110px;
  transform: translateX(-50%);
  background: url('/download/BG@1x.png') center/contain no-repeat;
  opacity: 0.84;
  pointer-events: none;
}

.course-gallery-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, 328px);
  justify-content: center;
  gap: 28px 22px;
  min-height: 720px;
}

.course-gallery-card {
  display: block;
  align-self: start;
  border-radius: 40px;
  overflow: hidden;
  box-shadow: 0 18px 44px rgba(200, 194, 232, 0.16);
}

.course-gallery-card img {
  width: 100%;
  height: auto;
  display: block;
}

.course-gallery-pagination {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 52px;
  margin-top: 96px;
}

.course-gallery-pagination a,
.course-gallery-pagination span {
  color: #30264c;
  font-size: 22px;
  font-weight: 500;
}

.course-gallery-pagination a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
}

.course-gallery-pagination .is-active {
  width: 62px;
  min-width: 62px;
  height: 62px;
  border-radius: 18px;
  background: linear-gradient(180deg, #c5a6ff, #ab8cff);
  color: #fff;
  font-weight: 700;
}

.course-gallery-empty {
  grid-column: 1 / -1;
  min-height: 420px;
  display: grid;
  place-items: center;
  border-radius: 40px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 18px 44px rgba(200, 194, 232, 0.12);
  color: rgba(35, 37, 46, 0.54);
  font-size: 22px;
  font-weight: 600;
}

@media (max-width: 1520px) {
  .course-gallery-shell {
    width: min(1340px, calc(100% - 72px));
  }

  .course-gallery-tabs {
    gap: 18px;
    padding-inline: 20px;
  }

  .course-gallery-grid {
    transform: scale(0.94);
    transform-origin: top center;
    margin-bottom: -82px;
  }
}

@media (max-width: 1180px) {
  .course-gallery-shell {
    width: calc(100% - 40px);
  }

  .course-gallery-hero {
    padding-top: 88px;
  }

  .course-gallery-hero h1 {
    font-size: 42px;
  }

  .course-gallery-tabs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border-radius: 36px;
  }

  .course-gallery-grid-shell::before {
    width: 980px;
    height: 980px;
    top: 40px;
  }

  .course-gallery-grid {
    transform: none;
    margin-bottom: 0;
    grid-template-columns: repeat(2, 344px);
  }
}

@media (max-width: 760px) {
  .course-gallery-main {
    padding-bottom: 88px;
  }

  .course-gallery-shell {
    width: calc(100% - 24px);
  }

  .course-gallery-hero {
    padding-top: 58px;
  }

  .course-gallery-hero h1 {
    font-size: 30px;
    line-height: 1.36;
  }

  .course-gallery-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 36px;
    padding: 14px;
    border-radius: 28px;
  }

  .course-gallery-tabs button {
    font-size: 16px;
  }

  .course-gallery-grid-shell::before {
    width: 520px;
    height: 520px;
    top: 100px;
    opacity: 0.7;
  }

  .course-gallery-grid {
    grid-template-columns: 344px;
    gap: 20px;
  }

  .course-gallery-pagination {
    gap: 28px;
    margin-top: 54px;
  }

  .course-gallery-pagination a,
  .course-gallery-pagination span {
    font-size: 18px;
  }

  .course-gallery-pagination .is-active {
    width: 48px;
    min-width: 48px;
    height: 48px;
    border-radius: 14px;
  }
}

.course-detail-page {
  background: #fff;
}

.course-detail-main {
  position: relative;
  overflow: hidden;
  padding-bottom: 148px;
  background:
    radial-gradient(circle at 50% 13%, rgba(194, 216, 255, 0.42), transparent 17%),
    linear-gradient(180deg, #ffffff 0%, #fefeff 52%, #fbfaff 100%);
}

.course-detail-main::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 138px;
  width: 1390px;
  height: 1390px;
  transform: translateX(-50%);
  background: url('/download/BG@1x.png') center/contain no-repeat;
  opacity: 0.92;
  pointer-events: none;
}

.course-detail-shell {
  width: min(1436px, calc(100% - 196px));
  margin: 0 auto;
}

.course-detail-hero {
  position: relative;
  z-index: 1;
  padding: 102px 0 58px;
}

.course-detail-hero h1 {
  margin: 0;
  max-width: 1180px;
  margin-inline: auto;
  text-align: center;
  color: #0b0b10;
  font-size: 58px;
  line-height: 1.22;
  letter-spacing: -0.05em;
  font-weight: 800;
}

.course-detail-meta {
  margin: 28px 0 0;
  text-align: center;
  color: #181823;
  font-size: 24px;
  font-weight: 500;
  letter-spacing: -0.02em;
}

.course-detail-tags {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 54px;
  width: min(980px, 100%);
  margin: 38px auto 0;
}

.course-detail-tags span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 48px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 20px 46px rgba(201, 195, 232, 0.16);
  color: #34345c;
  font-size: 18px;
  font-weight: 500;
}

.course-detail-content {
  position: relative;
  z-index: 1;
  padding-top: 18px;
}

.course-detail-grid {
  display: grid;
  grid-template-columns: 308px minmax(0, 1fr) 308px;
  gap: 40px;
  align-items: start;
}

.course-detail-side,
.course-detail-latest {
  display: grid;
  gap: 30px;
  min-width: 0;
}

.course-detail-side-card,
.course-detail-latest-card,
.course-detail-panel {
  border-radius: 44px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(232, 227, 247, 0.95);
  box-shadow: 0 24px 52px rgba(210, 203, 236, 0.14);
}

.course-detail-side-card,
.course-detail-latest-card {
  padding: 34px 22px 28px;
}

.course-detail-side-card h2,
.course-detail-latest-card h2 {
  margin: 0;
  text-align: center;
  color: #c19cff;
  font-size: 26px;
  line-height: 1.1;
  font-weight: 800;
}

.course-detail-toc {
  display: grid;
  gap: 18px;
  margin-top: 26px;
}

.course-detail-toc a {
  color: #2f2f5a;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.55;
  padding: 0 28px;
}

.course-detail-toc .is-active {
  display: flex;
  align-items: center;
  min-height: 54px;
  border-radius: 999px;
  background: linear-gradient(90deg, #b193f5, #c4a2ff);
  color: #fff;
}

.course-detail-side-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 62px;
  border-radius: 999px;
  background: #050505;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  box-shadow: 0 16px 36px rgba(15, 15, 15, 0.12);
}

.course-detail-panel {
  min-width: 0;
  padding: 42px 36px 56px;
}

.course-detail-lead,
.course-detail-paragraph {
  margin: 0;
  max-width: 960px;
  margin-inline: auto;
  text-align: center;
  color: #343460;
  font-size: 28px;
  line-height: 1.5;
  font-weight: 600;
}

.course-detail-video {
  position: relative;
  width: min(868px, 100%);
  height: 546px;
  margin: 56px auto 76px;
  border-radius: 40px;
  background: #000;
}

.course-detail-video.is-large {
  margin-top: 64px;
  margin-bottom: 0;
  height: 620px;
}

.course-detail-video span {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 92px;
  height: 92px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.96);
}

.course-detail-video span::before {
  content: '';
  position: absolute;
  left: 37px;
  top: 28px;
  width: 0;
  height: 0;
  border-top: 18px solid transparent;
  border-bottom: 18px solid transparent;
  border-left: 30px solid #000;
}

.course-detail-spacer {
  height: 560px;
}

.course-detail-latest-list {
  display: grid;
  gap: 16px;
  margin-top: 26px;
}

.course-detail-latest-list a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 24px;
  border-radius: 999px;
  background: #f0f0f4;
  color: rgba(45, 45, 55, 0.72);
  font-size: 15px;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.detail-flex-stack {
  display: grid;
  gap: 30px;
  min-width: 0;
}

.detail-flex-block {
  display: grid;
  gap: 18px;
  min-width: 0;
}

.detail-flex-title {
  margin: 0;
  color: #3c3761;
  font-size: 28px;
  line-height: 1.28;
  font-weight: 800;
}

.detail-rich-html {
  color: #262434;
  font-size: 20px;
  line-height: 1.95;
  font-weight: 500;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.detail-rich-html p,
.detail-rich-html h2,
.detail-rich-html h3,
.detail-rich-html h4,
.detail-rich-html blockquote,
.detail-rich-html ul,
.detail-rich-html ol {
  margin: 0 0 16px;
}

.detail-rich-html p:last-child,
.detail-rich-html h2:last-child,
.detail-rich-html h3:last-child,
.detail-rich-html h4:last-child,
.detail-rich-html blockquote:last-child,
.detail-rich-html ul:last-child,
.detail-rich-html ol:last-child {
  margin-bottom: 0;
}

.detail-rich-html .member-only-inline {
  padding: 0 6px;
  border-radius: 8px;
  background: rgba(188, 164, 255, 0.18);
  color: #8d63ff;
}

.detail-rich-html .member-only-inline.is-locked {
  display: inline-block;
  filter: blur(6px);
  cursor: pointer;
  user-select: none;
}

.detail-flex-single,
.detail-gallery-item {
  display: grid;
  gap: 12px;
}

.detail-flex-media {
  overflow: hidden;
  border-radius: 28px;
  background: #191525;
}

.detail-flex-media video,
.detail-flex-media img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 720px;
  object-fit: cover;
}

.detail-flex-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.detail-flex-caption {
  margin: 0;
  color: rgba(66, 62, 93, 0.72);
  font-size: 15px;
  line-height: 1.8;
}

.detail-flex-block.is-locked .is-blurred {
  position: relative;
  filter: blur(11px);
  user-select: none;
  pointer-events: none;
}

.detail-flex-gate {
  width: fit-content;
  min-width: 188px;
  height: 50px;
  padding: 0 22px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #b497ff, #8b76ee);
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
}

@media (max-width: 1520px) {
  .course-detail-shell {
    width: min(1340px, calc(100% - 72px));
  }

  .course-detail-hero h1 {
    font-size: 38px;
  }

  .course-detail-meta {
    font-size: 17px;
  }

  .course-detail-grid {
    grid-template-columns: 280px minmax(0, 1fr) 280px;
  }

  .course-detail-side-card,
  .course-detail-latest-card {
    padding-inline: 20px;
  }

  .course-detail-toc a {
    font-size: 15px;
    padding-inline: 24px;
  }
}

@media (max-width: 1180px) {
  .course-detail-shell {
    width: calc(100% - 40px);
  }

  .course-detail-main {
    padding-bottom: 92px;
  }

  .course-detail-main::before {
    width: 900px;
    height: 900px;
  }

  .course-detail-hero {
    padding-top: 90px;
  }

  .course-detail-hero h1 {
    font-size: 36px;
  }

  .course-detail-meta {
    font-size: 18px;
  }

  .course-detail-tags {
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
  }

  .course-detail-grid {
    grid-template-columns: 1fr;
  }

  .course-detail-side,
  .course-detail-latest {
    gap: 18px;
  }

  .course-detail-panel {
    padding: 48px 28px 54px;
  }

  .course-detail-video,
  .course-detail-video.is-large {
    width: 100%;
    height: 420px;
  }

  .course-detail-spacer {
    height: 260px;
  }
}

@media (max-width: 760px) {
  .course-detail-hero {
    padding-top: 58px;
    padding-bottom: 36px;
  }

  .course-detail-hero h1 {
    font-size: 28px;
    line-height: 1.42;
  }

  .course-detail-meta {
    margin-top: 18px;
    font-size: 16px;
  }

  .course-detail-tags {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-top: 24px;
  }

  .course-detail-tags span {
    height: 42px;
    font-size: 15px;
  }

  .course-detail-side-card,
  .course-detail-latest-card,
  .course-detail-panel {
    border-radius: 28px;
  }

  .course-detail-side-card,
  .course-detail-latest-card {
    padding: 34px 16px 22px;
  }

  .course-detail-side-card h2,
  .course-detail-latest-card h2 {
    font-size: 26px;
  }

  .course-detail-toc {
    gap: 16px;
    margin-top: 24px;
  }

  .course-detail-toc a {
    font-size: 16px;
    padding-inline: 18px;
  }

  .course-detail-side-btn {
    height: 52px;
    font-size: 16px;
  }

  .course-detail-lead,
  .course-detail-paragraph {
    font-size: 17px;
    line-height: 1.8;
  }

  .course-detail-video,
  .course-detail-video.is-large {
    height: 240px;
    margin: 32px auto 38px;
    border-radius: 24px;
  }

  .course-detail-video span {
    width: 62px;
    height: 62px;
  }

  .course-detail-video span::before {
    left: 24px;
    top: 18px;
    border-top-width: 13px;
    border-bottom-width: 13px;
    border-left-width: 20px;
  }

  .course-detail-spacer {
    height: 120px;
  }

  .course-detail-latest-list {
    margin-top: 24px;
  }

  .course-detail-latest-list a {
    min-height: 46px;
    padding-inline: 22px;
    font-size: 15px;
  }

  .detail-flex-title {
    font-size: 22px;
  }

  .detail-rich-html {
    font-size: 18px;
  }
}

body.site-native.cases-gallery-page {
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 255, 255, 0.08), transparent 30%),
    linear-gradient(180deg, #7066ef 0%, #9a8cf2 54%, #f6f4ff 100%);
}

.cases-gallery-main {
  min-height: 100vh;
  padding-bottom: 138px;
}

.cases-gallery-shell {
  width: min(1436px, calc(100% - 196px));
  margin: 0 auto;
}

.cases-gallery-hero {
  padding: 112px 0 78px;
}

.cases-gallery-hero h1 {
  margin: 0;
  text-align: center;
  color: #fff;
  font-size: 58px;
  line-height: 1.2;
  letter-spacing: -0.06em;
  font-weight: 800;
}

.cases-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 328px);
  justify-content: center;
  gap: 28px 22px;
}

.cases-gallery-card {
  position: relative;
  display: block;
  border-radius: 40px;
  overflow: hidden;
  box-shadow: 0 18px 44px rgba(81, 68, 172, 0.14);
}

.cases-gallery-card-link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.cases-gallery-card img {
  width: 100%;
  height: auto;
  display: block;
}

.cases-gallery-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 52px;
  margin-top: 96px;
}

.cases-gallery-pagination a,
.cases-gallery-pagination span {
  color: #29234f;
  font-size: 22px;
  font-weight: 500;
}

.cases-gallery-pagination a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
}

.cases-gallery-pagination .is-active {
  width: 62px;
  min-width: 62px;
  height: 62px;
  border-radius: 18px;
  background: linear-gradient(180deg, #c5a6ff, #ab8cff);
  color: #fff;
  font-weight: 700;
}

@media (max-width: 1520px) {
  .home-page .native-header-inner,
  .course-gallery-page .native-header-inner,
  .cases-gallery-page .native-header-inner,
  .course-detail-page .native-header-inner,
  .cases-detail-page .native-header-inner,
  .contact-page .native-header-inner,
  .membership-page .native-header-inner {
    width: min(1340px, calc(100% - 72px));
  }

  .cases-gallery-shell {
    width: min(1340px, calc(100% - 72px));
  }

  .cases-gallery-grid {
    transform: scale(0.94);
    transform-origin: top center;
    margin-bottom: -82px;
  }
}

@media (max-width: 1180px) {
  .home-page .native-header-inner,
  .course-gallery-page .native-header-inner,
  .cases-gallery-page .native-header-inner,
  .course-detail-page .native-header-inner,
  .cases-detail-page .native-header-inner,
  .contact-page .native-header-inner,
  .membership-page .native-header-inner,
  .cases-gallery-shell {
    width: calc(100% - 40px);
  }

  .cases-gallery-hero {
    padding-top: 90px;
    padding-bottom: 64px;
  }

  .cases-gallery-hero h1 {
    font-size: 42px;
  }

  .cases-gallery-grid {
    transform: none;
    margin-bottom: 0;
    grid-template-columns: repeat(2, 328px);
  }
}

@media (max-width: 760px) {
  .cases-gallery-main {
    padding-bottom: 88px;
  }

  .home-page .native-header-inner,
  .course-gallery-page .native-header-inner,
  .cases-gallery-page .native-header-inner,
  .course-detail-page .native-header-inner,
  .cases-detail-page .native-header-inner,
  .contact-page .native-header-inner,
  .membership-page .native-header-inner,
  .cases-gallery-shell {
    width: calc(100% - 24px);
  }

  .cases-gallery-hero {
    padding-top: 58px;
    padding-bottom: 38px;
  }

  .cases-gallery-hero h1 {
    font-size: 30px;
    line-height: 1.34;
  }

  .cases-gallery-grid {
    grid-template-columns: 328px;
    gap: 20px;
  }

  .cases-gallery-pagination {
    gap: 28px;
    margin-top: 54px;
  }

  .cases-gallery-pagination a,
  .cases-gallery-pagination span {
    font-size: 18px;
  }

  .cases-gallery-pagination .is-active {
    width: 48px;
    min-width: 48px;
    height: 48px;
    border-radius: 14px;
  }
}

body.site-native.cases-detail-page {
  background:
    linear-gradient(180deg, #7066ef 0%, #9a8cf2 42%, #f7f5ff 100%);
}

.cases-detail-main {
  min-height: 100vh;
  padding-bottom: 142px;
}

.cases-detail-shell {
  width: min(1682px, calc(100% - 236px));
  margin: 0 auto;
}

.cases-detail-hero {
  padding: 104px 0 48px;
}

.cases-detail-hero h1 {
  margin: 0;
  text-align: center;
  color: #fff;
  font-size: 58px;
  line-height: 1.16;
  letter-spacing: -0.05em;
  font-weight: 800;
}

.cases-detail-hero-actions {
  display: flex;
  justify-content: center;
  margin-top: 22px;
}

.cases-detail-section {
  padding-top: 2px;
}

.cases-detail-panel {
  padding: 62px 68px 64px;
  border-radius: 58px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 30px 70px rgba(180, 172, 232, 0.2);
}

.cases-detail-tabline {
  position: relative;
  padding-bottom: 34px;
  text-align: center;
  color: #4a4481;
  font-size: 30px;
  font-weight: 700;
}

.cases-detail-tabline::before {
  content: '';
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 0;
  height: 2px;
  background: rgba(79, 79, 103, 0.12);
}

.cases-detail-tabline::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -2px;
  width: 144px;
  height: 9px;
  transform: translateX(-50%);
  background: #59508d;
}

.cases-detail-card {
  margin-top: 42px;
  padding: 54px 88px 72px;
  border-radius: 46px;
  border: 1px solid rgba(145, 152, 222, 0.72);
  background: rgba(255, 255, 255, 0.78);
}

.cases-detail-row {
  display: grid;
  grid-template-columns: 164px minmax(0, 1fr);
  gap: 72px;
  align-items: start;
}

.cases-detail-row + .cases-detail-row {
  margin-top: 96px;
}

.cases-detail-label {
  padding-top: 8px;
  color: #504985;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
}

.cases-detail-value {
  color: #1c1c1f;
  font-size: 30px;
  line-height: 1.48;
  font-weight: 600;
}

.cases-detail-video {
  position: relative;
  width: 100%;
  max-width: 1046px;
  height: 534px;
  border-radius: 34px;
  background: #39305c;
}

.cases-detail-video span {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 94px;
  height: 94px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.98);
}

.cases-detail-video span::before {
  content: '';
  position: absolute;
  left: 39px;
  top: 29px;
  width: 0;
  height: 0;
  border-top: 18px solid transparent;
  border-bottom: 18px solid transparent;
  border-left: 30px solid #39305c;
}

.cases-detail-note {
  padding-top: 2px;
  font-size: 30px;
  font-weight: 700;
}

.cases-detail-image {
  display: block;
  width: 250px;
  height: 250px;
  border-radius: 24px;
  object-fit: cover;
}

.cases-detail-row.is-copy .cases-detail-value {
  max-width: 930px;
  font-size: 27px;
  line-height: 1.72;
  color: rgba(61, 61, 67, 0.44);
  font-weight: 600;
}

.cases-detail-row.is-copy p {
  margin: 0;
}

.cases-detail-row.is-copy p + p {
  margin-top: 14px;
}

.cases-detail-flex-row .cases-detail-value {
  min-width: 0;
}

.cases-detail-flex-row .detail-flex-block {
  gap: 14px;
}

.cases-detail-flex-row .detail-flex-single,
.cases-detail-flex-row .detail-gallery-item {
  min-width: 0;
}

.cases-detail-flex-row .detail-flex-media {
  width: 100%;
  max-width: 1046px;
  overflow: hidden;
  border-radius: 34px;
  background: #39305c;
}

.cases-detail-flex-row .detail-flex-media video,
.cases-detail-flex-row .detail-flex-media img {
  width: 100%;
  height: auto;
  max-height: 680px;
  display: block;
  object-fit: contain;
}

.cases-detail-flex-row .detail-flex-media video {
  aspect-ratio: 16 / 9;
  background: #000;
}

.cases-detail-flex-row .detail-rich-html {
  max-width: 930px;
  color: #1c1c1f;
  font-size: 27px;
  line-height: 1.72;
  font-weight: 600;
}

.cases-detail-flex-row .detail-flex-caption {
  max-width: 930px;
  color: rgba(61, 61, 67, 0.62);
  font-size: 18px;
  line-height: 1.7;
}

@media (max-width: 1520px) {
  .cases-detail-shell {
    width: min(1410px, calc(100% - 72px));
  }

  .cases-detail-hero h1 {
    font-size: 42px;
  }

  .cases-detail-card {
    padding: 48px 54px 60px;
  }

  .cases-detail-row {
    grid-template-columns: 142px minmax(0, 1fr);
    gap: 34px;
  }

  .cases-detail-label {
    font-size: 24px;
  }

  .cases-detail-value,
  .cases-detail-note {
    font-size: 22px;
  }

  .cases-detail-row.is-copy .cases-detail-value {
    font-size: 20px;
  }

  .cases-detail-flex-row .detail-rich-html {
    font-size: 20px;
  }

  .cases-detail-flex-row .detail-flex-caption {
    font-size: 16px;
  }
}

@media (max-width: 1180px) {
  .cases-detail-shell {
    width: calc(100% - 40px);
  }

  .cases-detail-main {
    padding-bottom: 88px;
  }

  .cases-detail-hero {
    padding-top: 72px;
  }

  .cases-detail-hero h1 {
    font-size: 34px;
  }

  .cases-detail-panel {
    padding: 32px 18px 24px;
    border-radius: 30px;
  }

  .cases-detail-card {
    padding: 24px 22px 28px;
    border-radius: 28px;
  }

  .cases-detail-row {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .cases-detail-row + .cases-detail-row {
    margin-top: 34px;
  }

  .cases-detail-video {
    height: 380px;
  }

  .cases-detail-flex-row .detail-flex-media {
    max-width: 100%;
    border-radius: 26px;
  }

  .detail-flex-gallery {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .cases-detail-shell {
    width: calc(100% - 24px);
  }

  .cases-detail-hero {
    padding-top: 54px;
    padding-bottom: 26px;
  }

  .cases-detail-hero h1 {
    font-size: 28px;
  }

  .cases-detail-tabline {
    font-size: 22px;
    padding-bottom: 24px;
  }

  .cases-detail-tabline::after {
    width: 96px;
    height: 8px;
  }

  .cases-detail-label {
    font-size: 20px;
    padding-top: 0;
  }

  .cases-detail-value,
  .cases-detail-note {
    font-size: 18px;
  }

  .cases-detail-video {
    height: 220px;
    border-radius: 24px;
  }

  .cases-detail-video span {
    width: 62px;
    height: 62px;
  }

  .cases-detail-video span::before {
    left: 24px;
    top: 18px;
    border-top-width: 13px;
    border-bottom-width: 13px;
    border-left-width: 20px;
  }

  .cases-detail-image-placeholder {
    width: 180px;
    height: 180px;
    border-radius: 18px;
  }

  .cases-detail-row.is-copy .cases-detail-value {
    font-size: 17px;
  }

  .cases-detail-flex-row .detail-rich-html {
    font-size: 17px;
  }

  .cases-detail-flex-row .detail-flex-media {
    border-radius: 22px;
  }

  .detail-flex-title {
    font-size: 20px;
  }

  .detail-rich-html {
    font-size: 16px;
  }
}

.contact-page {
  --native-header-bg: transparent;
  --native-header-border: transparent;
  --native-header-blur: none;
  --native-brand-color: rgba(255, 255, 255, 0.96);
  --native-brand-glow-opacity: 0.92;
  --native-nav-color: rgba(255, 255, 255, 0.82);
  --native-nav-active: #ffffff;
  --native-login-bg: linear-gradient(180deg, rgba(176, 150, 255, 0.98), rgba(138, 118, 232, 0.98));
  --native-login-text: #ffffff;
  --native-login-border: rgba(180, 156, 255, 0.18);
  --native-login-shadow: none;
  background: #f8f9ff;
}

.contact-page .native-header {
  transition: background 0.28s ease, border-color 0.28s ease, backdrop-filter 0.28s ease;
}

.contact-page .native-header.is-light {
  --native-header-bg: rgba(255, 252, 255, 0.86);
  --native-header-border: rgba(186, 164, 228, 0.14);
  --native-header-blur: blur(20px);
  --native-brand-color: #5b526f;
  --native-brand-glow-opacity: 1;
  --native-nav-color: rgba(108, 92, 162, 0.88);
  --native-nav-active: #8f79ec;
  --native-login-bg: linear-gradient(180deg, #ab94ff, #8f77f5);
  --native-login-text: #ffffff;
  --native-login-border: rgba(151, 124, 245, 0.2);
  --native-login-shadow: 0 10px 24px rgba(151, 124, 245, 0.22);
}

.join-landing {
  color: #1f1b36;
  background:
    radial-gradient(circle at 18% 76%, rgba(255, 182, 222, 0.24), transparent 16%),
    radial-gradient(circle at 78% 72%, rgba(156, 201, 255, 0.22), transparent 18%),
    linear-gradient(180deg, #f7f8ff 0%, #ffffff 100%);
}

.join-shell {
  width: min(1280px, calc(100% - 120px));
  margin: 0 auto;
}

.join-section-title {
  text-align: center;
}

.join-section-title h2 {
  margin: 0;
  color: #1a2258;
  font-size: 34px;
  line-height: 1.22;
  font-weight: 800;
}

.join-section-title h2 span {
  color: #b19aff;
}

.join-hero {
  position: relative;
  overflow: hidden;
  min-height: 680px;
  padding: 118px 0 82px;
  background:
    linear-gradient(180deg, rgba(8, 2, 20, 0.88), rgba(8, 2, 20, 0.88)),
    url('/download/join-page/hero-wave.png') center top/cover no-repeat;
}

.join-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 58% 52%, rgba(145, 112, 255, 0.18), transparent 28%),
    radial-gradient(circle at 18% 48%, rgba(255, 173, 214, 0.12), transparent 26%);
  pointer-events: none;
}

.join-hero-copy {
  position: relative;
  z-index: 1;
  text-align: center;
}

.join-hero h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(54px, 8vw, 74px);
  line-height: 1.06;
  font-weight: 800;
  letter-spacing: -0.06em;
}

.join-hero p {
  margin: 52px 0 0;
  color: rgba(255, 255, 255, 0.92);
  font-size: 30px;
  line-height: 1.54;
  font-weight: 500;
}

.join-shift {
  position: relative;
  padding: 104px 0 110px;
  background:
    linear-gradient(90deg, rgba(21, 31, 72, 0.04) 1px, transparent 1px) 0 0/248px 100%,
    linear-gradient(180deg, rgba(21, 31, 72, 0.04) 1px, transparent 1px) 0 0/100% 248px,
    linear-gradient(180deg, #f8f9ff 0%, #fafbff 100%);
}

.join-shift-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 40px;
  margin-top: 70px;
}

.join-shift-card {
  text-align: center;
  color: #1f295d;
  transition: transform 0.28s ease, opacity 0.28s ease;
}

.join-shift-card img {
  width: 66px;
  height: 66px;
}

.join-shift-card h3 {
  margin: 30px 0 28px;
  font-size: 21px;
  line-height: 1.35;
  font-weight: 800;
}

.join-shift-card p {
  margin: 0;
  color: rgba(60, 74, 118, 0.64);
  font-size: 16px;
  line-height: 1.95;
  font-weight: 500;
}

.join-shift-card p + p {
  margin-top: 18px;
}

.join-proof {
  position: relative;
  padding: 96px 0 126px;
}

.join-proof::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 40px;
  width: 1480px;
  height: 980px;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 28% 34%, rgba(255, 207, 169, 0.24), transparent 20%),
    radial-gradient(circle at 76% 28%, rgba(156, 195, 255, 0.22), transparent 22%),
    radial-gradient(circle at 66% 68%, rgba(180, 166, 255, 0.18), transparent 24%);
  pointer-events: none;
}

.join-proof-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 704px;
  gap: 72px;
  align-items: center;
}

.join-proof-copy h2 {
  margin: 0;
  color: #17245d;
  font-size: 34px;
  line-height: 1.38;
  font-weight: 800;
}

.join-proof-list {
  list-style: none;
  margin: 52px 0 0;
  padding: 0;
  display: grid;
  gap: 30px;
}

.join-proof-list li {
  position: relative;
  padding-left: 44px;
  color: #24305d;
  font-size: 24px;
  line-height: 1.4;
  font-weight: 600;
}

.join-proof-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 6px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid #1b1b22;
}

.join-proof-list li::after {
  content: '';
  position: absolute;
  left: 8px;
  top: 12px;
  width: 9px;
  height: 5px;
  border-left: 2px solid #1b1b22;
  border-bottom: 2px solid #1b1b22;
  transform: rotate(-45deg);
}

.join-proof-video {
  position: relative;
  padding: 0;
  border: 0;
  width: 100%;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(77, 82, 172, 0.18);
  cursor: pointer;
  transition: transform 0.28s ease, box-shadow 0.28s ease;
}

.join-proof-video img {
  width: 100%;
  display: block;
}

.join-proof-play {
  position: absolute;
  right: 22px;
  top: 22px;
  width: 102px;
  height: 102px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 32px rgba(56, 69, 128, 0.16);
}

.join-proof-play::before {
  content: '';
  position: absolute;
  left: 44px;
  top: 34px;
  width: 0;
  height: 0;
  border-top: 14px solid transparent;
  border-bottom: 14px solid transparent;
  border-left: 22px solid #2f3d74;
}

.join-map {
  position: relative;
  overflow: hidden;
  padding: 130px 0 118px;
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 201, 232, 0.34), transparent 20%),
    radial-gradient(circle at 72% 22%, rgba(173, 207, 255, 0.26), transparent 20%),
    linear-gradient(180deg, #f8f9ff 0%, #f6f7ff 100%);
}

.join-map-stage {
  position: relative;
  min-height: 930px;
  margin-top: 78px;
}

.join-map-device {
  position: absolute;
  left: 0;
  top: 148px;
  width: 630px;
  height: 796px;
  border-radius: 48px;
  background: #fff;
  box-shadow: 0 34px 78px rgba(176, 188, 221, 0.2);
  z-index: 2;
}

.join-map-device::before {
  content: '';
  position: absolute;
  inset: 22px;
  border-radius: 38px;
  background: #d8f3ff;
}

.join-map-screen {
  position: absolute;
  inset: 44px 62px 58px;
  border-radius: 34px;
  background: linear-gradient(180deg, #d76cd7 0%, #9e7ddf 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.join-map-screen img {
  width: 210px;
  opacity: 0.72;
}

.join-map-stage[data-tone='green'] .join-map-screen {
  background: linear-gradient(180deg, #75ef9a 0%, #57c97d 100%);
}

.join-map-stage[data-tone='sky'] .join-map-screen {
  background: linear-gradient(180deg, #8fd8ff 0%, #73bff4 100%);
}

.join-map-stage[data-tone='blue'] .join-map-screen {
  background: linear-gradient(180deg, #8ca6ff 0%, #6e82ef 100%);
}

.join-map-stage[data-tone='pink'] .join-map-screen {
  background: linear-gradient(180deg, #ef8be0 0%, #d467bf 100%);
}

.join-map-lines span {
  position: absolute;
  right: 240px;
  height: 1px;
  width: 190px;
  background: rgba(86, 95, 139, 0.24);
}

.join-map-lines span:nth-child(1) {
  top: 182px;
  left: calc(50% + 28px);
}

.join-map-lines span:nth-child(2) {
  top: 334px;
  left: calc(50% + 154px);
}

.join-map-lines span:nth-child(3) {
  top: 492px;
  left: calc(50% + 197px);
}

.join-map-lines span:nth-child(4) {
  top: 652px;
  left: calc(50% + 177px);
}

.join-map-lines span:nth-child(5) {
  top: 812px;
  left: calc(50% + 80px);
}

.join-map-lines::before {
  content: '';
  position: absolute;
  left: -50px;
  top: 100px;
  width: 840px;
  height: 840px;
  border: 1px solid rgba(86, 95, 139, 0.18);
  border-left: 0;
  border-radius: 50%;
}

.join-map-note {
  position: absolute;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 400px;
  padding: 50px 60px;
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 24px 60px rgba(181, 192, 223, 0.2);
}

.join-map-note img {
  width: 82px;
  height: 82px;
}

.join-map-note strong {
  display: block;
  color: #1c1639;
  font-size: 22px;
  font-weight: 800;
}

.join-map-note span {
  display: block;
  margin-top: 8px;
  color: rgba(28, 22, 57, 0.82);
  font-size: 14px;
  font-weight: 600;
}

.join-map-note-top {
  left: 50%;
  top: 12px;
  transform: translateX(-2%);
}

.join-map-note-bottom {
  left: 126px;
  bottom: 30px;
}

.join-map-bubbles {
  position: absolute;
  inset: 0;
  z-index: 2;
}

.join-map-bubble {
  position: absolute;
  right: 96px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 290px;
  min-height: 58px;
  padding: 0 26px;
  border-radius: 999px;
  border: 0;
  color: #1b254b;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.24s ease, box-shadow 0.24s ease, opacity 0.24s ease;
  box-shadow: 0 16px 28px rgba(130, 145, 196, 0.08);
}

.join-map-bubble.is-active {
  transform: translateX(-16px) scale(1.03);
  box-shadow: 0 26px 40px rgba(111, 126, 184, 0.18);
}

.join-map-bubble.is-violet { top: 156px; right: 70px; background: #ceb9ff; }
.join-map-bubble.is-green { top: 304px; right: -60px; background: #74ea90; }
.join-map-bubble.is-sky { top: 466px; right: -110px; background: #b6e2ff; }
.join-map-bubble.is-blue { top: 626px; right: -80px; background: #819bff; }
.join-map-bubble.is-pink { top: 786px; right: 20px; background: #ea7ad7; }

.join-band {
  padding: 108px 0 114px;
  background:
    linear-gradient(180deg, rgba(17, 20, 61, 0.9), rgba(17, 20, 61, 0.9)),
    url('/download/join-page/dark-band.png') center/cover no-repeat;
}

.join-band h2 {
  margin: 0;
  text-align: center;
  color: #fff;
  font-size: 38px;
  line-height: 1.44;
  font-weight: 800;
}

.join-benefits {
  padding: 112px 0 132px;
  background:
    radial-gradient(circle at 22% 92%, rgba(255, 188, 223, 0.32), transparent 22%),
    radial-gradient(circle at 86% 84%, rgba(173, 218, 255, 0.32), transparent 18%),
    linear-gradient(180deg, #fafbff 0%, #f8fbff 100%);
}

.join-benefit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 66px 110px;
  margin-top: 86px;
}

.join-benefit-item {
  display: grid;
  grid-template-columns: 128px minmax(0, 1fr);
  gap: 38px;
  align-items: center;
  transition: transform 0.28s ease;
}

.join-benefit-item img {
  width: 128px;
  height: 128px;
}

.join-benefit-item h3 {
  margin: 0;
  color: #171e53;
  font-size: 30px;
  line-height: 1.28;
  font-weight: 800;
}

.join-benefit-item p {
  margin: 16px 0 0;
  color: rgba(44, 55, 94, 0.48);
  font-size: 17px;
  line-height: 1.8;
  font-weight: 500;
}

.join-audience-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 54px;
  margin-top: 96px;
}

.join-audience-card {
  padding: 46px 30px 38px;
  border-radius: 34px;
  border: 3px solid rgba(255, 255, 255, 0.92);
  text-align: center;
  cursor: pointer;
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.join-audience-card.is-active {
  transform: translateY(-8px);
  box-shadow: 0 28px 46px rgba(167, 177, 229, 0.18);
  border-color: rgba(255, 255, 255, 1);
}

.join-audience-card.is-pink {
  background: rgba(239, 228, 255, 0.88);
}

.join-audience-card.is-lilac {
  background: rgba(228, 223, 255, 0.88);
}

.join-audience-card.is-blue {
  background: rgba(219, 239, 255, 0.88);
}

.join-audience-card img {
  width: 154px;
  height: 154px;
  display: inline-block;
}

.join-audience-card h3 {
  margin: 24px 0 18px;
  color: #181743;
  font-size: 26px;
  line-height: 1.28;
  font-weight: 800;
}

.join-audience-card p {
  margin: 0;
  color: #2d2f58;
  font-size: 18px;
  line-height: 1.8;
  font-weight: 500;
}

.join-open {
  padding: 118px 0 116px;
  background:
    linear-gradient(180deg, rgba(21, 26, 56, 0.58), rgba(21, 26, 56, 0.58)),
    url('/download/Subscribe.png') center top/cover no-repeat;
}

.join-open-copy {
  text-align: center;
}

.join-open h2 {
  margin: 0;
  color: #fff;
  font-size: 54px;
  line-height: 1.14;
  font-weight: 800;
}

.join-open h3 {
  margin: 24px 0 0;
  color: #fff;
  font-size: 34px;
  font-weight: 700;
}

.join-open p {
  margin: 14px 0 0;
  color: rgba(255, 255, 255, 0.95);
  font-size: 20px;
  line-height: 1.8;
  font-weight: 600;
}

.join-open-note {
  margin-top: 34px;
  color: rgba(255, 255, 255, 0.84);
  font-size: 18px;
  font-weight: 500;
}

.join-hero.is-baked-visual {
  min-height: 584px;
  padding: 0;
  background: #0c061c url('/download/join-page/fixed/hero-wave-section.png') center/cover no-repeat;
}

.join-hero.is-baked-visual::after {
  display: none;
}

.join-hero.is-baked-visual .join-shell,
.join-open.is-baked-visual .join-shell {
  display: none;
}

.join-open.is-baked-visual {
  aspect-ratio: 1920 / 506;
  min-height: auto;
  padding: 0;
  background: #8188a1 url('/download/Subscribe.png') center top/100% 100% no-repeat;
}

.join-connect {
  padding: 82px 0 92px;
  background: #edf1ff;
}

.join-connect h2 {
  margin: 0;
  text-align: center;
  color: #495173;
  font-size: 32px;
  font-weight: 800;
}

.join-connect-card {
  width: min(100%, 520px);
  margin: 34px auto 0;
  padding: 34px 28px 30px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 38px rgba(161, 172, 207, 0.18);
  text-align: center;
}

.join-connect-media {
  display: flex;
  align-items: center;
  justify-content: center;
}

.join-connect-qr {
  width: 132px;
  height: 132px;
  padding: 10px;
  border-radius: 24px;
  background: #ffffff;
  border: 1px solid rgba(122, 139, 194, 0.16);
  object-fit: cover;
  box-shadow: 0 14px 30px rgba(133, 147, 196, 0.16);
  animation: joinPulse 3.2s ease-in-out infinite;
}

.join-connect-card p {
  margin: 18px 0 0;
  color: rgba(53, 61, 99, 0.62);
  font-size: 16px;
  line-height: 1.8;
  font-weight: 500;
}

.join-final {
  padding: 126px 0 96px;
  background:
    radial-gradient(circle at 26% 44%, rgba(255, 176, 228, 0.36), transparent 12%),
    radial-gradient(circle at 68% 54%, rgba(170, 190, 255, 0.32), transparent 12%),
    linear-gradient(180deg, #ffffff 0%, #fbfbff 100%);
}

.join-final-copy {
  text-align: center;
}

.join-final-copy p {
  margin: 0;
  color: #1f223c;
  font-size: 44px;
  line-height: 1.56;
  font-weight: 600;
}

.join-final-copy h2 {
  margin: 18px 0 0;
  color: #000;
  font-size: clamp(52px, 7vw, 78px);
  line-height: 1.06;
  font-weight: 800;
}

.join-final-cta {
  margin-top: 34px;
  min-width: 174px;
  height: 56px;
  border: 0;
  border-radius: 999px;
  background: #000;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
}

.join-final-line {
  width: min(1280px, 100%);
  height: 1px;
  margin: 84px auto 0;
  background: rgba(198, 205, 227, 0.46);
}

.join-media-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 28px;
  background: rgba(10, 10, 18, 0.66);
  backdrop-filter: blur(12px);
  z-index: 70;
}

.join-media-modal.is-open {
  display: flex;
}

.home-case-card-dynamic {
  width: 429px;
  height: 620px;
  overflow: hidden;
  border-radius: 34px;
  background: #c9c9c9;
  box-shadow: none;
}

.home-case-card-link {
  display: grid;
  grid-template-rows: 424px 196px;
  height: 100%;
  color: inherit;
  overflow: hidden;
}

.home-case-card-media {
  height: auto;
  min-height: 0;
  overflow: hidden;
  background: #111;
  border-radius: 34px 34px 0 0;
}

.home-case-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.home-case-card-copy {
  height: 196px;
  min-height: 0;
  padding: 26px 28px 24px;
  overflow: hidden;
  background: linear-gradient(180deg, #d3d1ce 0%, #aaa7a1 100%);
  border-radius: 0 0 34px 34px;
}

.home-case-card-meta {
  margin: 0 0 12px;
  color: rgba(255, 255, 255, 0.92);
  font-size: 18px;
  font-weight: 800;
  line-height: 1.42;
}

.home-case-card-copy h3 {
  margin: 0;
  color: #fff;
  font-size: 20px;
  line-height: 1.42;
  font-weight: 800;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.home-case-card-copy > p:last-child {
  margin: 20px 0 0;
  color: rgba(255, 255, 255, 0.66);
  font-size: 15px;
  line-height: 1.72;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

@media (max-width: 1024px) {
  .home-case-card-dynamic {
    width: 100%;
    max-width: 429px;
  }
}

@media (max-width: 640px) {
  .home-case-card-dynamic {
    width: 100%;
    max-width: none;
    height: 520px;
  }

  .home-case-card-link {
    grid-template-rows: 350px 170px;
  }
}

.content-vip-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 26px;
  padding: 0 10px;
  margin-left: 10px;
  border-radius: 999px;
  background: rgba(160, 120, 255, 0.14);
  color: #7c59dd;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  vertical-align: middle;
}

.content-favorite-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 96px;
  height: 40px;
  padding: 0 16px;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: rgba(49, 38, 83, 0.82);
  font: inherit;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  box-shadow:
    0 18px 36px rgba(191, 174, 240, 0.22),
    inset 0 0 0 1px rgba(217, 205, 245, 0.86);
  transition: transform 180ms ease, background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.content-favorite-btn:hover {
  transform: translateY(-1px);
}

.content-favorite-btn.is-active {
  background: linear-gradient(135deg, #c99bff, #a580ff);
  color: #fff;
  box-shadow: 0 22px 40px rgba(184, 140, 255, 0.34);
}

.content-favorite-btn.is-card {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 3;
}

.content-favorite-btn.is-detail {
  min-width: 124px;
  height: 46px;
}

.content-favorite-icon {
  font-size: 14px;
  line-height: 1;
}

.course-gallery-card-dynamic,
.cases-gallery-card-dynamic {
  overflow: hidden;
  background: #fff;
  box-shadow: 0 18px 44px rgba(200, 194, 232, 0.16);
}

.course-gallery-card-dynamic {
  align-self: start;
}

.course-gallery-card-media,
.cases-gallery-card-media {
  aspect-ratio: 1.08 / 1;
  overflow: hidden;
}

.course-gallery-card-media img,
.cases-gallery-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.course-gallery-card-body,
.cases-gallery-card-body {
  padding: 22px 22px 26px;
  background: rgba(255, 255, 255, 0.94);
}

.course-gallery-card-body {
  padding-bottom: 20px;
}

.course-gallery-card-badge,
.cases-gallery-card-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(167, 139, 250, 0.14);
  color: #6650c3;
  font-size: 12px;
  font-weight: 700;
}

.course-gallery-card-body h3,
.cases-gallery-card-body h3 {
  margin: 14px 0 10px;
  color: #111118;
  font-size: 22px;
  line-height: 1.4;
  font-weight: 800;
}

.course-gallery-card-body p,
.cases-gallery-card-body p {
  margin: 0;
  color: rgba(17, 17, 24, 0.68);
  font-size: 15px;
  line-height: 1.75;
}

.course-gallery-pagination button,
.cases-gallery-pagination button {
  border: 0;
  background: transparent;
  color: #30264c;
  font: inherit;
  cursor: pointer;
}

.course-gallery-pagination span,
.cases-gallery-pagination span {
  color: #30264c;
}

.course-detail-video video,
.course-detail-video img,
.cases-detail-video video,
.cases-detail-video img {
  width: 100%;
  height: 100%;
  border-radius: inherit;
  object-fit: cover;
  display: block;
}

.course-detail-paid h3 {
  margin: 52px 0 24px;
  text-align: center;
  color: #c19cff;
  font-size: 32px;
  font-weight: 800;
}

.content-lock-card {
  display: grid;
  justify-items: center;
  gap: 14px;
  padding: 36px 28px 34px;
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(246, 243, 255, 0.98), rgba(238, 233, 255, 0.96));
  box-shadow: inset 0 0 0 1px rgba(192, 156, 255, 0.22);
  text-align: center;
}

.content-lock-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  border-radius: 18px;
  background: linear-gradient(135deg, #b993ff, #8c6dff);
  color: #fff;
  font-size: 26px;
  font-weight: 800;
}

.content-lock-card h3 {
  margin: 0;
  color: #1a1730;
  font-size: 24px;
  font-weight: 800;
}

.content-lock-card p {
  margin: 0;
  color: rgba(30, 24, 50, 0.7);
  font-size: 16px;
  line-height: 1.8;
}

.content-lock-preview {
  width: 100%;
  padding: 18px 20px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.78);
  color: rgba(28, 22, 44, 0.68);
  font-size: 14px;
  line-height: 1.9;
  text-align: left;
}

.content-lock-action {
  min-width: 168px;
  height: 48px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #b189ff, #896eff);
  color: #fff;
  font: inherit;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
}

body.has-content-gate {
  overflow: hidden;
}

.content-gate-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 32px;
  background: rgba(17, 14, 24, 0.76);
  backdrop-filter: blur(6px);
}

.content-gate-modal.is-open {
  display: flex;
}

.content-gate-dialog {
  position: relative;
  width: min(1100px, calc(100vw - 64px));
}

.content-gate-dialog.is-login {
  width: min(560px, calc(100vw - 64px));
}

.content-gate-close {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 2;
  width: 54px;
  height: 54px;
  border: 0;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.94);
  color: #31285a;
  font-size: 34px;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 18px 36px rgba(34, 25, 60, 0.18);
}

.content-gate-card {
  display: grid;
  justify-items: center;
  gap: 28px;
  padding: 72px 48px 58px;
  border-radius: 34px;
  background: #fff;
  box-shadow: 0 42px 90px rgba(30, 20, 55, 0.22);
}

.content-gate-card h3 {
  margin: 0;
  color: #292347;
  font-size: 48px;
  line-height: 1.08;
  font-weight: 800;
}

.content-gate-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-width: 208px;
  height: 62px;
  padding: 0 28px;
  border: 0;
  border-radius: 999px;
  background: #141018;
  color: #fff;
  font: inherit;
  font-size: 24px;
  font-weight: 800;
  cursor: pointer;
}

.content-gate-primary.is-vip {
  min-width: 220px;
  background: linear-gradient(135deg, #f08ef2, #a57dff);
  box-shadow: 0 24px 40px rgba(220, 140, 245, 0.28);
}

.content-vip-dialog {
  position: relative;
  padding: 56px;
  border-radius: 36px;
  background:
    radial-gradient(circle at 10% 8%, rgba(255, 246, 170, 0.7), transparent 18%),
    linear-gradient(135deg, rgba(255, 202, 233, 0.96), rgba(247, 233, 255, 0.98) 32%, rgba(223, 243, 255, 0.98) 100%);
  box-shadow: 0 46px 96px rgba(31, 19, 60, 0.28);
}

.content-vip-ribbon {
  position: absolute;
  top: 36px;
  left: 42px;
  color: #fff;
  font-size: 42px;
  font-weight: 800;
  text-shadow: 0 10px 28px rgba(243, 145, 220, 0.34);
}

.content-vip-panel {
  display: grid;
  justify-items: center;
  gap: 18px;
  min-height: 420px;
  padding: 96px 64px 72px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 245, 205, 0.88), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(251, 255, 255, 0.96));
  box-shadow:
    inset 0 0 0 2px rgba(255, 186, 226, 0.46),
    0 24px 54px rgba(91, 72, 154, 0.24);
}

.content-vip-panel h3 {
  margin: 0;
  color: #6b61d6;
  font-size: 52px;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -0.05em;
}

.content-vip-price {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 430px;
  min-height: 74px;
  margin: 0;
  padding: 0 24px;
  border-radius: 18px;
  background: #3a2d5f;
  color: #fff;
  font-size: 32px;
  font-weight: 800;
}

.content-vip-benefits {
  display: grid;
  justify-items: center;
  gap: 10px;
  color: #6b629e;
  font-size: 21px;
  line-height: 1.5;
  font-weight: 700;
}

.membership-page {
  background:
    radial-gradient(circle at 18% 10%, rgba(208, 224, 255, 0.4), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, #f8f4ff 28%, #f3ecff 100%);
}

.member-main {
  padding: 118px 0 120px;
}

.member-shell {
  width: min(1436px, calc(100% - 196px));
  margin: 0 auto;
}

.member-dashboard {
  display: grid;
  grid-template-columns: 184px minmax(0, 1fr);
  gap: 22px;
}

.member-side,
.member-panel,
.member-tier-card,
.member-profile-card,
.member-favorite-card,
.member-empty {
  border-radius: 34px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(224, 206, 245, 0.88);
  box-shadow: 0 26px 58px rgba(223, 200, 247, 0.22);
}

.member-side {
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 24px 14px;
  min-height: 760px;
  background:
    linear-gradient(180deg, rgba(255, 200, 235, 0.96), rgba(255, 240, 246, 0.92)),
    #fff;
}

.member-side-brand {
  padding: 6px 12px 18px;
}

.member-side-logo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #272343;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.04em;
}

.member-side-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 62px;
  padding: 0 18px;
  border-radius: 18px;
  border: 0;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: inset 0 0 0 1px rgba(226, 206, 245, 0.72);
  color: #3b3155;
  font: inherit;
  font-size: 16px;
  font-weight: 800;
  cursor: pointer;
}

.member-side-link.is-active {
  background: linear-gradient(135deg, rgba(255, 241, 247, 0.98), rgba(255, 255, 255, 0.92));
  box-shadow:
    inset 0 0 0 1px rgba(238, 205, 243, 0.94),
    0 14px 28px rgba(248, 190, 232, 0.22);
  color: #f06eb2;
}

.member-side-logout {
  margin-top: 8px;
  color: rgba(59, 49, 85, 0.72);
}

.member-stage {
  display: grid;
}

.member-panel {
  display: none;
  padding: 34px 38px 38px;
  min-height: 760px;
  background:
    radial-gradient(circle at 10% 8%, rgba(255, 211, 238, 0.58), transparent 28%),
    linear-gradient(180deg, rgba(255, 250, 253, 0.98), rgba(255, 244, 250, 0.98));
}

.member-panel.is-active {
  display: block;
}

.member-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: start;
  margin-bottom: 28px;
}

.member-panel-head h1,
.member-panel-head h2 {
  margin: 0;
  color: #252242;
  font-size: 52px;
  line-height: 1.1;
  letter-spacing: -0.06em;
  font-weight: 800;
}

.member-panel-head p {
  margin: 16px 0 0;
  color: rgba(69, 60, 105, 0.56);
  font-size: 16px;
  line-height: 1.8;
}

.member-profile-card {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  gap: 30px;
  padding: 26px 30px;
  background: linear-gradient(180deg, rgba(255, 244, 249, 0.98), rgba(255, 255, 255, 0.98));
}

.member-profile-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 104px;
  height: 104px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ffb9dd, #f083d8);
  color: #fff;
  font-size: 40px;
  font-weight: 800;
  box-shadow: 0 18px 32px rgba(244, 127, 196, 0.28);
}

.member-profile-info {
  display: grid;
  gap: 16px;
  align-content: center;
}

.member-profile-row {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr);
  gap: 20px;
  align-items: center;
}

.member-profile-row span {
  color: rgba(81, 70, 110, 0.6);
  font-size: 14px;
  font-weight: 700;
}

.member-profile-row strong {
  margin: 0;
  color: #2a2648;
  font-size: 19px;
  line-height: 1.5;
  font-weight: 800;
}

.member-tier-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  margin-top: 22px;
  max-width: 520px;
}

.member-tier-card {
  position: relative;
  overflow: hidden;
  padding: 26px 24px 22px;
  min-height: 196px;
  background:
    radial-gradient(circle at 0% 0%, rgba(161, 203, 255, 0.7), transparent 36%),
    linear-gradient(135deg, rgba(129, 154, 232, 0.94), rgba(96, 120, 208, 0.9) 58%, rgba(213, 163, 231, 0.82));
}

.member-tier-card::after {
  content: '';
  position: absolute;
  inset: auto -40px -70px auto;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.16);
  filter: blur(16px);
}

.member-tier-card.is-current {
  box-shadow: 0 28px 58px rgba(136, 124, 226, 0.32);
}

.member-tier-card.is-locked {
  background:
    linear-gradient(180deg, rgba(246, 243, 255, 0.98), rgba(251, 247, 255, 0.98));
}

.member-tier-card.is-locked::after {
  background: rgba(170, 155, 225, 0.12);
}

.member-tier-kicker {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.9);
  font-size: 12px;
  font-weight: 800;
}

.member-tier-card.is-locked .member-tier-kicker {
  background: rgba(151, 125, 234, 0.1);
  color: #8a6de9;
}

.member-tier-card h3 {
  position: relative;
  z-index: 1;
  margin: 18px 0 10px;
  color: #fff;
  font-size: 36px;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -0.04em;
}

.member-tier-card.is-locked h3 {
  color: #2a2648;
}

.member-tier-price {
  position: relative;
  z-index: 1;
  margin: 0;
  color: rgba(255, 255, 255, 0.94);
  font-size: 24px;
  font-weight: 800;
}

.member-tier-card.is-locked .member-tier-price {
  color: #8a6de9;
}

.member-tier-desc {
  position: relative;
  z-index: 1;
  margin: 14px 0 0;
  color: rgba(255, 255, 255, 0.86);
  font-size: 14px;
  line-height: 1.8;
}

.member-tier-card.is-locked .member-tier-desc {
  color: rgba(66, 57, 98, 0.72);
}

.member-tier-action,
.member-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 140px;
  height: 46px;
  padding: 0 22px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #cf9dff, #a78fff);
  color: #fff;
  font: inherit;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 18px 30px rgba(201, 154, 255, 0.24);
}

.member-tier-action[disabled] {
  opacity: 0.88;
  cursor: default;
}

.member-link-btn {
  background: rgba(255, 255, 255, 0.82);
  color: #6e61b0;
  box-shadow: inset 0 0 0 1px rgba(209, 195, 243, 0.92);
}

.member-favorites-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.member-favorite-card {
  position: relative;
  display: grid;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.95);
}

.member-favorite-link {
  display: grid;
  color: inherit;
  text-decoration: none;
}

.member-favorite-remove {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 2;
  min-width: 92px;
  height: 34px;
  padding: 0 14px;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: #8367dd;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  box-shadow:
    0 16px 28px rgba(206, 183, 243, 0.24),
    inset 0 0 0 1px rgba(214, 197, 244, 0.94);
}

.member-favorite-media {
  aspect-ratio: 1 / 1;
  overflow: hidden;
}

.member-favorite-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.member-favorite-copy {
  display: grid;
  gap: 12px;
  padding: 16px 18px 20px;
}

.member-favorite-copy span {
  display: inline-flex;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(177, 138, 255, 0.14);
  color: #8a6de9;
  font-size: 11px;
  font-weight: 800;
  align-items: center;
}

.member-favorite-copy h3 {
  margin: 12px 0 8px;
  color: #161320;
  font-size: 28px;
  line-height: 1.34;
  font-weight: 800;
}

.member-favorite-copy p {
  margin: 0;
  color: rgba(29, 24, 44, 0.66);
  font-size: 14px;
  line-height: 1.8;
}

.member-empty {
  padding: 48px 34px;
  background: rgba(255, 255, 255, 0.82);
  color: rgba(47, 39, 75, 0.64);
  font-size: 15px;
  text-align: center;
}

.cases-detail-empty {
  color: rgba(21, 21, 30, 0.55);
  font-size: 16px;
}

@media (max-width: 760px) {
  .content-favorite-btn.is-card {
    top: 14px;
    right: 14px;
    min-width: 84px;
    height: 34px;
    padding: 0 12px;
    font-size: 12px;
  }

  .content-favorite-btn.is-detail {
    min-width: 108px;
    height: 40px;
  }

  .course-gallery-card-body h3,
  .cases-gallery-card-body h3 {
    font-size: 18px;
  }

  .course-gallery-card-body p,
  .cases-gallery-card-body p {
    font-size: 14px;
  }

  .home-case-card-copy {
    padding: 18px 18px 22px;
  }

  .home-case-card-meta {
    font-size: 12px;
  }

  .member-favorite-remove {
    top: 12px;
    right: 12px;
  }

  .course-detail-paid h3 {
    margin-top: 38px;
    font-size: 24px;
  }

  .content-lock-card {
    padding: 26px 18px;
    border-radius: 24px;
  }

  .content-lock-card h3 {
    font-size: 20px;
  }

  .content-lock-card p,
  .content-lock-preview {
    font-size: 14px;
  }

  .content-gate-modal {
    padding: 20px;
  }

  .content-gate-dialog,
  .content-gate-dialog.is-login {
    width: calc(100vw - 40px);
  }

  .content-gate-card {
    gap: 20px;
    padding: 56px 24px 38px;
  }

  .content-gate-card h3 {
    font-size: 34px;
  }

  .content-gate-primary {
    min-width: 170px;
    height: 54px;
    font-size: 18px;
  }

  .content-vip-dialog {
    padding: 44px 20px 24px;
  }

  .content-vip-ribbon {
    top: 20px;
    left: 22px;
    font-size: 28px;
  }

  .content-vip-panel {
    min-height: auto;
    padding: 76px 20px 32px;
  }

  .content-vip-panel h3 {
    font-size: 32px;
    text-align: center;
  }

  .content-vip-price {
    min-width: 100%;
    min-height: 60px;
    font-size: 24px;
  }

  .content-vip-benefits {
    font-size: 16px;
  }

  .member-shell {
    width: calc(100% - 40px);
  }

  .member-main {
    padding-top: 92px;
  }

  .member-dashboard,
  .member-tier-grid,
  .member-favorites-grid {
    grid-template-columns: 1fr;
  }

  .member-side,
  .member-panel {
    min-height: auto;
  }

  .member-side {
    padding: 14px;
  }

  .member-panel {
    padding: 26px 22px 28px;
  }

  .member-panel-head h1,
  .member-panel-head h2 {
    font-size: 34px;
  }

  .member-panel-head p {
    font-size: 16px;
  }

  .member-panel-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .member-profile-card {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .member-profile-row {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .member-favorite-copy h3 {
    font-size: 22px;
  }
}

.join-media-dialog {
  position: relative;
  width: min(100%, 880px);
  padding: 18px;
  border-radius: 34px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 36px 80px rgba(18, 22, 52, 0.28);
}

.join-media-dialog img {
  display: block;
  width: 100%;
  border-radius: 24px;
}

.join-media-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  color: #31365e;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}

@keyframes joinPulse {
  0%, 100% { transform: translateY(0) scale(1); opacity: 0.88; }
  50% { transform: translateY(-4px) scale(1.05); opacity: 1; }
}

.join-shift-card:hover,
.join-benefit-item:hover,
.join-proof-video:hover {
  transform: translateY(-6px);
}

.join-proof-video:hover {
  box-shadow: 0 36px 90px rgba(77, 82, 172, 0.24);
}

@media (max-width: 1520px) {
  .join-shell {
    width: min(1280px, calc(100% - 72px));
  }

  .join-map-lines::before {
    width: 650px;
    height: 650px;
  }

  .join-map-note {
    min-width: 310px;
    padding: 30px 20px;
  }

  .join-map-note-bottom {
    bottom: 80px !important;
  }

  .join-map-lines span:nth-child(1) {
    top: 182px;
    left: calc(50% + 28px);
  }

  .join-map-lines span:nth-child(2) {
    top: 304px;
    left: calc(50% + 18px);
  }

  .join-map-lines span:nth-child(3) {
    top: 432px;
    left: calc(50% + 40px);
  }

  .join-map-lines span:nth-child(4) {
    top: 562px;
    left: calc(50% + 10px);
  }

  .join-map-lines span:nth-child(5) {
    top: 682px;
    left: calc(50% + -85px);
  }


  .join-map-bubble.is-violet { top: 156px; right: 70px; }
  .join-map-bubble.is-green { top: 276px; right: 40px; }
  .join-map-bubble.is-sky { top: 406px; right: 20px; }
  .join-map-bubble.is-blue { top: 526px; right: 50px; }
  .join-map-bubble.is-pink { top: 650px; right: 140px; }

  .join-proof-grid {
    grid-template-columns: minmax(0, 1fr) 620px;
    gap: 56px;
  }

  .join-map-device {
    width: 460px;
    height: 652px;
  }

  .join-map-screen {
    inset: 38px 54px 48px;
  }

  .join-map-note-bottom {
    left: 30px;
  }

  .join-map-bubble {
    right: 0;
    font-size: 17px;
  }
}

@media (max-width: 1180px) {
  .join-shell {
    width: calc(100% - 40px);
  }

  .join-hero {
    min-height: 540px;
    padding: 92px 0 66px;
  }

  .join-hero.is-baked-visual {
    min-height: 520px;
    padding: 0;
  }

  .join-hero p {
    font-size: 24px;
    margin-top: 34px;
  }

  .join-shift-grid,
  .join-audience-grid {
    grid-template-columns: 1fr;
  }

  .join-proof-grid,
  .join-benefit-grid {
    grid-template-columns: 1fr;
  }

  .join-proof-video {
    max-width: 704px;
    margin: 0 auto;
  }

  .join-map {
    padding-top: 98px;
  }

  .join-map-stage {
    min-height: auto;
    display: grid;
    gap: 28px;
  }

  .join-map-device,
  .join-map-note,
  .join-map-lines,
  .join-map-bubbles {
    position: static;
    transform: none;
  }

  .join-map-device {
    width: min(100%, 520px);
    height: 680px;
    margin: 0 auto;
  }

  .join-map-note {
    min-width: 0;
    width: min(100%, 420px);
    margin: 0 auto;
  }

  .join-map-lines {
    display: none;
  }

  .join-map-bubbles {
    display: grid;
    gap: 16px;
  }

  .join-map-bubble {
    position: static;
    width: fit-content;
    max-width: 100%;
    margin-left: auto;
  }

  .join-benefit-item {
    grid-template-columns: 108px minmax(0, 1fr);
  }

  .join-open h2 {
    font-size: 42px;
  }

  .join-final-copy p {
    font-size: 30px;
  }
}

@media (max-width: 760px) {
  .join-shell {
    width: calc(100% - 24px);
  }

  .join-section-title h2,
  .join-proof-copy h2 {
    font-size: 28px;
  }

  .join-hero {
    min-height: 460px;
    padding-top: 72px;
  }

  .join-hero.is-baked-visual {
    min-height: 340px;
    padding: 0;
    background-position: center;
  }

  .join-hero h1 {
    font-size: 40px;
    line-height: 1.12;
  }

  .join-hero p {
    font-size: 19px;
    line-height: 1.7;
  }

  .join-shift,
  .join-proof,
  .join-map,
  .join-benefits,
  .join-open,
  .join-final {
    padding-block: 72px;
  }

  .join-proof-list li {
    font-size: 20px;
  }

  .join-map-device {
    height: 520px;
    border-radius: 34px;
  }

  .join-map-device::before {
    inset: 16px;
    border-radius: 28px;
  }

  .join-map-screen {
    inset: 30px 34px 36px;
    border-radius: 24px;
  }

  .join-map-screen img {
    width: 136px;
  }

  .join-map-note {
    padding: 16px 18px;
    border-radius: 22px;
  }

  .join-map-note img {
    width: 64px;
    height: 64px;
  }

  .join-map-note strong {
    font-size: 18px;
  }

  .join-map-bubble {
    min-height: 48px;
    padding-inline: 18px;
    font-size: 15px;
  }

  .join-band h2,
  .join-open h2 {
    font-size: 30px;
  }

  .join-open h3 {
    font-size: 24px;
  }

  .join-open p {
    font-size: 17px;
  }

  .join-benefit-item {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .join-benefit-item img {
    margin: 0 auto;
  }

  .join-benefit-item h3 {
    font-size: 24px;
  }

  .join-audience-card {
    padding: 36px 22px 30px;
  }

  .join-audience-card img {
    width: 124px;
    height: 124px;
  }

  .join-audience-card h3 {
    font-size: 22px;
  }

  .join-audience-card p {
    font-size: 16px;
  }

  .join-connect h2,
  .join-final-copy p {
    font-size: 24px;
  }

  .join-final-copy h2 {
    font-size: 40px;
  }

  .join-final-cta {
    min-width: 156px;
    height: 50px;
    font-size: 16px;
  }

  .join-final-line {
    margin-top: 52px;
  }
}

/* Unified native navigation, matched to the MasterGo home header. */
.site-native .native-header,
.contact-page .native-header,
.contact-page .native-header.is-light {
  position: sticky;
  top: 0;
  z-index: 30;
  padding: 24px 18px 20px;
  background: #fff;
  border-bottom: 0;
  backdrop-filter: none;
}

.site-native .native-header-inner,
.home-page .native-header-inner,
.course-gallery-page .native-header-inner,
.cases-gallery-page .native-header-inner,
.course-detail-page .native-header-inner,
.cases-detail-page .native-header-inner,
.contact-page .native-header-inner,
.membership-page .native-header-inner {
  width: min(1176px, calc(100% - 64px));
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  margin: 0 auto;
}

.site-native .native-brand,
.home-page .native-brand {
  display: inline-flex;
  flex: 0 0 105px;
  width: 105px;
  height: 31px;
  padding: 0;
  overflow: visible;
  color: transparent;
  font-size: 0;
  line-height: 0;
  letter-spacing: 0;
  background: none;
}

.site-native .native-brand::before,
.site-native .native-brand::after {
  display: none;
}

.site-native .native-brand img {
  display: block;
  width: 105px;
  height: 31px;
  max-width: none;
  object-fit: contain;
}

.site-native .native-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 31px;
}

.site-native .native-nav a,
.site-native .native-nav-login,
.site-native .native-nav-logout {
  height: 32px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  color: #897ae3;
  font-size: 15px;
  font-weight: 800;
  line-height: 32px;
}

.site-native .native-nav a.is-active {
  color: #897ae3;
}

.site-native .native-nav-login,
.site-native .native-nav-logout,
.site-native .native-nav a.native-member-link {
  min-width: 88px;
  justify-content: center;
  padding: 0 14px;
  border: 1px solid rgba(137, 122, 227, 0.2);
  border-radius: 4px;
  background: #897ae3;
  color: #fff;
}

.site-native .native-nav-logout {
  background: #fff;
  color: #897ae3;
}

@media (max-width: 760px) {
  .site-native .native-header,
  .contact-page .native-header,
  .contact-page .native-header.is-light {
    padding: 16px 12px;
  }

  .site-native .native-header-inner,
  .home-page .native-header-inner,
  .course-gallery-page .native-header-inner,
  .cases-gallery-page .native-header-inner,
  .course-detail-page .native-header-inner,
  .cases-detail-page .native-header-inner,
  .contact-page .native-header-inner,
  .membership-page .native-header-inner {
    width: calc(100% - 24px);
  }

  .site-native .native-nav {
    gap: 12px;
  }
}

/* Final nav stability pass: keep header geometry identical across pages and auth states. */
.site-native .native-header,
.contact-page .native-header,
.contact-page .native-header.is-light {
  padding: 24px 18px 20px !important;
  background: #fff !important;
}

.site-native .native-header-inner,
.home-page .native-header-inner,
.course-gallery-page .native-header-inner,
.cases-gallery-page .native-header-inner,
.course-detail-page .native-header-inner,
.cases-detail-page .native-header-inner,
.contact-page .native-header-inner,
.membership-page .native-header-inner {
  width: min(1176px, calc(100% - 64px)) !important;
  min-height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 22px !important;
  margin: 0 auto !important;
}

.site-native .native-brand,
.home-page .native-brand {
  display: inline-flex !important;
  flex: 0 0 132px !important;
  width: 132px !important;
  height: 44px !important;
  align-items: center !important;
  justify-content: flex-start !important;
  padding: 0 !important;
  overflow: visible !important;
  background: none !important;
  color: transparent !important;
  font-size: 0 !important;
  line-height: 0 !important;
}

.site-native .native-brand::before,
.site-native .native-brand::after,
.home-page .native-brand::before,
.home-page .native-brand::after {
  display: none !important;
  content: none !important;
}

.site-native .native-brand img,
.home-page .native-brand img {
  display: block !important;
  width: 105px !important;
  height: 31px !important;
  min-width: 105px !important;
  max-width: 105px !important;
  object-fit: contain !important;
  opacity: 1 !important;
  filter: none !important;
}

.site-native .native-nav {
  display: grid !important;
  grid-template-columns: 48px 94px 70px 86px 112px 104px !important;
  column-gap: 31px !important;
  align-items: center !important;
  justify-content: end !important;
  flex: 0 0 669px !important;
  width: 669px !important;
}

.site-native .native-nav a,
.site-native .native-nav-login,
.site-native .native-nav-logout {
  box-sizing: border-box !important;
  display: inline-flex !important;
  width: 100% !important;
  min-width: 0 !important;
  height: 40px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 4px !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #897ae3 !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 40px !important;
  white-space: nowrap !important;
  letter-spacing: 0 !important;
  transform: none !important;
  transition: color 0.16s ease, background-color 0.16s ease, border-color 0.16s ease !important;
}

.site-native .native-nav a.is-active {
  color: #897ae3 !important;
  font-size: 15px !important;
  font-weight: 800 !important;
}

.site-native .native-nav-login {
  border: 1px solid rgba(137, 122, 227, 0.2) !important;
  background: #897ae3 !important;
  color: #fff !important;
}

.site-native .native-nav-logout {
  border: 1px solid rgba(137, 122, 227, 0.2) !important;
  background: #fff !important;
  color: #897ae3 !important;
}

.site-native .native-nav-logout[hidden] {
  display: inline-flex !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

@media (max-width: 900px) {
  .site-native .native-header-inner,
  .home-page .native-header-inner,
  .course-gallery-page .native-header-inner,
  .cases-gallery-page .native-header-inner,
  .course-detail-page .native-header-inner,
  .cases-detail-page .native-header-inner,
  .contact-page .native-header-inner,
  .membership-page .native-header-inner {
    width: calc(100% - 28px) !important;
    gap: 14px !important;
  }

  .site-native .native-brand,
  .home-page .native-brand {
    flex-basis: 112px !important;
    width: 112px !important;
  }

  .site-native .native-nav {
    grid-template-columns: repeat(4, max-content) 92px 88px !important;
    column-gap: 14px !important;
    flex: 1 1 auto !important;
    width: auto !important;
  }

  .site-native .native-nav a,
  .site-native .native-nav-login,
  .site-native .native-nav-logout {
    font-size: 13px !important;
  }
}

/* Join page MasterGo alignment: keep real DOM/interactions, lock section geometry to exported artboards. */
.contact-page {
  background: #f5f8ff;
}

.contact-page .native-header {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 96px !important;
  padding: 24px 18px 0 !important;
  background: transparent !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.contact-page .native-header-inner {
  width: min(1138px, calc(100% - 140px)) !important;
  height: 48px !important;
}

.contact-page .native-nav a,
.contact-page .native-nav-login,
.contact-page .native-nav-logout {
  color: #9b86ff !important;
}

.contact-page .native-nav-login {
  background: #8d79e9 !important;
  color: #fff !important;
}

.join-landing {
  background: #f5f8ff;
}

.join-shell {
  width: min(1184px, calc(100% - 140px));
}

.join-hero.is-baked-visual {
  height: 800px;
  min-height: 800px;
  padding: 0;
  background: #0b0618 url('/download/切图 100.png') center top / cover no-repeat;
}

.join-shift {
  min-height: 704px;
  padding: 132px 0 92px;
  background: #f5f8ff url('/download/切图 101.png') center top / cover no-repeat;
}

.join-shift .join-section-title h2 {
  color: #111a4b;
  font-size: 34px;
  line-height: 1.18;
  font-weight: 800;
}

.join-shift-grid {
  max-width: 1080px;
  margin: 82px auto 0;
  gap: 72px;
}

.join-shift-card img {
  width: 58px;
  height: 58px;
  display: inline-block;
}

.join-shift-card h3 {
  margin: 38px 0 24px;
  color: #121b4f;
  font-size: 20px;
  line-height: 1.32;
}

.join-shift-card p {
  color: rgba(46, 61, 102, 0.55);
  font-size: 15px;
  line-height: 1.75;
}

.join-proof {
  min-height: 850px;
  padding: 166px 0 132px;
  background:
    radial-gradient(circle at 36% 8%, rgba(255, 205, 174, 0.24), transparent 20%),
    radial-gradient(circle at 77% 18%, rgba(174, 206, 255, 0.22), transparent 22%),
    #fff;
}

.join-proof::before {
  display: none;
}

.join-proof-grid {
  grid-template-columns: 390px 670px;
  gap: 150px;
  align-items: center;
}

.join-proof-copy h2 {
  color: #172257;
  font-size: 36px;
  line-height: 1.42;
  letter-spacing: -0.02em;
}

.join-proof-list {
  margin-top: 62px;
  gap: 34px;
}

.join-proof-list li {
  font-size: 26px;
  color: #5c647d;
}

.join-proof-video {
  width: 670px;
  border-radius: 16px;
  box-shadow: 0 34px 90px rgba(113, 118, 204, 0.22);
}

.join-proof-play {
  right: 124px;
  top: 54px;
  width: 100px;
  height: 100px;
}

.join-map {
  /* min-height: 1617px; */
  padding: 126px 0 40px;
  background:
    radial-gradient(circle at 10% 21%, rgba(255, 200, 227, 0.5), transparent 18%),
    radial-gradient(circle at 86% 20%, rgba(191, 223, 255, 0.42), transparent 18%),
    linear-gradient(180deg, #f5f8ff 0%, #eef3ff 100%);
}

.join-map .join-section-title h2 {
  font-size: 40px;
  line-height: 1.2;
}

.join-map-stage {
  max-width: 1280px;
  margin: 92px auto 0;
}

.join-map-screen {
  inset: 54px 72px 64px;
  border-radius: 38px;
}

.join-map-note-top {
  left: 300px;
  top: 40px;
  transform: none;
}

.join-map-note-bottom {
  left: -72px;
  bottom: -70px;
}

.join-map-lines span {
  right: 220px;
}

.join-map-bubble {
  right: 0;
}

.join-band {
  height: 253px;
  padding: 0;
  display: flex;
  align-items: center;
  background: #101744 url('/download/切图 120.png') center / cover no-repeat;
}

.join-band h2 {
  display: none;
}

.join-benefits {
  padding: 110px 0 128px;
  background:
    radial-gradient(circle at 14% 92%, rgba(255, 203, 237, 0.48), transparent 20%),
    radial-gradient(circle at 86% 92%, rgba(194, 235, 255, 0.55), transparent 20%),
    #fff;
}

.join-benefit-grid {
  width: min(1220px, 100%);
  margin: 82px auto 0;
  gap: 88px 160px;
}

.join-audience-grid {
  width: min(1560px, 100%);
  margin: 150px auto 0;
  gap: 58px;
}

.join-audience-card {
  min-height: 344px;
  padding: 54px 34px 44px;
}

.join-open.is-baked-visual {
  height: 506px;
  min-height: 506px;
  aspect-ratio: auto;
  background: #7b86a0 url('/download/Subscribe.png') center top / cover no-repeat;
}

.join-connect {
  min-height: 350px;
  padding: 58px 0 62px;
  background: #eaf0ff;
}

.join-connect h2 {
  color: #4b536f;
  font-size: 31px;
}

.join-connect-card {
  width: 126px;
  min-height: 126px;
  margin-top: 36px;
  padding: 0;
  border-radius: 16px;
  background: #fff;
}

.join-connect-media {
  width: 100%;
  height: 100%;
}

.join-connect-qr {
  width: 100%;
  height: 100%;
  padding: 0;
  border: 0;
  border-radius: inherit;
  box-shadow: none;
}

.join-connect-card p {
  display: none;
}

.join-final {
  min-height: 620px;
  padding: 148px 0 78px;
  background:
    radial-gradient(circle at 31% 52%, rgba(255, 177, 231, 0.42), transparent 14%),
    radial-gradient(circle at 67% 58%, rgba(176, 202, 255, 0.38), transparent 15%),
    linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.join-final-copy p {
  color: #000;
  font-size: 35px;
  line-height: 1.66;
  font-weight: 600;
}

.join-final-copy h2 {
  margin-top: 4px;
  color: #000;
  font-size: 46px;
  line-height: 1.2;
}

.join-final-cta {
  min-width: 236px;
  height: 58px;
  margin-top: 40px;
  font-size: 18px;
}

.join-final-line {
  margin-top: 104px;
}

@media (max-width: 1180px) {
  .contact-page .native-header {
    height: 82px !important;
    padding-top: 18px !important;
  }

  .contact-page .native-header-inner,
  .join-shell {
    width: calc(100% - 40px) !important;
  }

  .join-hero.is-baked-visual {
    height: 540px;
    min-height: 540px;
  }

  .join-shift,
  .join-proof,
  .join-map,
  .join-benefits,
  .join-connect,
  .join-final {
    min-height: 0;
  }

  .join-proof-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .join-proof-video {
    width: min(100%, 670px);
  }
}

@media (max-width: 760px) {
  .join-hero.is-baked-visual {
    height: 360px;
    min-height: 360px;
  }

  .join-shift {
    padding: 88px 0 68px;
  }

  .join-shift-grid {
    margin-top: 56px;
  }

  .join-map {
    padding-top: 82px;
  }

  .join-open.is-baked-visual {
    height: 260px;
    min-height: 260px;
  }
}

/* No-jitter navigation lock: route changes and auth hydration must not move the header. */
body.site-native .native-header,
body.contact-page .native-header,
body.contact-page .native-header.is-light {
  box-sizing: border-box !important;
  height: 88px !important;
  min-height: 88px !important;
  padding: 22px 18px !important;
  border-bottom: 0 !important;
  transform: none !important;
  transition: none !important;
}

body.site-native:not(.contact-page) .native-header {
  position: sticky !important;
  top: 0 !important;
  background: #fff !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

body.contact-page .native-header {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

body.site-native .native-header-inner,
body.home-page .native-header-inner,
body.course-gallery-page .native-header-inner,
body.cases-gallery-page .native-header-inner,
body.course-detail-page .native-header-inner,
body.cases-detail-page .native-header-inner,
body.contact-page .native-header-inner,
body.membership-page .native-header-inner {
  box-sizing: border-box !important;
  width: min(1176px, calc(100% - 64px)) !important;
  height: 44px !important;
  min-height: 44px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 24px !important;
  transform: none !important;
  transition: none !important;
}

body.site-native .native-brand,
body.home-page .native-brand {
  box-sizing: border-box !important;
  flex: 0 0 132px !important;
  width: 132px !important;
  min-width: 132px !important;
  height: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  overflow: hidden !important;
  transform: none !important;
  transition: none !important;
}

body.site-native .native-brand::before,
body.site-native .native-brand::after,
body.home-page .native-brand::before,
body.home-page .native-brand::after {
  display: none !important;
}

body.site-native .native-brand img,
body.home-page .native-brand img {
  display: block !important;
  width: 105px !important;
  min-width: 105px !important;
  max-width: 105px !important;
  height: 31px !important;
  object-fit: contain !important;
  opacity: 1 !important;
  filter: none !important;
  transform: none !important;
  transition: none !important;
}

body.site-native .native-nav {
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: 48px 94px 70px 86px 112px 104px !important;
  column-gap: 31px !important;
  align-items: center !important;
  justify-content: end !important;
  flex: 0 0 669px !important;
  width: 669px !important;
  min-width: 669px !important;
  height: 44px !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: none !important;
  transition: none !important;
}

body.site-native .native-nav a,
body.site-native .native-nav-login,
body.site-native .native-nav-logout {
  box-sizing: border-box !important;
  display: inline-flex !important;
  width: 100% !important;
  min-width: 0 !important;
  height: 40px !important;
  min-height: 40px !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 4px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 40px !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
  transform: none !important;
  transition: none !important;
}

body.site-native .native-nav a,
body.site-native .native-nav a.is-active {
  border: 0 !important;
  background: transparent !important;
  color: #897ae3 !important;
  box-shadow: none !important;
}

body.site-native .native-nav-login {
  border: 1px solid rgba(137, 122, 227, 0.2) !important;
  background: #897ae3 !important;
  color: #fff !important;
  box-shadow: none !important;
}

body.site-native .native-nav-logout {
  border: 1px solid rgba(137, 122, 227, 0.2) !important;
  background: #fff !important;
  color: #897ae3 !important;
  box-shadow: none !important;
}

body.site-native .native-nav-login[hidden],
body.site-native .native-nav-logout[hidden] {
  display: inline-flex !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

@media (max-width: 900px) {
  body.site-native .native-header,
  body.contact-page .native-header,
  body.contact-page .native-header.is-light {
    height: 76px !important;
    min-height: 76px !important;
    padding: 16px 14px !important;
  }

  body.site-native .native-header-inner,
  body.home-page .native-header-inner,
  body.course-gallery-page .native-header-inner,
  body.cases-gallery-page .native-header-inner,
  body.course-detail-page .native-header-inner,
  body.cases-detail-page .native-header-inner,
  body.contact-page .native-header-inner,
  body.membership-page .native-header-inner {
    width: calc(100% - 28px) !important;
    height: 44px !important;
    min-height: 44px !important;
    gap: 14px !important;
  }

  body.site-native .native-brand,
  body.home-page .native-brand {
    flex-basis: 96px !important;
    width: 96px !important;
    min-width: 96px !important;
  }

  body.site-native .native-brand img,
  body.home-page .native-brand img {
    width: 90px !important;
    min-width: 90px !important;
    max-width: 90px !important;
    height: 27px !important;
  }

  body.site-native .native-nav {
    grid-template-columns: 40px 74px 56px 70px 92px 88px !important;
    column-gap: 12px !important;
    flex: 0 0 492px !important;
    width: 492px !important;
    min-width: 492px !important;
  }

  body.site-native .native-nav a,
  body.site-native .native-nav-login,
  body.site-native .native-nav-logout {
    height: 34px !important;
    min-height: 34px !important;
    font-size: 13px !important;
    line-height: 34px !important;
  }
}
