/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Apr 30 2026 | 03:57:35 */
@charset "UTF-8";

/* =========================================================
   front-page-refine.css
   - for front-page.php (main.top-page-v2)
   - background restored
   - no MV background image
   - safe scoped styles for TOP page only
========================================================= */

/* =========================================================
   background restore
   - 以前消えてしまった背景表現を復活
   - TOP以外にも使われている共通背景要素を壊さないための最低限
========================================================= */
html,
body {
  background-color: #04080f;
}

.site-bg-ambient {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.site-bg-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0;
  transition: opacity 1.4s ease;
}

.site-bg-ambient.is-bg-ready .site-bg-glow {
  opacity: 1;
}

.site-bg-glow:nth-child(1) {
  width: 700px;
  height: 700px;
  top: -12%;
  left: -8%;
  background: radial-gradient(circle, rgba(24, 78, 210, .38) 0%, transparent 68%);
}

.site-bg-glow:nth-child(2) {
  width: 560px;
  height: 560px;
  top: 18%;
  right: -10%;
  background: radial-gradient(circle, rgba(110, 38, 230, .32) 0%, transparent 68%);
}

.site-bg-glow:nth-child(3) {
  width: 480px;
  height: 480px;
  bottom: 10%;
  left: 18%;
  background: radial-gradient(circle, rgba(0, 190, 230, .26) 0%, transparent 68%);
}

.site-bg-glow:nth-child(4) {
  width: 420px;
  height: 420px;
  top: 52%;
  right: 12%;
  background: radial-gradient(circle, rgba(50, 110, 255, .24) 0%, transparent 68%);
}

.site-bg-glow:nth-child(5) {
  width: 520px;
  height: 520px;
  bottom: -8%;
  right: -12%;
  background: radial-gradient(circle, rgba(160, 60, 255, .28) 0%, transparent 68%);
}

.site-bg-stars {
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1.2px 1.2px at 8% 12%, rgba(255,255,255,.72) 0%, transparent 100%),
    radial-gradient(1px 1px at 22% 38%, rgba(255,255,255,.50) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 38% 7%, rgba(255,255,255,.60) 0%, transparent 100%),
    radial-gradient(1px 1px at 58% 28%, rgba(255,255,255,.44) 0%, transparent 100%),
    radial-gradient(1.2px 1.2px at 74% 52%, rgba(255,255,255,.55) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 86% 10%, rgba(255,255,255,.65) 0%, transparent 100%),
    radial-gradient(1px 1px at 48% 68%, rgba(255,255,255,.38) 0%, transparent 100%),
    radial-gradient(1px 1px at 14% 78%, rgba(255,255,255,.48) 0%, transparent 100%),
    radial-gradient(1px 1px at 90% 73%, rgba(255,255,255,.42) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 32% 58%, rgba(255,255,255,.58) 0%, transparent 100%),
    radial-gradient(1px 1px at 65% 88%, rgba(255,255,255,.35) 0%, transparent 100%),
    radial-gradient(1.2px 1.2px at 3% 45%, rgba(255,255,255,.46) 0%, transparent 100%);
  opacity: .75;
}

.site-bg-stars-2 {
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at 5% 52%, rgba(200,220,255,.48) 0%, transparent 100%),
    radial-gradient(1px 1px at 17% 23%, rgba(200,220,255,.36) 0%, transparent 100%),
    radial-gradient(1px 1px at 69% 79%, rgba(200,220,255,.42) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 81% 38%, rgba(200,220,255,.54) 0%, transparent 100%),
    radial-gradient(1px 1px at 43% 91%, rgba(200,220,255,.36) 0%, transparent 100%),
    radial-gradient(1px 1px at 94% 28%, rgba(200,220,255,.48) 0%, transparent 100%),
    radial-gradient(1px 1px at 53% 46%, rgba(200,220,255,.30) 0%, transparent 100%),
    radial-gradient(1px 1px at 27% 70%, rgba(200,220,255,.42) 0%, transparent 100%),
    radial-gradient(1.2px 1.2px at 76% 14%, rgba(200,220,255,.52) 0%, transparent 100%),
    radial-gradient(1px 1px at 11% 60%, rgba(200,220,255,.32) 0%, transparent 100%);
  opacity: .55;
}

