@import "https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@300;400;500;600;700&family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&display=swap";:root{--primary-900:#0d0b1a;--primary-800:#15122b;--primary-700:#1e1a3d;--primary-600:#2a2452;--primary-500:#3d3570;--accent-gold:#c9a96e;--accent-gold-light:#e8d5a8;--accent-gold-dim:#c9a96e26;--accent-rose:#e8475f;--accent-rose-light:#ff6b9d;--accent-rose-dim:#e8475f26;--accent-teal:#4ecdc4;--accent-teal-dim:#4ecdc41f;--accent-purple:#7c5cfc;--accent-purple-dim:#7c5cfc1f;--text-primary:#f0ebe3;--text-secondary:#a8a0b8;--text-muted:#6b6380;--text-gold:#c9a96e;--surface-card:#1e1a3d99;--surface-card-hover:#2a2452cc;--surface-glass:#ffffff0a;--surface-glass-border:#ffffff14;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--shadow-card:0 4px 24px #0000004d;--shadow-glow:0 0 40px #c9a96e26;--transition:.3s cubic-bezier(.4, 0, .2, 1);--font-body:"Be Vietnam Pro", -apple-system, sans-serif;--font-display:"Cormorant Garamond", Georgia, serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);background:var(--primary-900);color:var(--text-primary);min-height:100dvh;position:relative;overflow-x:hidden}body:before{content:"";z-index:0;background:radial-gradient(at 20% 20%,#7c5cfc14 0%,#0000 50%),radial-gradient(at 80% 80%,#c9a96e0f 0%,#0000 50%),radial-gradient(#e8475f0a 0%,#0000 60%);animation:20s ease-in-out infinite alternate bgShift;position:fixed;inset:0}@keyframes bgShift{0%{opacity:.8}50%{opacity:1}to{opacity:.7}}#app{z-index:1;flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;padding:0 20px;display:flex;position:relative}.display-title{font-family:var(--font-display);color:var(--accent-gold);letter-spacing:.02em;font-size:2.2rem;font-weight:600;line-height:1.2}.section-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:8px;font-size:1.5rem;font-weight:600}.subtitle{color:var(--text-secondary);font-size:.95rem;font-weight:300;line-height:1.6}.label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:500}.screen{flex-direction:column;min-height:100dvh;padding:40px 0 32px;animation:.5s fadeSlideIn;display:none}.screen.active{display:flex}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.brand-bar{text-align:center;padding:16px 0 24px}.brand-bar .logo-text{font-family:var(--font-display);color:var(--accent-gold);letter-spacing:.15em;text-transform:uppercase;text-shadow:0 0 10px #d4af3766;font-size:1.4rem}.brand-bar .logo-text a{color:var(--text-muted);transition:color var(--transition);text-decoration:none}.brand-bar .logo-text a:hover{color:var(--accent-gold)}.brand-bar-intro{padding:24px 0 12px}.logo-link{transition:opacity var(--transition);display:inline-block}.logo-link:hover{opacity:.8}.logo-img{object-fit:contain;width:auto;height:58px}.btn{border-radius:var(--radius-lg);font-family:var(--font-body);cursor:pointer;transition:all var(--transition);-webkit-tap-highlight-color:transparent;border:none;outline:none;justify-content:center;align-items:center;gap:8px;padding:14px 28px;font-size:.95rem;font-weight:500;text-decoration:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent-gold) 0%, #b8903a 100%);color:var(--primary-900);box-shadow:0 4px 20px #c9a96e4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 28px #c9a96e73}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--surface-glass);color:var(--text-primary);border:1px solid var(--surface-glass-border)}.btn-secondary:hover{background:var(--surface-card-hover);border-color:#ffffff26}.btn-ghost{color:var(--text-secondary);background:0 0;padding:10px 16px}.btn-ghost:hover{color:var(--accent-gold)}.btn-full{width:100%}.card{background:var(--surface-card);border:1px solid var(--surface-glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);transition:all var(--transition);padding:20px}.card:hover{background:var(--surface-card-hover);box-shadow:var(--shadow-card);border-color:#ffffff1f;transform:translateY(-2px)}.card.selected{border-color:var(--accent-gold);box-shadow:0 0 0 1px var(--accent-gold), var(--shadow-glow)}.card-clickable{cursor:pointer}.mode-grid{grid-template-columns:1fr 1fr;gap:12px;margin:20px 0;display:grid}.mode-card{background:var(--surface-card);border:1px solid var(--surface-glass-border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition);padding:20px 16px}.mode-card .mode-icon{margin-bottom:8px;font-size:2rem;display:block}.mode-card .mode-label{color:var(--text-primary);margin-bottom:4px;font-size:.85rem;font-weight:500}.mode-card .mode-desc{color:var(--text-muted);font-size:.72rem;line-height:1.4}.mode-card:hover{box-shadow:var(--shadow-card);transform:translateY(-3px)}.mode-card.selected{border-color:var(--accent-gold);box-shadow:0 0 0 1px var(--accent-gold), var(--shadow-glow)}.mode-card.selected .mode-label{color:var(--accent-gold)}.form-group{margin-bottom:18px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:.82rem;font-weight:500;display:block}.form-input{background:var(--surface-glass);border:1px solid var(--surface-glass-border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:all var(--transition);outline:none;padding:12px 16px;font-size:.95rem}.form-input:focus{border-color:var(--accent-gold);box-shadow:0 0 0 2px var(--accent-gold-dim)}.form-input::placeholder{color:var(--text-muted)}.form-row{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}.form-row-2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.chip-group{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--surface-glass-border);background:var(--surface-glass);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border-radius:100px;padding:8px 16px;font-size:.85rem}.chip:hover{border-color:#ffffff26}.chip.selected{border-color:var(--accent-gold);color:var(--accent-gold);background:var(--accent-gold-dim)}.question-progress{gap:6px;margin-bottom:28px;display:flex}.progress-dot{background:var(--surface-glass-border);height:3px;transition:background var(--transition);border-radius:2px;flex:1}.progress-dot.filled{background:var(--accent-gold)}.progress-dot.current{background:var(--accent-gold-light);box-shadow:0 0 8px #c9a96e66}.question-number{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-size:.75rem}.question-text{font-family:var(--font-display);color:var(--text-primary);margin-bottom:28px;font-size:1.35rem;font-weight:400;line-height:1.4}.answer-list{flex-direction:column;gap:10px;display:flex}.answer-card{background:var(--surface-card);border:1px solid var(--surface-glass-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);color:var(--text-secondary);padding:16px 20px;font-size:.92rem;position:relative;overflow:hidden}.answer-card:before{content:"";width:3px;transition:background var(--transition);background:0 0;position:absolute;top:0;bottom:0;left:0}.answer-card:hover{background:var(--surface-card-hover);color:var(--text-primary);transform:translate(4px)}.answer-card:hover:before{background:var(--accent-gold)}.answer-card.selected{border-color:var(--accent-gold);color:var(--accent-gold-light);background:var(--accent-gold-dim)}.answer-card.selected:before{background:var(--accent-gold)}.loading-container{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:32px;display:flex}.loading-orb{background:radial-gradient(circle, var(--accent-gold) 0%, transparent 70%);border-radius:50%;width:80px;height:80px;animation:2s ease-in-out infinite orbPulse;position:relative}.loading-orb:after{content:"";border:1px solid #c9a96e33;border-radius:50%;animation:3s linear infinite orbRing;position:absolute;inset:-15px}@keyframes orbPulse{0%,to{opacity:.6;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}@keyframes orbRing{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-title{font-family:var(--font-display);color:var(--accent-gold);font-size:1.3rem;font-style:italic}.loading-steps{flex-direction:column;gap:10px;display:flex}.loading-step{color:var(--text-muted);opacity:0;font-size:.82rem;animation:.8s forwards stepFade}.loading-step:first-child{animation-delay:.5s}.loading-step:nth-child(2){animation-delay:1.5s}.loading-step:nth-child(3){animation-delay:2.5s}.loading-step:nth-child(4){animation-delay:3.5s}@keyframes stepFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}[data-animate=fade-up]{opacity:0;transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1);transform:translateY(24px)}[data-animate=fade-up].r-visible{opacity:1;transform:translateY(0)}.r-section{margin-bottom:24px}.r-hero{text-align:center;border-radius:var(--radius-xl);background:linear-gradient(168deg,#1e1a3dd9 0%,#14112df2 40%,#0f0c23fa 100%);border:1px solid #c9a96e1f;margin-bottom:20px;padding:36px 24px 32px;position:relative;overflow:hidden}.r-hero-glow{pointer-events:none;background:radial-gradient(#c9a96e1f 0%,#0000 70%);width:280px;height:180px;position:absolute;top:-60px;left:50%;transform:translate(-50%)}.r-hero-mode{color:var(--text-muted);letter-spacing:.04em;background:#ffffff0a;border:1px solid #ffffff0f;border-radius:100px;align-items:center;gap:6px;margin-bottom:24px;padding:5px 14px;font-size:.72rem;font-weight:500;display:inline-flex}.r-hero-mode-icon{font-size:.85rem}.r-score-ring{width:140px;height:140px;margin:0 auto 20px;position:relative}.r-score-svg{width:100%;height:100%;transform:rotate(-90deg)}.r-score-track{fill:none;stroke:#ffffff0d;stroke-width:3px}.r-score-arc{fill:none;stroke-width:4px;stroke-linecap:round;filter:drop-shadow(0 0 6px);transition:stroke-dashoffset 1.6s cubic-bezier(.4,0,.2,1)}.r-score-inner{flex-direction:row;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:0}.r-score-value{font-family:var(--font-display);color:var(--accent-gold-light);font-size:3rem;font-weight:700;line-height:1}.r-score-unit{color:var(--text-muted);align-self:flex-end;padding-bottom:6px;font-size:.9rem;font-weight:300}.r-hero-badge{border-radius:100px;align-items:center;gap:8px;margin-bottom:16px;padding:6px 18px;font-size:.82rem;font-weight:500;display:inline-flex}.r-hero-badge-dot{border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite dotPulse}@keyframes dotPulse{0%,to{opacity:.6;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}.r-hero-title{font-family:var(--font-display);color:var(--accent-gold);margin-bottom:10px;font-size:1.4rem;font-weight:600;line-height:1.3}.r-hero-hook{color:var(--text-secondary);max-width:320px;margin:0 auto;font-size:.88rem;font-style:italic;font-weight:300;line-height:1.6}.r-zodiac{border-radius:var(--radius-lg);background:#ffffff05;border:1px solid #ffffff0f;flex-wrap:wrap;justify-content:center;align-items:center;gap:0;margin-bottom:20px;padding:20px 16px 16px;display:flex}.r-zodiac-person{text-align:center;min-width:90px}.r-zodiac-icon{filter:drop-shadow(0 0 4px #c9a96e4d);margin-bottom:4px;font-size:2rem}.r-zodiac-name{color:var(--text-muted);margin-bottom:2px;font-size:.78rem}.r-zodiac-sign{color:var(--accent-gold);font-size:.85rem;font-weight:500}.r-zodiac-connector{align-items:center;gap:8px;padding:0 12px;display:flex}.r-zodiac-line{background:linear-gradient(90deg,#0000,#c9a96e4d,#0000);width:20px;height:1px}.r-zodiac-cross{color:var(--accent-gold);opacity:.5;font-size:.65rem}.r-zodiac-element{text-align:center;border-top:1px solid #ffffff0d;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:12px;padding-top:12px;display:flex}.r-zodiac-element-label{color:var(--text-muted);letter-spacing:.04em;font-size:.72rem}.r-zodiac-element-value{color:var(--accent-gold-light);font-size:.82rem;font-weight:500}.r-reading-card{border-radius:var(--radius-lg);background:linear-gradient(160deg,#1e1a3d80 0%,#0f0c23b3 100%);border:1px solid #c9a96e1a;padding:24px 20px 20px;position:relative}.r-reading-ornament{font-family:var(--font-display);color:#c9a96e26;-webkit-user-select:none;user-select:none;margin-bottom:8px;font-size:2.4rem;line-height:1}.r-reading-text{color:var(--text-primary);font-size:.92rem;font-weight:300;line-height:1.75}.r-section-header{align-items:center;gap:8px;margin-bottom:14px;display:flex}.r-section-icon{color:var(--accent-gold);opacity:.7;font-size:.7rem}.r-section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.75rem;font-weight:600}.r-sub-list{flex-direction:column;gap:14px;display:flex}.r-sub-item{flex-direction:column;gap:5px;display:flex}.r-sub-top{justify-content:space-between;align-items:baseline;display:flex}.r-sub-label{color:var(--text-secondary);font-size:.78rem;font-weight:400}.r-sub-value{color:var(--text-primary);font-size:.75rem;font-weight:600;font-family:var(--font-display)}.r-sub-track{background:#ffffff0f;border-radius:2px;height:3px;overflow:hidden}.r-sub-fill{background:var(--accent-gold);border-radius:2px;width:0;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1) .6s}.r-list-item{border-radius:var(--radius-md);background:#ffffff05;border:1px solid #ffffff0d;gap:0;margin-bottom:8px;transition:transform .2s,box-shadow .2s;display:flex;overflow:hidden}.r-list-item:last-child{margin-bottom:0}.r-list-item:hover{transform:translate(3px);box-shadow:0 2px 12px #0003}.r-list-accent{flex-shrink:0;width:3px}.r-list-content{color:var(--text-secondary);padding:14px 16px;font-size:.88rem;font-weight:300;line-height:1.55}.r-list-strength .r-list-accent{background:linear-gradient(#4ecdc4,#2cb5a8)}.r-list-friction .r-list-accent{background:linear-gradient(#e8475f,#c73a4e)}.r-list-action .r-list-accent{background:linear-gradient(#7c5cfc,#6248d0)}.r-note-card{border-radius:var(--radius-lg);text-align:center;background:linear-gradient(135deg,#c9a96e0f 0%,#1e1a3d66 100%);border:1px solid #c9a96e1a;padding:20px}.r-note-icon{color:var(--accent-gold);opacity:.6;margin-bottom:6px;font-size:1.4rem}.r-note-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:10px;font-size:.68rem;font-weight:500}.r-note-text{color:var(--text-secondary);font-size:.88rem;font-style:italic;font-weight:300;line-height:1.65}.r-tendency-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.r-tendency-card{border-radius:var(--radius-md);text-align:center;background:#ffffff05;border:1px solid #ffffff0f;padding:16px}.r-tendency-person{color:var(--text-muted);margin-bottom:6px;font-size:.78rem;font-weight:500}.r-tendency-role{font-family:var(--font-display);color:var(--accent-gold);margin-bottom:8px;font-size:1.1rem;font-weight:600}.r-tendency-desc{color:var(--text-secondary);font-size:.78rem;font-weight:300;line-height:1.5}.r-share-card{border-radius:var(--radius-xl);text-align:center;background:linear-gradient(145deg,#1e1a3db3 0%,#14112de6 50%,#0f0c23f2 100%);border:1px solid #c9a96e26;padding:32px 24px;position:relative;overflow:hidden}.r-share-glow{pointer-events:none;background:radial-gradient(#c9a96e14 0%,#0000 70%);width:200px;height:120px;position:absolute;bottom:-40px;left:50%;transform:translate(-50%)}.r-share-ornament-tl,.r-share-ornament-br{color:#c9a96e33;-webkit-user-select:none;user-select:none;font-size:.65rem;position:absolute}.r-share-ornament-tl{top:14px;left:14px}.r-share-ornament-br{bottom:14px;right:14px}.r-share-quote{font-family:var(--font-display);color:var(--accent-gold-light);z-index:1;border:none;margin:0 0 16px;padding:0;font-size:1.15rem;font-style:italic;font-weight:400;line-height:1.55;position:relative}.r-share-brand{letter-spacing:.18em;color:var(--text-muted);text-transform:uppercase;opacity:.6;z-index:1;font-size:.62rem;font-weight:500;position:relative}.r-share-btn{border-radius:var(--radius-md);width:100%;color:var(--accent-gold);font-family:var(--font-body);cursor:pointer;transition:all var(--transition);background:#c9a96e0f;border:1px solid #c9a96e33;justify-content:center;align-items:center;gap:8px;margin-top:12px;padding:12px 20px;font-size:.82rem;font-weight:500;display:inline-flex}.r-share-btn:hover{background:#c9a96e1f;border-color:#c9a96e59;transform:translateY(-1px)}.r-share-btn:active{transform:translateY(0)}.r-share-btn-success{color:#22c55e!important;background:#22c55e1f!important;border-color:#22c55e4d!important}.screen-footer{margin-top:auto;padding:20px 0 32px}.footer-actions{gap:10px;display:flex}.footer-actions .btn{flex:1}.spacer-sm{height:12px}.spacer-md{height:24px}.spacer-lg{height:40px}.person-badge{letter-spacing:.05em;text-transform:uppercase;border-radius:100px;align-items:center;gap:6px;margin-bottom:12px;padding:4px 14px;font-size:.75rem;font-weight:600;display:inline-flex}.person-badge.person-a{background:var(--accent-rose-dim);color:var(--accent-rose-light);border:1px solid #e8475f40}.person-badge.person-b{background:var(--accent-teal-dim);color:var(--accent-teal);border:1px solid #4ecdc440}.intro-hero{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px 0;display:flex}.intro-icon{margin-bottom:20px;font-size:4rem;animation:4s ease-in-out infinite floatIcon}@keyframes floatIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.intro-title{font-family:var(--font-display);color:var(--accent-gold);letter-spacing:.03em;margin-bottom:12px;font-size:2.4rem;font-weight:600}.intro-desc{color:var(--text-secondary);max-width:320px;margin:0 auto 32px;font-size:.92rem;line-height:1.7}.stars-bg{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.star{background:#c9a96e66;border-radius:50%;width:2px;height:2px;animation:3s ease-in-out infinite twinkle;position:absolute}@keyframes twinkle{0%,to{opacity:.2}50%{opacity:1}}.screen-enter{animation:.45s fadeSlideIn}@media (width<=380px){.mode-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr 1fr}.display-title{font-size:1.8rem}.r-tendency-grid{grid-template-columns:1fr}.r-hero{padding:28px 16px 24px}.r-score-ring{width:120px;height:120px}.r-score-value{font-size:2.4rem}}@media (width>=481px){#app{padding:0 32px}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-glass-border);border-radius:2px}::selection{background:var(--accent-gold-dim);color:var(--accent-gold)}.nav-back{color:var(--text-muted);cursor:pointer;transition:color var(--transition);font-size:.85rem;font-family:var(--font-body);z-index:10;background:0 0;border:none;padding:8px 12px;position:absolute;top:42px;left:0}.nav-back:hover{color:var(--accent-gold)}.api-key-section{background:var(--surface-glass);border:1px solid var(--surface-glass-border);border-radius:var(--radius-md);margin-top:20px;padding:14px 16px}.api-key-section .form-label{color:var(--text-muted);font-size:.75rem}.api-key-section .form-input{padding:8px 12px;font-size:.82rem}.api-key-note{color:var(--text-muted);margin-top:4px;font-size:.7rem;font-style:italic}.result-share-hint{text-align:center;color:var(--text-muted);border-top:1px solid #ffffff0a;margin-top:20px;padding:12px 0;font-size:.72rem}
