:root{font-family:Noto Sans SC,PingFang SC,Hiragino Sans GB,sans-serif;color:#4b2ca3;background:radial-gradient(circle at top left,rgba(255,255,255,.7),transparent 24%),radial-gradient(circle at right center,rgba(205,186,255,.35),transparent 20%),linear-gradient(180deg,#f8f4ff,#f4eefe);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--surface: rgba(255, 255, 255, .92);--surface-soft: rgba(244, 237, 255, .8);--line: rgba(124, 88, 233, .16);--line-strong: rgba(124, 88, 233, .45);--text-main: #4a2e96;--text-soft: #6f6496;--text-muted: #8f86af;--accent: #7c58e9;--accent-deep: #5a32b4;--accent-soft: #ece3ff;--success: #18a36f;--shadow: 0 22px 48px rgba(105, 71, 196, .12);--scale-ui: .72}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{min-height:100vh;color:var(--text-main)}button,input,textarea,select{font:inherit}button{cursor:pointer}.page-shell{position:relative;min-height:100vh;overflow:hidden;padding:24px 16px 90px}.page-shell__inner{position:relative;z-index:1;width:min(100%,1120px);margin:0 auto}.page-shell--home .page-shell__inner,.page-shell--quiz .page-shell__inner{width:min(100%,676px)}.page-shell__content{animation:fade-up .65s ease both}.page-shell__glow{position:absolute;inset:auto;border-radius:999px;filter:blur(50px);opacity:.5}.page-shell__glow--one{top:-80px;left:-60px;width:240px;height:240px;background:#ffffffe6}.page-shell__glow--two{right:-20px;bottom:100px;width:180px;height:180px;background:#aa91ff47}.hero{display:grid;justify-items:center;gap:7px;margin-bottom:20px;text-align:center;animation:fade-up .65s ease both}.hero__eyebrow{margin:0;color:#7d63e7;font-size:.63rem;letter-spacing:.38em}.hero__title{margin:0;font-size:clamp(1.8rem,4.2vw,3.25rem);line-height:1.05}.hero__accent{width:58px;height:4px;border-radius:999px;background:linear-gradient(90deg,#7c58e933,#7c58e9,#7c58e933)}.hero__subtitle{margin:0;max-width:36rem;color:var(--text-soft);font-size:.78rem;line-height:1.65}.stack-grid{display:grid;gap:14px}.stack-grid--result{gap:18px}.animated-card{background:var(--surface);border:1px solid rgba(255,255,255,.65);border-radius:20px;box-shadow:var(--shadow);padding:20px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:fade-up .65s ease both}.info-block__title,.section-title{display:flex;align-items:center;gap:8px;margin:0 0 12px}.info-block__title h2,.section-title{font-size:1.05rem;margin:0}.info-block__icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--accent-soft);font-size:.8rem}.info-block__body,.consent-note,.result-hero__summary,.insight-card p{margin:0;color:var(--text-soft);line-height:1.65;font-size:.78rem}.info-block__list{margin:0;padding-left:16px;color:var(--text-soft);line-height:1.65;font-size:.78rem}.consent-row{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-weight:600;font-size:.78rem}.consent-row input{width:16px;height:16px;accent-color:var(--accent)}.action-stack{display:grid;gap:10px}.primary-button{border:none;border-radius:999px;padding:11px 18px;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease,opacity .18s ease}.primary-button:hover:not(:disabled){transform:translateY(-2px)}.primary-button:disabled{opacity:.55;cursor:not-allowed}.primary-button--full{width:100%}.primary-button--primary{background:linear-gradient(135deg,#7c58e9,#8e5bfb);color:#fff;box-shadow:0 12px 24px #7c58e947}.primary-button--secondary{background:#7c58e91f;color:var(--accent-deep)}.primary-button--ghost{background:#fffc;color:var(--accent-deep);border:1px solid rgba(124,88,233,.18)}.progress-header{margin-bottom:12px;animation:fade-up .5s ease both}.progress-header__meta{display:flex;justify-content:space-between;margin-bottom:7px;color:var(--text-soft);font-weight:600;font-size:.72rem}.progress-header__track{width:100%;height:4px;border-radius:999px;background:#7c58e91f;overflow:hidden}.progress-header__fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#7c58e9,#a06dff);transition:width .24s ease}.question-card{min-height:322px}.question-type-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:10px;font-size:.62rem;font-weight:700}.question-type-badge--single{background:#7c58e91f}.question-type-badge--check{background:#18a36f1f;color:var(--success)}.question-type-badge--sort{background:#ffb44b29;color:#c77a00}.question-card__title{margin:16px 0 10px;font-size:clamp(1.15rem,2.4vw,1.6rem);line-height:1.45}.question-card__hint{margin:0 0 14px;color:var(--text-muted);line-height:1.55;font-size:.72rem}.question-card__options{display:grid;gap:10px}.option-card{display:grid;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:10px;padding:12px 12px 12px 10px;border-radius:14px;border:1px solid var(--line);background:#faf7fff2;color:var(--text-main);text-align:left;transition:border-color .18s ease,transform .18s ease,background .18s ease,box-shadow .18s ease}.option-card:hover{border-color:#7c58e952;transform:translateY(-1px)}.option-card--active{border-color:#7c58e9;background:#efe8fff2;box-shadow:0 18px 32px #7c58e924}.option-card__marker{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:2px solid currentColor;font-size:.72rem;font-weight:700}.option-card--active .option-card__marker{background:#7c58e9;color:#fff;border-color:#7c58e9}.option-card__text{font-size:.76rem;line-height:1.55}.sort-list{display:grid;gap:10px}.sort-list__item{display:grid;grid-template-columns:36px minmax(0,1fr);gap:10px;align-items:start;border-radius:14px;border:1px solid var(--line);background:#faf7fff2;padding:12px}.sort-list__rank{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:#7c58e924;color:var(--accent-deep);font-weight:700;font-size:.72rem}.sort-list__body{display:grid;gap:10px}.sort-list__text{font-size:.76rem;line-height:1.55}.sort-list__actions{display:flex;gap:8px;flex-wrap:wrap}.footer-actions{display:flex;gap:10px;justify-content:center;margin-top:16px;animation:fade-up .75s ease both}.footer-actions--quiz{justify-content:space-between}.result-hero{text-align:center}.result-hero__icon{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:var(--accent-soft);margin-bottom:12px;font-size:1.4rem}.result-hero__eyebrow{margin:0 0 10px;color:var(--text-soft);font-size:.72rem}.result-hero__title{margin:0;font-size:clamp(1.45rem,3vw,2.2rem)}.result-hero__score{display:inline-flex;align-items:end;gap:6px;margin:16px 0 12px}.result-hero__score span{font-size:clamp(2.8rem,5.6vw,4rem);line-height:1;font-weight:800;color:#7c58e9}.result-hero__score small{font-size:.9rem;color:var(--text-soft)}.radar-chart{display:flex;justify-content:center}.radar-chart__svg{width:min(100%,460px);overflow:visible}.radar-chart__ring,.radar-chart__axis{fill:none;stroke:#7c58e92e}.radar-chart__shape{fill:#7c58e91f;stroke:#7c58e9;stroke-width:3}.radar-chart__label{font-size:10px;text-anchor:middle;fill:var(--text-main)}.dimension-grid{display:grid;gap:10px;margin-top:12px}.dimension-bar{padding:12px;border-radius:14px;background:#f8f4ffe6}.dimension-bar__header{display:flex;justify-content:space-between;gap:10px;margin-bottom:8px;color:var(--text-soft);font-size:.72rem}.dimension-bar__track{width:100%;height:5px;border-radius:999px;background:#7c58e91f;overflow:hidden}.dimension-bar__fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#7c58e9,#10a86f)}.insight-list{display:grid;gap:10px}.insight-card{padding:14px;border-radius:16px;background:#f7f1ffe6}.insight-card h3{margin:0 0 8px;font-size:.95rem}.disclaimer-card{text-align:center;color:var(--text-soft);font-size:.72rem}.modal{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none;opacity:0;transition:opacity .22s ease;z-index:30}.modal--open{opacity:1;pointer-events:auto}.modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#38267247;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal__panel{position:relative;width:min(100% - 32px,460px);border-radius:20px;background:#fffffffa;padding:20px;box-shadow:0 30px 60px #3d297d2e;animation:modal-in .24s ease both}.modal__title{margin:0 0 12px;font-size:1rem}.modal__description{margin:0 0 20px;color:var(--text-soft);line-height:1.65;font-size:.78rem}.modal__actions{display:flex;justify-content:flex-end;gap:8px}@keyframes fade-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes modal-in{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 780px){.page-shell{padding:18px 12px 92px}.animated-card{padding:16px;border-radius:18px}.hero__title{font-size:2rem}.question-card{min-height:auto}.question-card__title{font-size:1.15rem}.footer-actions,.footer-actions--quiz{flex-wrap:wrap;justify-content:stretch}.footer-actions .primary-button,.footer-actions--quiz .primary-button{flex:1 1 calc(50% - 7px)}}@media (max-width: 520px){.hero__eyebrow{letter-spacing:.22em;font-size:.56rem}.hero__title{font-size:1.65rem}.hero__subtitle,.question-card__title{line-height:1.5}.option-card,.sort-list__item{grid-template-columns:30px minmax(0,1fr);gap:8px;padding:10px}.option-card__marker,.sort-list__rank{width:22px;height:22px;font-size:.66rem}.sort-list__actions{display:grid;grid-template-columns:1fr 1fr}.modal__actions{flex-direction:column}.footer-actions .primary-button,.footer-actions--quiz .primary-button{flex:1 1 100%}}