.site-bg-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 56px 56px;
  opacity: .65;
}

.site-bg-bridge {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 220px;
  background: linear-gradient(to top, rgba(28,56,140,.24) 0%, transparent 100%);
  opacity: .85;
}

header.site-header.is-scrolled {
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom-color: rgba(255,255,255,.08);
  box-shadow: 0 1px 24px rgba(3,8,18,.20);
}

/* =========================================================
   top page scoped styles
========================================================= */
.top-page-v2 {
  --tp-color-text: #edf4ff;
  --tp-color-text-soft: rgba(237, 244, 255, 0.82);
  --tp-color-text-muted: rgba(237, 244, 255, 0.60);
  --tp-color-text-faint: rgba(237, 244, 255, 0.40);
  --tp-color-accent: #4a9eff;
  --tp-color-accent-soft: rgba(100, 180, 255, 0.70);
  --tp-color-surface: rgba(255, 255, 255, 0.03);
  --tp-color-surface-hover: rgba(255, 255, 255, 0.05);
  --tp-color-border: rgba(255, 255, 255, 0.09);
  --tp-color-border-strong: rgba(255, 255, 255, 0.16);
  --tp-shadow-card: 0 8px 32px rgba(3, 8, 18, 0.40);
  --tp-radius-card: 20px;
  --tp-radius-btn: 999px;

  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 100%;
  color: var(--tp-color-text);
  background: transparent;
  overflow: visible;
}

/* ---------------------------------------------------------
   scope reset
--------------------------------------------------------- */
.top-page-v2,
.top-page-v2 *,
.top-page-v2 *::before,
.top-page-v2 *::after {
  box-sizing: border-box;
}

.top-page-v2 h1,
.top-page-v2 h2,
.top-page-v2 h3,
.top-page-v2 h4,
.top-page-v2 h5,
.top-page-v2 h6,
.top-page-v2 p,
.top-page-v2 ul,
.top-page-v2 ol,
.top-page-v2 li,
.top-page-v2 figure {
  margin: 0;
  padding: 0;
  color: inherit;
}

.top-page-v2 ul,
.top-page-v2 ol {
  list-style: none;
}

.top-page-v2 a {
  color: inherit;
  text-decoration: none;
  transition:
    color .25s ease,
    background-color .25s ease,
    border-color .25s ease,
    transform .22s ease,
    box-shadow .25s ease,
    opacity .25s ease;
}

.top-page-v2 a:hover {
  opacity: 1;
}

.top-page-v2 img {
  display: block;
  max-width: 100%;
  height: auto;
}

/* ---------------------------------------------------------
   inner
--------------------------------------------------------- */
.top-page-v2__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1320px;
  margin-inline: auto;
  padding-inline: clamp(20px, 4vw, 60px);
}

/* ---------------------------------------------------------
   orb unified settings
   - 位置とサイズは CSS
   - 回転 / 浮遊 / スクロール連動は JS
--------------------------------------------------------- */
.top-page-v2__mv-orb {
  position: fixed;
  top: 50%;
  right: 8%;
  width: clamp(320px, 38vw, 600px);
  height: auto;
  translate: 0 -50%;
  pointer-events: none;
  z-index: 0;
  display: block;
  visibility: visible;
  opacity: 1;
}

.top-page-v2__mv-orb-img {
  display: block;
  width: 100%;
  height: auto;
  opacity: 1;
  filter: none;
  transform-origin: 50% 50%;
  will-change: transform;
}

.is-gsap-active .top-page-v2__mv-orb,
.is-gsap-active .top-page-v2__mv-orb-img {
  will-change: transform;
}

/* ---------------------------------------------------------
   MV
--------------------------------------------------------- */
.top-page-v2__mv {
  position: relative;
  isolation: isolate;
  min-height: clamp(420px, 68vh, 760px);
  display: flex;
  align-items: center;
  padding-block: clamp(60px, 8vh, 100px);
  overflow: visible;
}

