@charset "UTF-8";

:root {
  --color-bg: #f5f9ff;
  --color-surface: #ffffff;
  --color-primary: #1267e5;
  --color-primary-dark: #081f49;
  --color-accent: #58d8ff;
  --color-violet: #625ee8;
  --color-text: #132238;
  --color-muted: #64748b;
  --color-border: #dbeafe;
  --color-soft: #eaf6ff;
  --shell: 1100px;
  --shadow: 0 24px 60px rgba(26, 77, 135, 0.11);
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--color-text);
  background: var(--color-bg);
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Yu Gothic UI", Meiryo, sans-serif;
  font-size: 16px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
button, a { font: inherit; }
button { color: inherit; }
a { color: inherit; }
svg { display: block; fill: none; stroke: currentColor; stroke-linecap: round; stroke-linejoin: round; stroke-width: 1.8; }
[hidden] { display: none !important; }

.viture-app {
  min-width: 0;
  overflow: hidden;
  background:
    linear-gradient(rgba(18, 103, 229, 0.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(18, 103, 229, 0.032) 1px, transparent 1px),
    var(--color-bg);
  background-size: 48px 48px;
}
.shell { width: min(calc(100% - 40px), var(--shell)); margin-inline: auto; }
.shell--narrow { max-width: 820px; }

.promotion-band {
  position: absolute;
  z-index: 5;
  top: 0;
  left: 0;
  width: 100%;
  margin: 0;
  padding: 9px 20px;
  border-bottom: 1px solid rgba(255,255,255,.16);
  color: rgba(255,255,255,.94);
  background: #10386d;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .04em;
  line-height: 1.45;
  text-align: center;
}

.hero {
  position: relative;
  display: grid;
  min-height: min(900px, 100dvh);
  padding: 94px 0 70px;
  align-items: center;
  isolation: isolate;
}
.hero::after {
  position: absolute;
  z-index: -2;
  right: -220px;
  bottom: -310px;
  width: 680px;
  height: 680px;
  border: 1px solid rgba(18,103,229,.11);
  border-radius: 50%;
  content: "";
}
.hero__orb { position: absolute; z-index: -3; border-radius: 50%; pointer-events: none; }
.hero__orb--one { top: -140px; right: 0; width: 580px; height: 580px; background: radial-gradient(circle, rgba(88,216,255,.23), rgba(88,216,255,0) 69%); }
.hero__orb--two { bottom: -20px; left: -170px; width: 450px; height: 450px; background: radial-gradient(circle, rgba(18,103,229,.1), rgba(18,103,229,0) 70%); }
.hero__grid { display: grid; grid-template-columns: minmax(0, 1.04fr) minmax(410px, .96fr); gap: clamp(34px, 6vw, 80px); align-items: center; }
.hero__content { position: relative; z-index: 2; min-width: 0; }
.eyebrow, .section-kicker, .question-panel__kicker {
  margin: 0;
  color: var(--color-primary);
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .16em;
  line-height: 1.4;
}
.eyebrow { display: inline-flex; padding: 8px 13px; border: 1px solid rgba(18,103,229,.22); border-radius: 999px; background: rgba(255,255,255,.7); align-items: center; gap: 8px; letter-spacing: .02em; }
.eyebrow span { width: 7px; height: 7px; border-radius: 50%; background: var(--color-primary); box-shadow: 0 0 0 5px rgba(18,103,229,.1); }
.hero h1 { margin: 25px 0 0; color: var(--color-primary-dark); font-size: clamp(3rem, 5vw, 4.8rem); font-weight: 800; letter-spacing: -.045em; line-height: 1.08; }
.hero h1 span { display: block; white-space: nowrap; }
.hero__accent { display: inline-block; margin: 22px 0 0; padding-bottom: 6px; border-bottom: 3px solid var(--color-accent); color: var(--color-primary); font-size: clamp(1.22rem, 2.2vw, 1.75rem); font-weight: 800; letter-spacing: -.025em; }
.hero__lead { max-width: 640px; margin: 27px 0 0; color: #233653; font-size: 1.04rem; font-weight: 650; line-height: 1.85; }
.hero__detail { max-width: 620px; margin: 13px 0 0; color: var(--color-muted); font-size: .92rem; }
.hero__actions { display: flex; margin-top: 33px; align-items: center; gap: 23px; flex-wrap: wrap; }
.button { display: inline-flex; min-height: 54px; padding: 14px 24px; border: 0; border-radius: 14px; cursor: pointer; align-items: center; justify-content: center; gap: 11px; font-weight: 800; text-decoration: none; transition: transform .28s var(--ease), box-shadow .28s var(--ease), background .28s var(--ease); }
.button svg { width: 19px; height: 19px; }
.button:hover { transform: translateY(-2px); }
.button:active { transform: translateY(1px) scale(.985); }
.button--primary { color: #fff; background: var(--color-primary); box-shadow: 0 14px 30px rgba(18,103,229,.22); }
.button--primary:hover { background: #0c5bd2; box-shadow: 0 18px 36px rgba(18,103,229,.25); }
.button--large { min-height: 60px; min-width: 205px; }
.button--ghost { border: 1px solid rgba(18,103,229,.22); color: var(--color-primary); background: rgba(255,255,255,.85); }
.privacy-note { display: inline-flex; margin: 0; color: var(--color-muted); font-size: .76rem; align-items: center; gap: 7px; }
.privacy-note svg { width: 17px; height: 17px; }

.xr-scene { position: relative; min-height: 730px; isolation: isolate; perspective: 1100px; }
.xr-scene::before { position: absolute; z-index: -3; inset: 35px -10px 25px 5px; border: 1px solid rgba(18,103,229,.13); border-radius: 48% 52% 45% 55% / 44% 45% 55% 56%; background: radial-gradient(circle at 62% 28%, rgba(88,216,255,.31), rgba(234,246,255,.76) 44%, rgba(255,255,255,.44) 75%); box-shadow: inset 0 1px 0 rgba(255,255,255,.92), 0 26px 66px rgba(38,94,150,.1); content: ""; }
.virtual-screen { position: absolute; top: 88px; left: 50%; width: 350px; height: 220px; padding: 18px; border: 1px solid rgba(255,255,255,.58); border-radius: 22px; background: linear-gradient(145deg, rgba(8,31,73,.96), rgba(18,103,229,.8)); box-shadow: inset 0 1px 0 rgba(255,255,255,.24), 0 28px 48px rgba(9,39,84,.23); transform: translateX(-50%) rotateX(2deg); overflow: hidden; }
.screen-top { display: flex; color: rgba(255,255,255,.64); font-size: .56rem; letter-spacing: .15em; align-items: center; justify-content: space-between; }
.screen-top i { width: 6px; height: 6px; border-radius: 50%; background: var(--color-accent); box-shadow: 0 0 0 4px rgba(88,216,255,.1); }
.screen-grid { position: absolute; inset: 52px 35px 44px; display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; transform: perspective(420px) rotateX(56deg); transform-origin: center bottom; }
.screen-grid b { border: 1px solid rgba(88,216,255,.27); border-radius: 7px; background: linear-gradient(160deg, rgba(88,216,255,.24), rgba(255,255,255,.04)); }
.screen-horizon { position: absolute; right: 0; bottom: 30px; left: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(88,216,255,.9), transparent); box-shadow: 0 0 24px rgba(88,216,255,.5); }
.xr-product { position: absolute; z-index: 3; top: 154px; left: 50%; width: min(560px, 118%); height: auto; transform: translate3d(-50%,0,0) rotate(-5deg); filter: drop-shadow(0 28px 22px rgba(11,40,84,.25)); animation: xrProductFloat 5.6s ease-in-out -1.2s infinite; will-change: transform; }
@keyframes xrProductFloat {
  0%, 100% { transform: translate3d(-50%,0,0) rotate(-5deg); }
  48% { transform: translate3d(-50%,-16px,0) rotate(-3.8deg); }
  72% { transform: translate3d(-50%,-9px,0) rotate(-4.4deg); }
}
.scene-card, .model-card, .accessory-card { position: absolute; z-index: 4; border: 1px solid rgba(255,255,255,.8); background: rgba(255,255,255,.84); box-shadow: inset 0 1px 0 #fff, 0 15px 35px rgba(40,84,133,.12); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
.scene-card small, .model-card small, .accessory-card small { display: block; color: var(--color-primary-dark); font-size: .55rem; font-weight: 800; letter-spacing: .16em; }
.scene-card--game { top: 12px; left: -24px; width: 130px; padding: 15px; border-radius: 18px; }
.scene-card--game strong { display: block; margin-top: 7px; color: var(--color-primary); font-size: 1.6rem; line-height: 1; }
.scene-card--game strong span { margin-left: 3px; font-size: .58rem; }
.scene-card--game i { display: block; width: 64px; height: 5px; margin-top: 12px; border-radius: 99px; background: linear-gradient(90deg,var(--color-accent) 65%,var(--color-border) 65%); }
.scene-card--movie { top: 28px; right: -18px; width: 126px; padding: 15px; border-radius: 18px; }
.play { display: grid; width: 32px; height: 32px; margin-top: 10px; border-radius: 50%; color: #fff; background: var(--color-primary); place-items: center; }
.play i { width: 0; height: 0; margin-left: 2px; border-top: 5px solid transparent; border-bottom: 5px solid transparent; border-left: 8px solid currentColor; }
.scene-card--movie b { position: absolute; right: 15px; bottom: 18px; width: 43px; height: 4px; border-radius: 9px; background: var(--color-border); }
.scene-card--work { top: 575px; left: -18px; width: 142px; padding: 15px; border-radius: 18px; }
.window-lines { display: grid; margin-top: 10px; gap: 6px; }
.window-lines i { height: 5px; border-radius: 99px; background: #d7e8fb; }
.window-lines i:nth-child(2) { width: 73%; background: #bceaff; }
.window-lines i:nth-child(3) { width: 52%; }
.model-card { top: 575px; right: -18px; width: 164px; padding: 15px 17px; border-radius: 18px; }
.model-card strong { display: block; margin-top: 5px; color: var(--color-primary); font-size: .78rem; }
.accessory-card { top: 650px; right: 30px; bottom: auto; width: 202px; padding: 13px 15px; border-radius: 17px; }
.accessory-card span { display: inline-block; margin: 8px 5px 0 0; padding: 4px 8px; border-radius: 99px; color: #244468; background: var(--color-soft); font-size: .62rem; font-weight: 750; }
.device-rail { position: absolute; z-index: 2; top: 668px; bottom: auto; left: 15px; display: flex; padding: 10px 14px; border: 1px solid rgba(18,103,229,.12); border-radius: 99px; color: #496987; background: rgba(255,255,255,.68); font-size: .49rem; font-weight: 800; letter-spacing: .08em; align-items: center; gap: 8px; }
.device-rail i { width: 13px; height: 1px; background: #9bc6f1; }

.how { position: relative; padding: 112px 0; background: rgba(255,255,255,.68); }
.how__grid { display: grid; grid-template-columns: minmax(0,.95fr) minmax(420px,1.05fr); gap: clamp(45px,6vw,72px); align-items: start; }
.hero h1, .how h2, .model-comparison h2, .accessory-result h2, .result-copy h2, .model-result h3, .insight-block__heading h3 {
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
  font-feature-settings: "palt" 1;
  line-break: strict;
  text-wrap: balance;
}
.how h2, .model-comparison h2, .accessory-result h2 { margin: 15px 0 0; color: var(--color-primary-dark); font-size: clamp(1.9rem,3.45vw,2.9rem); font-weight: 750; letter-spacing: -.035em; line-height: 1.22; }
.how h2 { font-size: clamp(1.9rem,3.25vw,2.75rem); }
.how h2 span { display: block; white-space: nowrap; }
.steps { border-top: 1px solid #bed7f2; }
.step { display: grid; grid-template-columns: 42px 1fr; padding: 24px 0; border-bottom: 1px solid #bed7f2; gap: 17px; }
.step > span { padding-top: 3px; color: var(--color-primary); font-size: .7rem; font-weight: 800; letter-spacing: .08em; }
.step h3 { margin: 0; color: var(--color-primary-dark); font-size: 1rem; }
.step p { margin: 6px 0 0; color: var(--color-muted); font-size: .85rem; }
.how__action { margin-top: 42px; text-align: center; }

.quiz { min-height: 100dvh; padding: 90px 0; background: rgba(245,249,255,.96); }
.quiz-progress { margin-bottom: 27px; }
.quiz-progress__labels { display: flex; margin-bottom: 10px; color: var(--color-muted); font-size: .76rem; font-weight: 750; justify-content: space-between; }
.progress-track { height: 7px; border-radius: 99px; background: #dbe9f8; overflow: hidden; }
.progress-track span { display: block; width: 11%; height: 100%; border-radius: inherit; background: linear-gradient(90deg,var(--color-primary),var(--color-accent)); transition: width .44s var(--ease); }
.question-panel { min-height: 580px; padding: clamp(28px,5vw,56px); border: 1px solid rgba(18,103,229,.12); border-radius: 28px; background: rgba(255,255,255,.9); box-shadow: var(--shadow); transition: opacity .22s ease, transform .22s ease; }
.question-panel.is-entering { animation: panelIn .34s var(--ease) both; }
.question-panel.is-leaving { opacity: 0; transform: translateY(8px); }
@keyframes panelIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
.question-panel h2 { max-width: 690px; margin: 18px 0 30px; color: var(--color-primary-dark); font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif; font-size: clamp(1.55rem,3vw,2.3rem); font-weight: 750; letter-spacing: -.025em; line-height: 1.48; line-break: strict; text-wrap: balance; }
.answer-list { display: grid; gap: 11px; }
.answer-button { position: relative; width: 100%; min-height: 58px; padding: 15px 52px 15px 18px; border: 1px solid #cfdef0; border-radius: 14px; color: #1e3452; background: #fff; cursor: pointer; font-size: .96rem; font-weight: 700; line-height: 1.55; text-align: left; transition: border-color .2s ease, background .2s ease, color .2s ease, transform .2s var(--ease), box-shadow .2s ease; }
.answer-button::after { position: absolute; top: 50%; right: 19px; width: 19px; height: 19px; border: 2px solid #b8cce2; border-radius: 50%; content: ""; transform: translateY(-50%); }
.answer-button:hover { border-color: #7db2ed; background: #f5faff; transform: translateX(3px); }
.answer-button:active { transform: translateX(3px) scale(.994); }
.answer-button.is-selected { border-color: var(--color-primary); color: #0d4fae; background: #edf6ff; box-shadow: 0 0 0 3px rgba(18,103,229,.08); }
.answer-button.is-selected::after { border: 6px solid var(--color-primary); }
.back-button { display: inline-flex; min-height: 44px; margin-top: 25px; padding: 8px 4px; border: 0; color: var(--color-muted); background: transparent; cursor: pointer; align-items: center; gap: 8px; font-size: .8rem; font-weight: 700; }
.back-button svg { width: 17px; height: 17px; }
.back-button:disabled { opacity: .36; cursor: not-allowed; }

.results { padding: 110px 0 70px; background: rgba(255,255,255,.42); }
.result-hero { display: grid; grid-template-columns: minmax(300px,.8fr) minmax(0,1.2fr); gap: clamp(45px,8vw,100px); align-items: center; }
.score-wrap { position: relative; display: grid; min-height: 380px; place-items: center; }
.score-wrap::before, .score-wrap::after { position: absolute; border: 1px solid rgba(18,103,229,.11); border-radius: 50%; content: ""; }
.score-wrap::before { width: 340px; height: 340px; }
.score-wrap::after { width: 390px; height: 390px; border-style: dashed; }
.score-ring { width: 300px; height: 300px; transform: rotate(-90deg); filter: drop-shadow(0 14px 24px rgba(18,103,229,.13)); }
.score-ring circle { fill: none; stroke-width: 13; }
.score-ring__track { stroke: #dfebf7; }
.score-ring__value { stroke: url(#none); stroke: var(--color-primary); stroke-dasharray: 603.19; stroke-dashoffset: 603.19; transition: stroke .3s ease; }
.score-center { position: absolute; display: grid; text-align: center; place-items: center; }
.score-center > span { color: var(--color-muted); font-size: .75rem; font-weight: 800; letter-spacing: .08em; }
.score-center strong { display: flex; margin-top: 3px; color: var(--color-primary-dark); align-items: baseline; line-height: 1; }
.score-center b { font-size: 4.8rem; letter-spacing: -.07em; }
.score-center small { margin-left: 3px; color: var(--color-primary); font-size: 1.3rem; }
.score-center em { margin-top: 10px; color: #8ba0b8; font-size: .59rem; font-style: normal; font-weight: 800; letter-spacing: .15em; }
.result-copy h2 { margin: 12px 0 0; color: var(--color-primary-dark); font-size: clamp(2rem,3.7vw,3.2rem); font-weight: 750; letter-spacing: -.035em; line-height: 1.2; }
.result-copy__title { margin: 20px 0 0; color: var(--color-primary); font-size: 1.23rem; font-weight: 800; }
.result-copy__description { margin: 10px 0 0; color: #536983; font-size: .94rem; line-height: 1.85; }
.model-result { margin-top: 26px; padding: 25px 27px; border: 1px solid rgba(18,103,229,.13); border-radius: 20px; background: rgba(255,255,255,.83); box-shadow: inset 4px 0 0 var(--model-accent,var(--color-primary)), 0 17px 36px rgba(34,79,129,.08); }
.model-badge { display: inline-block; margin: 0; padding: 5px 10px; border-radius: 99px; color: #fff; background: var(--model-accent,var(--color-primary)); font-size: .58rem; font-weight: 800; letter-spacing: .12em; }
.model-result h3 { margin: 13px 0 0; color: var(--color-primary-dark); font-size: 1.25rem; font-weight: 750; letter-spacing: -.02em; line-height: 1.55; }
.model-result > p:not(.model-badge) { margin: 8px 0 0; color: #586d85; font-size: .86rem; }
.model-result ul { display: grid; margin: 17px 0 0; padding: 0; list-style: none; gap: 7px; }
.model-result li { position: relative; padding-left: 19px; color: #273e5a; font-size: .82rem; }
.model-result li::before { position: absolute; top: .68em; left: 2px; width: 6px; height: 6px; border-radius: 50%; background: var(--model-accent,var(--color-primary)); content: ""; }
.result-buy-links { display: grid; margin-top: 22px; padding-top: 20px; border-top: 1px solid #dce9f6; gap: 16px; }
.result-buy-links[hidden] { display: none; }
.result-buy-group { min-width: 0; }
.result-buy-group__name { margin: 0 0 9px; color: #35516f; font-size: .74rem; font-weight: 800; letter-spacing: .01em; }
.result-buy-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.result-buy-button { display: flex; min-height: 46px; padding: 10px 13px; border: 1px solid var(--model-accent,var(--color-primary)); border-radius: 12px; align-items: center; justify-content: center; text-align: center; text-decoration: none; font-size: .78rem; font-weight: 800; line-height: 1.4; transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease; }
.result-buy-button--rakuten { color: #fff; border-color: #a90000; background: #bf0000; box-shadow: 0 8px 18px rgba(148,0,0,.18); }
.result-buy-button--amazon { color: #18202a; border-color: #e68a00; background: #ff9900; box-shadow: 0 8px 18px rgba(180,103,0,.18); }
.result-buy-button:hover { transform: translateY(-2px); }
.result-buy-button:active { transform: translateY(1px) scale(.985); }
.result-buy-button:focus-visible { outline: 3px solid rgba(18,103,229,.25); outline-offset: 3px; }
.model-result[data-model="beast"] { --model-accent: #124f9c; }
.model-result[data-model="luma_ultra"] { --model-accent: #565fd2; }
.model-result[data-model="luma"] { --model-accent: #258fc9; }
.model-result[data-model="compare_upper"] { --model-accent: #366fd0; }
.model-result[data-model="no_device"] { --model-accent: #7b8a9d; }
.low-score-guide { display: grid; grid-template-columns: 28px 1fr; margin-top: 16px; padding: 15px 17px; border-radius: 15px; background: #eff4f8; gap: 10px; }
.low-score-guide svg { width: 22px; color: #71839a; }
.low-score-guide p { margin: 0; color: #586d82; font-size: .78rem; }

.accessory-result { display: grid; grid-template-columns: minmax(0,.85fr) minmax(0,1.15fr); margin-top: 100px; padding: clamp(28px,5vw,52px); border: 1px solid rgba(18,103,229,.13); border-radius: 28px; background: linear-gradient(140deg,rgba(255,255,255,.9),rgba(234,246,255,.78)); box-shadow: 0 20px 52px rgba(34,79,129,.08); gap: clamp(35px,7vw,80px); align-items: center; }
.accessory-result h2 { font-size: clamp(1.75rem,3vw,2.55rem); }
.accessory-result__heading > p:last-child { margin: 14px 0 0; color: var(--color-muted); font-size: .86rem; }
.accessory-list { display: grid; margin: 0; padding: 0; list-style: none; gap: 10px; }
.accessory-list li { position: relative; display: grid; grid-template-columns: minmax(0,1fr) auto; min-height: 55px; padding: 12px 12px 12px 47px; border: 1px solid #d6e7f8; border-radius: 14px; color: #29425f; background: rgba(255,255,255,.83); font-size: .86rem; font-weight: 700; align-items: center; gap: 10px; }
.accessory-list li::before { position: absolute; top: 50%; left: 18px; width: 15px; height: 10px; border-bottom: 2px solid var(--color-primary); border-left: 2px solid var(--color-primary); content: ""; transform: translateY(-68%) rotate(-45deg); }
.accessory-list__label { min-width: 0; }
.accessory-actions { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); width: 146px; gap: 6px; }
.accessory-link { display: flex; min-height: 34px; padding: 7px 8px; border: 1px solid transparent; border-radius: 9px; align-items: center; justify-content: center; text-align: center; text-decoration: none; font-size: .62rem; font-weight: 800; line-height: 1.3; transition: transform .18s ease, box-shadow .18s ease; }
.accessory-link--rakuten { color: #fff; border-color: #a90000; background: #bf0000; }
.accessory-link--amazon { color: #18202a; border-color: #e68a00; background: #ff9900; }
.accessory-link:hover { transform: translateY(-1px); box-shadow: 0 7px 14px rgba(180,103,0,.16); }
.accessory-link:active { transform: translateY(1px) scale(.985); }

.insight-grid { display: grid; grid-template-columns: 1fr 1fr; margin-top: 68px; gap: 20px; }
.insight-block { padding: 29px; border: 1px solid rgba(18,103,229,.12); border-radius: 22px; background: rgba(255,255,255,.84); }
.insight-block--caution { border-color: #e4e9ef; background: rgba(249,251,253,.9); }
.insight-block__heading { display: flex; align-items: center; gap: 14px; }
.insight-icon { display: grid; width: 40px; height: 40px; flex: 0 0 auto; border-radius: 12px; place-items: center; }
.insight-icon svg { width: 21px; height: 21px; }
.insight-icon--positive { color: var(--color-primary); background: var(--color-soft); }
.insight-icon--caution { color: #64748b; background: #edf1f5; }
.insight-block__heading p { margin: 0; color: var(--color-primary); font-size: .58rem; font-weight: 800; letter-spacing: .16em; }
.insight-block__heading h3 { margin: 3px 0 0; color: var(--color-primary-dark); font-size: 1.03rem; }
.insight-list { display: grid; margin: 22px 0 0; padding: 0; list-style: none; gap: 0; }
.insight-list li { position: relative; padding: 12px 4px 12px 22px; border-top: 1px solid #e1ebf5; color: #405773; font-size: .82rem; }
.insight-list li::before { position: absolute; top: 1.32rem; left: 4px; width: 6px; height: 6px; border-radius: 50%; background: var(--color-primary); content: ""; }
.insight-block--caution .insight-list li::before { background: #7d8b9c; }

.model-comparison { margin-top: 110px; }
.model-comparison__heading { max-width: 700px; }
.model-comparison__heading > p:last-child { margin: 14px 0 0; color: var(--color-muted); font-size: .9rem; }
.model-table-wrap { margin-top: 36px; border-top: 1px solid #abccee; overflow: hidden; }
table { width: 100%; border-collapse: collapse; table-layout: fixed; }
th, td { padding: 19px 15px; border-bottom: 1px solid #c9def2; font-size: .78rem; line-height: 1.65; text-align: left; vertical-align: top; }
thead th { color: #70839a; font-size: .63rem; font-weight: 800; letter-spacing: .08em; }
tbody th { width: 20%; color: var(--color-primary-dark); font-size: .84rem; }
tbody tr { transition: background .24s ease; }
tbody tr.is-recommended { background: #edf7ff; box-shadow: inset 4px 0 0 var(--color-primary); }

.disclaimer { margin-top: 84px; padding: 25px 27px; border: 1px solid #d8e4ef; border-radius: 18px; color: #687b90; background: rgba(247,250,252,.9); }
.disclaimer h2 { margin: 0; color: #50657b; font-size: .82rem; }
.disclaimer p { margin: 8px 0 0; font-size: .7rem; }
.restart-area { display: flex; padding: 45px 0 10px; justify-content: center; }

:focus-visible { outline: 3px solid rgba(18,103,229,.45); outline-offset: 3px; }
#question-title:focus-visible, #result-heading:focus-visible { outline: none; }

@media (max-width: 980px) {
  .hero { min-height: auto; }
  .hero__grid { grid-template-columns: minmax(0,1fr) minmax(350px,.8fr); gap: 20px; }
  .xr-scene { min-height: 730px; transform: scale(.91); transform-origin: center; }
  .how__grid { gap: 45px; }
  .result-hero { gap: 45px; }
}

@media (max-width: 767px) {
  .shell { width: min(calc(100% - 32px), var(--shell)); }
  .hero { padding: 78px 0 54px; }
  .hero__grid, .how__grid, .result-hero, .accessory-result, .insight-grid { grid-template-columns: 1fr; }
  .hero h1 { margin-top: 21px; font-size: clamp(2.35rem,12vw,3.45rem); line-height: 1.08; }
  .hero__accent { margin-top: 17px; font-size: 1.15rem; }
  .hero__lead { margin-top: 22px; font-size: .95rem; }
  .hero__detail { font-size: .82rem; }
  .hero__actions { display: grid; margin-top: 27px; gap: 14px; }
  .hero__actions .button { width: 100%; }
  .privacy-note { justify-content: center; }
  .xr-scene { min-height: 690px; margin-top: 20px; transform: none; }
  .xr-scene::before { inset: 24px -12px 8px; }
  .virtual-screen { top: 66px; width: min(82vw,330px); height: 198px; }
  .xr-product { top: 145px; width: min(465px, 122%); }
  .scene-card--game { top: 33px; left: -3px; transform: scale(.88); transform-origin: left top; }
  .scene-card--movie { top: 34px; right: -2px; transform: scale(.88); transform-origin: right top; }
  .scene-card--work { top: 505px; left: 0; transform: scale(.88); transform-origin: left top; }
  .model-card { top: 505px; right: 0; transform: scale(.88); transform-origin: right top; }
  .accessory-card { top: 600px; right: 0; bottom: auto; transform: scale(.9); transform-origin: right top; }
  .device-rail { top: 610px; bottom: auto; left: 0; transform: scale(.86); transform-origin: left top; }
  .how { padding: 82px 0; }
  .how h2, .model-comparison h2 { font-size: clamp(2rem,10vw,2.65rem); line-height: 1.25; }
  .steps { margin-top: 36px; }
  .how__action { margin-top: 32px; }
  .how__action .button { width: 100%; }
  .quiz { padding: 64px 0; }
  .question-panel { min-height: 540px; padding: 27px 18px; border-radius: 22px; }
  .question-panel h2 { margin: 15px 0 24px; font-size: clamp(1.45rem,6.5vw,2rem); }
  .answer-button { min-height: 60px; padding: 14px 46px 14px 15px; font-size: .9rem; }
  .results { padding: 80px 0 55px; }
  .score-wrap { min-height: 340px; }
  .score-ring { width: 275px; height: 275px; }
  .score-wrap::before { width: 305px; height: 305px; }
  .score-wrap::after { width: 335px; height: 335px; }
  .score-center b { font-size: 4.35rem; }
  .result-copy { margin-top: 15px; }
  .result-copy h2 { font-size: clamp(2rem,10vw,2.9rem); }
  .model-result { padding: 23px 20px; }
  .result-buy-actions { grid-template-columns: 1fr; }
  .accessory-result { margin-top: 72px; padding: 27px 20px; gap: 28px; }
  .accessory-result h2 { font-size: 1.75rem; }
  .accessory-list li { grid-template-columns: 1fr; }
  .accessory-actions { width: 100%; }
  .insight-grid { margin-top: 45px; }
  .insight-block { padding: 23px 19px; }
  .model-comparison { margin-top: 80px; }
  .model-table-wrap { border-top: 0; overflow: visible; }
  table, thead, tbody, tr, th, td { display: block; }
  thead { display: none; }
  tbody { display: grid; gap: 13px; }
  tbody tr { padding: 20px; border: 1px solid #d2e4f5; border-radius: 17px; background: rgba(255,255,255,.84); }
  tbody tr.is-recommended { border-color: #85b8ed; box-shadow: inset 4px 0 0 var(--color-primary); }
  tbody th, tbody td { width: auto; padding: 0; border: 0; }
  tbody th { margin-bottom: 13px; font-size: .95rem; }
  tbody td { position: relative; display: grid; grid-template-columns: 105px 1fr; padding: 8px 0; border-top: 1px solid #e3edf6; gap: 9px; font-size: .75rem; }
  tbody td::before { color: #73869b; content: attr(data-label); font-size: .65rem; font-weight: 800; }
  .disclaimer { margin-top: 64px; padding: 21px 18px; }
}

@media (max-width: 380px) {
  .shell { width: min(calc(100% - 24px), var(--shell)); }
  .promotion-band { padding-inline: 12px; font-size: .67rem; }
  .hero { padding-top: 74px; }
  .hero h1 { font-size: 2.35rem; }
  .hero__accent { font-size: 1.03rem; }
  .xr-scene { min-height: 680px; }
  .virtual-screen { width: 290px; }
  .xr-product { top: 152px; width: 405px; }
  .scene-card--game, .scene-card--movie { transform: scale(.78); }
  .scene-card--work, .model-card { transform: scale(.8); }
  .accessory-card { transform: scale(.82); }
  .score-wrap::after { width: 315px; height: 315px; }
  .score-wrap::before { width: 290px; height: 290px; }
  .score-ring { width: 260px; height: 260px; }
  .answer-button { font-size: .86rem; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
  .xr-product { animation: none !important; transform: translate3d(-50%,0,0) rotate(-5deg); }
}