.top-page-v2__mv-inner {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  width: 100%;
  min-width: 0;
}

.top-page-v2__mv-copy {
  flex: 1;
  min-width: 0;
  max-width: min(860px, 100%);
}

.top-page-v2__mv-label {
  font-size: clamp(.72rem, 1.2vw, .86rem);
  line-height: 1.4;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(237, 244, 255, 0.58);
  margin-bottom: 24px;
}

.top-page-v2__mv-title {
  max-width: 100%;
  font-size: clamp(2.25rem, 5.2vw, 4.8rem);
  font-weight: 700;
  line-height: 1.10;
  letter-spacing: -.015em;
  color: #edf4ff;
  margin-bottom: 24px;
  text-shadow: 0 4px 24px rgba(0, 0, 0, 0.22);
  white-space: normal;
  word-break: keep-all;
  overflow-wrap: normal;
}

.top-page-v2__mv-line {
  display: block;
  white-space: nowrap;
}

.top-page-v2__mv-line + .top-page-v2__mv-line {
  margin-top: .08em;
}

.top-page-v2__mv-lead {
  max-width: min(620px, 100%);
  margin-top: 0;
  font-size: clamp(.94rem, 1.45vw, 1.08rem);
  line-height: 1.85;
  color: var(--tp-color-text-soft);
  white-space: pre-line;
}

/* ---------------------------------------------------------
   section common
--------------------------------------------------------- */
.top-page-v2__section {
  position: relative;
  z-index: 1;
  padding-block: clamp(80px, 12vh, 140px);
}

.top-page-v2__section-heading {
  margin-bottom: clamp(40px, 6vw, 64px);
}

.top-page-v2__section-label {
  display: none;
}

.top-page-v2__section-title {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 8px;
  font-size: inherit;
  line-height: 1;
  font-family: inherit;
  font-weight: inherit;
}

.top-page-v2__section-title-ja {
  display: block;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: .04em;
  color: rgba(237, 244, 255, 0.70);
  font-family: YakuHanJP, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", Meiryo, sans-serif;
}

.top-page-v2__section-title-en {
  display: block;
  margin: 0;
  font-size: clamp(72px, 10vw, 128px);
  font-family: rama-gothic-c, sans-serif;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.02em;
  color: #edf4ff;
  text-transform: uppercase;
  user-select: none;
  word-break: break-word;
}

.top-page-v2__section-text {
  max-width: 620px;
  margin-top: 16px;
  font-size: clamp(.88rem, 1.3vw, 1rem);
  line-height: 1.85;
  color: var(--tp-color-text-muted);
}

.top-page-v2__section-footer {
  margin-top: clamp(32px, 4vw, 48px);
}

.top-page-v2__section-footer--news {
  display: flex;
  justify-content: flex-start;
}

/* ---------------------------------------------------------
   button
--------------------------------------------------------- */
.top-page-v2__btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 36px;
  min-height: 52px;
  font-size: .88rem;
  font-weight: 600;
  letter-spacing: .08em;
  color: #edf4ff;
  background: linear-gradient(
    135deg,
    rgba(74, 158, 255, .18) 0%,
    rgba(120, 80, 255, .14) 100%
  );
  border: 1px solid rgba(100, 170, 255, .30);
  border-radius: var(--tp-radius-btn);
  position: relative;
  overflow: hidden;
  box-shadow:
    0 2px 16px rgba(74, 158, 255, .10),
    inset 0 1px 0 rgba(255, 255, 255, .08);
  transition:
    background .30s ease,
    border-color .30s ease,
    transform .22s ease,
    box-shadow .30s ease,
    opacity .25s ease;
}

.top-page-v2__btn::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    135deg,
    rgba(74, 158, 255, .22) 0%,
    rgba(120, 80, 255, .18) 100%
  );
  opacity: 0;
  transition: opacity .30s ease;
}

.top-page-v2__btn:hover {
  opacity: 1;
  border-color: rgba(100, 170, 255, .55);
  transform: translateY(-2px);
  box-shadow:
    0 8px 28px rgba(74, 158, 255, .22),
    inset 0 1px 0 rgba(255, 255, 255, .12);
}

.top-page-v2__btn:hover::before {
  opacity: 1;
}

.top-page-v2__btn:active {
  transform: translateY(0);
}

.top-page-v2__btn > span {
  position: relative;
  z-index: 1;
}

.top-page-v2__btn-arrow {
  display: inline-flex;
  align-items: center;
  font-size: 1rem;
  transition: transform .22s ease;
}

.top-page-v2__btn:hover .top-page-v2__btn-arrow {
  transform: translateX(4px);
}

/* ---------------------------------------------------------
   News
--------------------------------------------------------- */
.top-page-v2__news-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  padding: 0;
  margin: 0 0 36px;
}

.top-page-v2__news-card {
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, .07);
  border-radius: var(--tp-radius-card);
  background: rgba(255, 255, 255, .02);
  transition:
    border-color .25s ease,
    background .25s ease,
    transform .22s ease;
}

.top-page-v2__news-card:hover {
  border-color: rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .04);
  transform: translateY(-2px);
}

.top-page-v2__news-link {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px 22px;
  height: 100%;
  color: inherit;
}

.top-page-v2__news-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.top-page-v2__news-date {
  font-size: .72rem;
  line-height: 1.5;
  letter-spacing: .06em;
  color: var(--tp-color-text-faint);
}

.top-page-v2__news-cat {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 2px 10px;
  font-size: .66rem;
  line-height: 1;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: var(--tp-color-accent-soft);
  border: 1px solid rgba(100, 180, 255, .25);
  border-radius: 100px;
}

.top-page-v2__news-title {
  font-size: .92rem;
  line-height: 1.65;
  color: rgba(237, 244, 255, .88);
  font-weight: 500;
  flex: 1;
  word-break: break-word;
}

.top-page-v2__news-empty {
  font-size: .9rem;
  color: rgba(237, 244, 255, .45);
  margin-bottom: 32px;
  padding: 40px 0;
}

/* ---------------------------------------------------------
   About
--------------------------------------------------------- */
.top-page-v2__about-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
  gap: clamp(24px, 4vw, 44px);
  align-items: stretch;
}

.top-page-v2__about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 3vw, 24px);
  min-width: 0;
}

.top-page-v2__about-card {
  padding: clamp(24px, 3vw, 40px);
  border: 1px solid rgba(255, 255, 255, .09);
  border-radius: var(--tp-radius-card);
  background: rgba(255, 255, 255, .03);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition:
    border-color .25s ease,
    background .25s ease;
}

.top-page-v2__about-card:hover {
  border-color: rgba(255, 255, 255, .16);
  background: rgba(255, 255, 255, .05);
}

.top-page-v2__about-title {
  font-size: clamp(1rem, 1.7vw, 1.3rem);
  font-weight: 700;
  line-height: 1.4;
  color: #edf4ff;
  margin-bottom: 14px;
}

.top-page-v2__about-body {
  font-size: .88rem;
  line-height: 1.9;
  color: rgba(237, 244, 255, .65);
}

.top-page-v2__about-visual {
  min-width: 0;
  border-radius: var(--tp-radius-card);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .10);
  background: rgba(255, 255, 255, .03);
  box-shadow: var(--tp-shadow-card);
}

.top-page-v2__about-visual img {
  width: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 4 / 3;
}

/* ---------------------------------------------------------
   Group
--------------------------------------------------------- */
.top-page-v2__group-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(32px, 5vw, 80px);
  align-items: center;
}

.top-page-v2__group-visual {
  min-width: 0;
  border-radius: var(--tp-radius-card);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .10);
  background: rgba(255, 255, 255, .03);
  box-shadow: var(--tp-shadow-card);
}

.top-page-v2__group-visual img {
  width: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 4 / 3;
}

.top-page-v2__group-body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.top-page-v2__group-title {
  font-size: clamp(1.1rem, 2vw, 1.5rem);
  font-weight: 700;
  line-height: 1.4;
  color: #edf4ff;
}

.top-page-v2__group-text {
  font-size: .92rem;
  line-height: 1.9;
  color: rgba(237, 244, 255, .68);
}

.top-page-v2__group-actions {
  margin-top: 8px;
}

/* ---------------------------------------------------------
   responsive
--------------------------------------------------------- */
@media (max-width: 1090px) {
  .top-page-v2__about-layout,
  .top-page-v2__group-grid,
  .top-page-v2__news-list {
    grid-template-columns: 1fr;
  }

  .top-page-v2__section-title-en {
    font-size: clamp(56px, 9vw, 96px);
  }

  .top-page-v2__about-visual img,
  .top-page-v2__group-visual img {
    aspect-ratio: 16 / 10;
  }

  .top-page-v2__mv-orb {
    right: 4%;
    width: clamp(260px, 40vw, 420px);
  }

  .top-page-v2__mv-title {
    font-size: clamp(2rem, 6.2vw, 4rem);
    line-height: 1.10;
    margin-bottom: 22px;
  }

  .top-page-v2__mv-line + .top-page-v2__mv-line {
    margin-top: .07em;
  }
}

@media (max-width: 710px) {
  .top-page-v2__inner {
    padding-inline: 18px;
  }

  .top-page-v2__mv {
    position: relative;
    overflow: hidden;
    min-height: auto;
    padding-block: 96px 64px;
  }

  .top-page-v2__mv-inner {
    flex-direction: column;
    align-items: flex-start;
    position: relative;
    z-index: 2;
  }

  .top-page-v2__mv-copy {
    max-width: 100%;
    position: relative;
    z-index: 2;
    padding-right: clamp(18px, 5vw, 32px);
  }

  .top-page-v2__mv-orb {
    position: absolute;
    top: 4vw;
    right: -14vw;
    width: clamp(190px, 56vw, 280px);
    height: auto;
    translate: 0 0;
    z-index: 1;
    display: block;
    visibility: visible;
    opacity: 1;
  }

  .top-page-v2__mv-title {
    font-size: clamp(1.58rem, 6.6vw, 2.7rem);
    line-height: 1.12;
    letter-spacing: -.01em;
    margin-bottom: 18px;
  }

  .top-page-v2__mv-line + .top-page-v2__mv-line {
    margin-top: .06em;
  }

  .top-page-v2__mv-lead {
    max-width: none;
    font-size: 14px;
    line-height: 1.8;
  }

  .top-page-v2__section {
    padding-block: 64px;
  }

  .top-page-v2__news-list {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .top-page-v2__news-link {
    gap: 8px;
    padding: 18px 16px;
  }

  .top-page-v2__section-title-ja {
    font-size: 14px;
  }

  .top-page-v2__section-title-en {
    font-size: clamp(48px, 13vw, 72px);
  }

  .top-page-v2__about-card {
    padding: 22px 18px;
  }

  .top-page-v2__about-visual img,
  .top-page-v2__group-visual img {
    aspect-ratio: 4 / 3;
  }

  .top-page-v2__btn {
    width: 100%;
    justify-content: center;
    padding-inline: 20px;
  }
}

@media (max-width: 480px) {
  .top-page-v2__mv-orb {
    top: 2vw;
    right: -18vw;
    width: clamp(170px, 58vw, 250px);
  }
}

@media (max-width: 390px) {
  .top-page-v2__mv-title {
    font-size: clamp(1.34rem, 5.8vw, 1.95rem);
    line-height: 1.14;
    letter-spacing: -.008em;
    margin-bottom: 16px;
  }

  .top-page-v2__mv-line + .top-page-v2__mv-line {
    margin-top: .05em;
  }
}

/* ---------------------------------------------------------
   reduced motion
--------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .top-page-v2 *,
  .top-page-v2 *::before,
  .top-page-v2 *::after,
  .site-bg-ambient,
  .site-bg-glow,
  .site-bg-stars,
  .site-bg-stars-2,
  .site-bg-grid,
  .site-bg-bridge {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }

  .top-page-v2__mv-orb,
  .top-page-v2__mv-orb-img {
    transition: none !important;
  }
}

/* =========================================================
   ADDITIONAL PATCH
   - ABOUT 3 cards + right image height fix
   - TECHNOLOGY section
   - longer body text readability
========================================================= */

/* -----------------------------
   SECTION TEXT READABILITY
------------------------------ */
.top-page-v2__section-text,
.top-page-v2__about-body,
.top-page-v2__technology-body,
.top-page-v2__group-text,
.top-page-v2__mv-lead {
  line-height: 1.9;
}

.top-page-v2__section-text,
.top-page-v2__group-text,
.top-page-v2__mv-lead {
  max-width: 860px;
}

/* -----------------------------
   ABOUT LAYOUT
------------------------------ */
.top-page-v2__about-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
  gap: clamp(20px, 3vw, 32px);
  align-items: stretch;
}

.top-page-v2__about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 2vw, 22px);
  height: 100%;
}

.top-page-v2__about-card {
  height: auto;
}

.top-page-v2__about-visual {
  display: flex;
  height: 100%;
  min-height: 100%;
}

.top-page-v2__about-visual-inner {
  display: flex;
  width: 100%;
  height: 100%;
}

.top-page-v2__about-image-wrap {
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: var(--tp-radius-md, 22px);
  background:
    radial-gradient(circle at 50% 35%, rgba(52, 129, 255, 0.18), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.22);
}

.top-page-v2__about-image {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
  object-position: center center;
}

/* -----------------------------
   TECHNOLOGY
------------------------------ */
.top-page-v2__section--technology .top-page-v2__section-heading {
  margin-bottom: clamp(22px, 3vw, 30px);
}

.top-page-v2__technology-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(16px, 2.4vw, 24px);
}

.top-page-v2__technology-card {
  min-width: 0;
  height: 100%;
  padding: clamp(20px, 2.8vw, 30px);
  border-radius: var(--tp-radius-md, 22px);
  border: 1px solid rgba(255,255,255,0.08);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.045) 0%, rgba(255,255,255,0.025) 100%);
  box-shadow: 0 14px 38px rgba(3, 8, 18, 0.26);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: transform .24s ease, border-color .24s ease, background .24s ease, box-shadow .24s ease;
}

.top-page-v2__technology-card:hover {
  transform: translateY(-2px);
  border-color: rgba(142, 208, 255, 0.22);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.03) 100%);
  box-shadow: 0 18px 44px rgba(3, 8, 18, 0.34);
}

.top-page-v2__technology-title {
  margin: 0 0 12px;
  font-size: clamp(1rem, 1.45vw, 1.16rem);
  font-weight: 700;
  line-height: 1.45;
  color: #edf4ff;
}

.top-page-v2__technology-body {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(237, 244, 255, 0.72);
}

/* -----------------------------
   RESPONSIVE
------------------------------ */
@media (max-width: 1090px) {
  .top-page-v2__about-layout {
    grid-template-columns: 1fr;
  }

  .top-page-v2__about-visual {
    min-height: 360px;
  }

  .top-page-v2__about-image {
    min-height: 360px;
  }

  .top-page-v2__technology-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 710px) {
  .top-page-v2__section-text,
  .top-page-v2__about-body,
  .top-page-v2__technology-body,
  .top-page-v2__group-text,
  .top-page-v2__mv-lead {
    line-height: 1.82;
  }

  .top-page-v2__about-layout {
    gap: 16px;
  }

  .top-page-v2__about-grid {
    gap: 12px;
  }

  .top-page-v2__about-visual {
    min-height: 260px;
  }

  .top-page-v2__about-image {
    min-height: 260px;
  }

  .top-page-v2__technology-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .top-page-v2__technology-card {
    padding: 18px 16px;
  }

  .top-page-v2__technology-title {
    margin-bottom: 10px;
    font-size: 1rem;
  }

  .top-page-v2__technology-body {
    font-size: 0.86rem;
  }
}


@media (max-width: 710px) {
  .top-page-v2__mv-orb {
    top:-15vw;
    right: -25vw;
    width: clamp(190px, 56vw, 280px);
  }
}

@media (max-width: 480px) {
  .top-page-v2__mv-orb {
    top: -20vw;
    right: -22vw;
    width: clamp(170px, 58vw, 250px);
  }
}
