*{box-sizing:border-box}:root{font-family:Open Sans,-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0a0a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--app-accent: #F2C811;--glass-bg: rgba(255, 255, 255, .08);--glass-bg-strong: rgba(255, 255, 255, .12);--glass-bg-subtle: rgba(255, 255, 255, .04);--glass-border: rgba(255, 255, 255, .18);--glass-border-subtle: rgba(255, 255, 255, .1);--glass-blur: blur(20px);--glass-blur-strong: blur(28px);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .3), 0 2px 8px rgba(0, 0, 0, .2), inset 0 1px 0 rgba(255, 255, 255, .06);--glass-shadow-elevated: 0 16px 48px rgba(0, 0, 0, .4), 0 4px 16px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255, 255, 255, .08)}body{margin:0;min-width:320px;min-height:100vh;background:#0a0a1a}#root{min-height:100vh}a{color:inherit;text-decoration:none}button,input,select{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}h1,h2,h3,h4,h5,h6{font-family:Open Sans,-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif;font-weight:700}h1{font-size:1.75rem}h2{font-size:1.35rem}h3{font-size:1.15rem}h4{font-size:1.05rem}.typing-test{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem;max-width:600px;margin:0 auto}.step-indicator{width:100%;text-align:center;margin-bottom:2rem}.step-indicator span{color:#fff9;font-size:.9rem}.step-dots{display:flex;justify-content:center;gap:.5rem;margin-top:.5rem}.dot{width:10px;height:10px;border-radius:50%;background:#fff3;transition:background .3s}.dot.active{background:var(--app-accent, #F2C811);box-shadow:0 0 8px color-mix(in srgb,var(--app-accent, #F2C811) 50%,transparent)}.typing-test h2{text-align:center;margin-bottom:.5rem;color:#fff}.instruction{color:#fff9;text-align:center;margin-bottom:2rem}.typing-card{background:var(--glass-bg);border:2px solid var(--glass-border-subtle);border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s ease;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);box-shadow:var(--glass-shadow);user-select:none;-webkit-user-select:none}.typing-card:hover{background:var(--glass-bg-strong);transform:translateY(-2px);border-color:var(--glass-border)}.card-icon{font-size:2rem;display:block;margin-bottom:.5rem}.typing-card h3{margin:0 0 .25rem;color:#fff}.card-subtitle{font-size:.85rem;color:#ffffff80;display:block;margin-bottom:.75rem}.typing-card p{font-size:.95rem;line-height:1.5;color:#fffc;margin:0}.card-pool{display:flex;flex-direction:column;gap:1rem;width:100%;margin-bottom:2rem}.pool-card{transition:transform .2s ease,opacity .2s ease}.rank-slots{display:flex;flex-direction:column;gap:1rem;width:100%;margin-bottom:1.5rem}.rank-slot.filled{position:relative;padding:0}.rank-slot.filled .ranked-card{border-color:color-mix(in srgb,var(--app-accent, #F2C811) 40%,transparent);background:color-mix(in srgb,var(--app-accent, #F2C811) 8%,var(--glass-bg));cursor:default}.rank-slot.filled .ranked-card:hover{transform:none}.rank-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--app-accent, #F2C811);margin-bottom:.25rem}.rank-slot.filled .rank-label{position:absolute;top:-.5rem;left:1rem;background:#1a1a2e;padding:0 .5rem;z-index:1}.ranking-actions{width:100%;display:flex;flex-direction:column;gap:.75rem}.reset-btn{width:100%;padding:.75rem;font-size:.95rem;font-weight:500;background:transparent;color:#fff9;border:1px solid rgba(255,255,255,.2);border-radius:12px;cursor:pointer;transition:all .2s ease}.reset-btn:hover{color:#ffffffe6;border-color:#fff6;background:#ffffff0d}.confirm-btn{width:100%;padding:1rem;font-size:1.1rem;font-weight:600;background:color-mix(in srgb,var(--app-accent, #F2C811) 80%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fff;border:1px solid color-mix(in srgb,var(--app-accent, #F2C811) 40%,transparent);border-radius:12px;cursor:pointer;transition:all .3s ease}.confirm-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 24px color-mix(in srgb,var(--app-accent, #F2C811) 40%,transparent);background:var(--app-accent, #F2C811)}.confirm-btn:disabled{opacity:.5;cursor:not-allowed}.type-select-container{width:100%;text-align:center}.type-select-disclaimer{color:#fff9;font-size:.95rem;line-height:1.6;margin:1rem 0 2rem;font-style:italic}.type-select-cards{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.type-select-card{background:var(--glass-bg);border:2px solid var(--glass-border-subtle);border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s ease;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);box-shadow:var(--glass-shadow);text-align:left;position:relative}.type-select-card:hover{background:var(--glass-bg-strong);transform:translateY(-2px);border-color:var(--glass-border)}.type-select-card.selected{border-color:var(--app-accent, #F2C811);background:color-mix(in srgb,var(--app-accent, #F2C811) 12%,transparent);box-shadow:0 0 24px color-mix(in srgb,var(--app-accent, #F2C811) 25%,transparent),var(--glass-shadow)}.type-select-card h3{margin:.25rem 0 .75rem;color:#fff;font-size:1.15rem}.match-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.2rem .6rem;border-radius:6px;display:inline-block}.match-0{background:color-mix(in srgb,var(--app-accent, #F2C811) 25%,transparent);color:var(--app-accent, #F2C811)}.match-1{background:#ffffff1f;color:#ffffffb3}.match-2{background:#ffffff14;color:#ffffff80}.type-details{display:flex;flex-direction:column;gap:.25rem}.type-details p{margin:0;font-size:.9rem;color:#ffffffb3;line-height:1.4}.type-details p:nth-child(3){margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.type-details strong{color:#ffffffe6}.wing-container{text-align:center;width:100%}.wing-container>p{color:#ffffffb3;margin:1rem 0 2rem}.wing-options{display:flex;flex-direction:column;gap:1rem}.wing-card{background:var(--glass-bg);border:2px solid var(--glass-border-subtle);border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s ease;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);box-shadow:var(--glass-shadow)}.wing-card:hover{border-color:var(--app-accent, #F2C811);background:color-mix(in srgb,var(--app-accent, #F2C811) 10%,transparent);transform:translateY(-2px)}.wing-card h3{margin:0 0 .5rem;color:#fff}.wing-card p{margin:0;color:#ffffffb3}.welcome-screen{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3rem 1rem;max-width:420px}.welcome-logo-row{display:flex;align-items:center;gap:1rem;margin-bottom:2.5rem}.welcome-ball{width:64px;height:64px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;box-shadow:0 6px 24px #f2c81159;overflow:hidden}.welcome-ball .ball-stripe{position:absolute;top:22%;left:0;right:0;height:56%;background:linear-gradient(180deg,#f7dc6f,#f2c811 40%,#c9a60e);display:flex;align-items:center;justify-content:center}.welcome-ball .ball-circle{width:30px;height:30px;border-radius:50%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:1}.welcome-ball .ball-nine{font-family:Open Sans,sans-serif;font-size:1.15rem;font-weight:800;color:#1a1a2e;line-height:1;margin-top:1px}.welcome-ball .ball-smile{display:block;width:12px;height:5px;border-bottom:2px solid #1a1a2e;border-radius:0 0 12px 12px;margin-top:-2px}.welcome-title h1{font-size:2rem;margin:0;color:#fff}.welcome-tagline{margin:.2rem 0 0;font-size:.95rem;color:var(--app-accent, #F2C811);font-weight:500}.welcome-body{margin-bottom:2.5rem}.welcome-body p{font-size:1rem;line-height:1.7;color:#ffffffbf;margin:0 0 1.25rem}.welcome-body strong{color:#fffffff2}.welcome-test-desc{font-size:1.05rem!important;color:#ffffffe6!important;font-weight:500}.begin-btn{width:100%;max-width:300px;padding:1rem;font-size:1.15rem;font-weight:600;background:var(--app-accent, #F2C811);color:#1a1a2e;border:none;border-radius:12px;cursor:pointer;transition:all .2s;box-shadow:0 4px 20px #f2c8114d}.begin-btn:hover{transform:translateY(-2px);box-shadow:0 6px 28px #f2c81166}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background:#0a0a1a66;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--glass-border);box-shadow:0 -4px 30px #0000004d,inset 0 1px #ffffff0f;display:flex;justify-content:space-around;align-items:center;padding:0 .5rem;z-index:100}.nav-tab{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;background:none;border:none;cursor:pointer;transition:all .2s;min-width:60px}.nav-icon{font-size:1.5rem;transition:transform .2s}.nav-label{font-size:.65rem;color:#ffffff80;transition:color .2s}.nav-tab.active .nav-icon{transform:scale(1.1);filter:drop-shadow(0 0 6px var(--app-accent, #F2C811))}.nav-tab.active .nav-label{color:var(--app-accent, #F2C811);font-weight:600}.nav-tab:hover .nav-icon{transform:scale(1.1)}.soul-card-container{perspective:1000px;width:100%;max-width:320px;height:420px;cursor:pointer;margin:0 auto}.soul-card{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .6s ease}.soul-card.flipped{transform:rotateY(180deg)}.soul-card-face{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:24px;padding:2rem;display:flex;flex-direction:column;align-items:center;box-shadow:var(--glass-shadow-elevated);border:1px solid var(--glass-border);overflow:hidden}.soul-card-front{background:linear-gradient(135deg,color-mix(in srgb,var(--type-color) 60%,transparent),color-mix(in srgb,var(--type-color) 25%,transparent));backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur)}.soul-card-back{background:#ffffff0f;backdrop-filter:var(--glass-blur-strong);-webkit-backdrop-filter:var(--glass-blur-strong);transform:rotateY(180deg)}.type-number{font-size:5rem;font-weight:800;color:#fff3;line-height:1;margin-bottom:.5rem}.type-name{font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 1rem;text-align:center}.wing-badge{background:#ffffff26;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:.4rem 1rem;border-radius:20px;font-size:.85rem;color:#fff;margin-bottom:2rem;border:1px solid rgba(255,255,255,.12)}.type-desire{text-align:center;margin-top:auto}.label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:#fff9;margin-bottom:.25rem}.type-desire .value{font-size:1.1rem;color:#fff;font-weight:500}.tap-hint{margin-top:auto;font-size:.8rem;color:#fff6;margin-bottom:0}.back-content{flex:1;display:flex;flex-direction:column;justify-content:center;gap:1.5rem;text-align:center}.ego-message,.core-fear,.wisdom-quote{text-align:center}.ego-message .quote,.wisdom-quote .quote{font-style:italic;font-size:1rem;color:#ffffffe6;margin:.25rem 0 0}.core-fear p{font-size:.95rem;color:#ff6b6b;margin:.25rem 0 0;font-weight:500}.wisdom-quote .quote{color:#69db7c}.home-page{padding:1.5rem;padding-bottom:100px}.home-header{margin-bottom:2rem}.brand-hero{margin-bottom:1.5rem}.brand-logo-row{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.brand-ball{width:56px;height:56px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;box-shadow:0 4px 16px #f2c8114d;overflow:hidden}.brand-ball .ball-stripe{position:absolute;top:22%;left:0;right:0;height:56%;background:linear-gradient(180deg,#f7dc6f,#f2c811 40%,#c9a60e);display:flex;align-items:center;justify-content:center}.brand-ball .ball-circle{width:26px;height:26px;border-radius:50%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:1}.brand-ball .ball-nine{font-family:Open Sans,sans-serif;font-size:1rem;font-weight:800;color:#1a1a2e;line-height:1;margin-top:1px}.brand-ball .ball-smile{display:block;width:10px;height:5px;border-bottom:2px solid #1a1a2e;border-radius:0 0 10px 10px;margin-top:-2px}.brand-text h1{font-size:1.75rem;margin:0;color:#fff}.brand-tagline{margin:.15rem 0 0;font-size:.9rem;color:var(--app-accent, #F2C811);font-weight:500}.brand-explanation{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:12px;padding:1rem 1.25rem}.brand-explanation p{margin:0 0 .75rem;font-size:.9rem;line-height:1.6;color:#ffffffb3}.brand-explanation p:last-child{margin-bottom:0}.brand-explanation strong{color:#fffffff2}.brand-explanation em{color:var(--app-accent, #F2C811);font-style:normal;font-weight:600}.home-header .date{color:#ffffff80;margin:0}section{margin-top:2.5rem}section h2{margin:0 0 .25rem;color:#fff}.getting-started{margin-top:2rem}.action-cards{display:flex;flex-direction:column;gap:.75rem}.action-card{display:flex;align-items:flex-start;gap:1rem;width:100%;padding:1.1rem 1.25rem;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:14px;box-shadow:var(--glass-shadow);cursor:pointer;transition:all .2s ease;text-align:left;color:#fff;font:inherit}.action-card:hover{border-color:color-mix(in srgb,var(--type-color) 50%,transparent);background:color-mix(in srgb,var(--type-color) 8%,var(--glass-bg));transform:translateY(-1px)}.action-icon{font-size:1.5rem;flex-shrink:0;line-height:1;margin-top:.1rem}.action-card strong{display:block;font-size:.95rem;margin-bottom:.2rem}.action-card p{margin:0;font-size:.85rem;color:#ffffff8c;line-height:1.4}.reality-check{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:16px;padding:1.5rem;box-shadow:var(--glass-shadow)}.mood-slider-container{margin:1.5rem 0}.mood-slider{width:100%;height:8px;-webkit-appearance:none;background:linear-gradient(to right,#22c55e,#eab308,#ef4444);border-radius:4px;outline:none}.mood-slider::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 2px 10px #0000004d}.mood-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:#ffffff80}.check-in-btn{width:100%;padding:.875rem;font-size:1rem;font-weight:600;background:color-mix(in srgb,var(--type-color) 70%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid color-mix(in srgb,var(--type-color) 40%,transparent);border-radius:12px;cursor:pointer;margin-top:1rem;transition:all .2s}.check-in-btn:hover{background:var(--type-color);box-shadow:0 4px 20px color-mix(in srgb,var(--type-color) 35%,transparent)}.mood-result{text-align:center;padding:1rem 0}.level-badge{display:inline-block;padding:.5rem 1.25rem;background:var(--level-color);color:#fff;border-radius:20px;font-weight:600;font-size:.9rem;margin-bottom:1rem}.level-message{font-size:1.1rem;color:#fff;margin:0 0 .75rem}.level-advice{font-size:.95rem;color:#ffffffb3;margin:0;line-height:1.5}.warning-signs{background:#ef444414;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid rgba(239,68,68,.2);border-radius:16px;padding:1.5rem;box-shadow:var(--glass-shadow)}.warning-list{list-style:none;padding:0;margin:0}.warning-list li{padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.08);color:#fffc;font-size:.95rem}.warning-list li:last-child{border-bottom:none;padding-bottom:0}.warning-list li:before{content:"⚠️";margin-right:.75rem}.goal-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:2px solid var(--glass-border-subtle);border-radius:16px;padding:1.25rem;box-shadow:var(--glass-shadow)}.goal-card p{margin:0 0 1rem;color:#ffffffe6;font-size:1rem;line-height:1.5}.goal-card button{width:100%;padding:.75rem;font-size:.95rem;font-weight:600;background:transparent;color:var(--type-color);border:2px solid color-mix(in srgb,var(--type-color) 60%,transparent);border-radius:10px;cursor:pointer;transition:all .2s;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.goal-card button:hover{background:color-mix(in srgb,var(--type-color) 20%,transparent);border-color:var(--type-color);box-shadow:0 0 16px color-mix(in srgb,var(--type-color) 25%,transparent)}.goal-card.completed{border-color:#22c55e66;background:#22c55e14}.completed-badge{display:block;text-align:center;color:#22c55e;font-weight:600}.journal-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:16px;padding:1.5rem;border:1px solid var(--glass-border-subtle);box-shadow:var(--glass-shadow)}.journal-card p{margin:0;font-style:italic;font-size:1.1rem;color:#ffffffe6;line-height:1.6}.enneagram-symbol{max-width:300px;margin:0 auto;background:var(--glass-bg-subtle);border-radius:20px;padding:1rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border-subtle)}.enneagram-symbol svg{display:block}.user-node circle{filter:drop-shadow(0 0 10px rgba(168,85,247,.5))}.stress-line{animation:pulse-stress 2s ease-in-out infinite}.growth-line{animation:pulse-growth 2s ease-in-out infinite}@keyframes pulse-stress{0%,to{opacity:.7}50%{opacity:1}}@keyframes pulse-growth{0%,to{opacity:.7}50%{opacity:1}}.deep-dive-page{padding:1.5rem;padding-bottom:100px}.enneagram-section{text-align:center}.flow-legend{display:flex;justify-content:center;gap:2rem;margin-top:1rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#ffffffb3}.legend-item .line{width:20px;height:3px;border-radius:2px}.legend-item.stress .line{background:#ef4444}.legend-item.growth .line{background:#22c55e}.dynamics-section{display:grid;gap:1rem}.dynamic-card{padding:1.25rem;border-radius:16px;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);box-shadow:var(--glass-shadow)}.stress-card{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.growth-card{background:#22c55e14;border:1px solid rgba(34,197,94,.2)}.dynamic-card h3{margin:0 0 .5rem;color:#fff}.dynamic-type{font-size:.9rem;color:#ffffffb3;margin:0 0 .5rem}.dynamic-desc{font-size:.9rem;color:#fff9;margin:0;line-height:1.5}.dynamics-intro{margin-bottom:1.5rem}.dynamics-explainer{font-size:.9rem;line-height:1.7;color:#ffffffa6;margin:0}.dynamics-explainer strong{color:#ffffffe6}.integration-section{margin-bottom:2.5rem}.integration-tips{display:flex;flex-direction:column;gap:.75rem}.integration-tip{display:flex;gap:1rem;align-items:flex-start;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid rgba(34,197,94,.15);border-radius:12px;padding:1rem 1.25rem}.tip-number{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:#22c55e33;color:#22c55e;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;font-family:Open Sans,sans-serif}.integration-tip p{margin:0;font-size:.9rem;line-height:1.6;color:#ffffffd9}.childhood-section{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:16px;padding:1.5rem;box-shadow:var(--glass-shadow)}.childhood-card{margin-bottom:1.5rem}.wound-text{font-size:1rem;line-height:1.7;color:#ffffffd9;margin:0}.heal-btn{width:100%;padding:1rem;font-size:1rem;font-weight:600;background:color-mix(in srgb,var(--type-color) 70%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid color-mix(in srgb,var(--type-color) 40%,transparent);border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s}.heal-btn:hover{transform:translateY(-2px);box-shadow:0 4px 24px color-mix(in srgb,var(--type-color) 35%,transparent);background:var(--type-color)}.breathing-exercise{display:flex;justify-content:center;padding:2rem 0}.breath-circle{width:200px;height:200px;border-radius:50%;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:2px solid color-mix(in srgb,var(--type-color) 60%,transparent);display:flex;align-items:center;justify-content:center;text-align:center;padding:1.5rem;animation:pulse 2.5s ease-in-out infinite;box-shadow:0 0 30px color-mix(in srgb,var(--type-color) 15%,transparent),var(--glass-shadow)}.breath-circle span{font-size:1.1rem;color:#fff;line-height:1.5}@keyframes pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}.wings-container{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.wing-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:2px solid var(--glass-border-subtle);border-radius:16px;padding:1.25rem;text-align:center;cursor:pointer;transition:all .2s;box-shadow:var(--glass-shadow)}.wing-card:hover{border-color:var(--type-color)}.wing-card.active{border-color:var(--type-color);background:color-mix(in srgb,var(--type-color) 10%,transparent);box-shadow:0 0 20px color-mix(in srgb,var(--type-color) 20%,transparent),var(--glass-shadow)}.wing-number{font-size:2rem;font-weight:700;color:var(--type-color);display:block;margin-bottom:.5rem}.wing-card h3{font-size:.95rem;margin:0 0 .25rem;color:#fff}.wing-card p{font-size:.8rem;color:#fff9;margin:0}.wing-detail{margin-top:1.5rem;background:var(--glass-bg-subtle);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border-subtle);border-radius:12px;padding:1.25rem}.wing-detail h4{margin:0 0 1rem;color:#fff}.wing-detail p{margin:.5rem 0;font-size:.9rem;color:#fffc}.wing-detail button{margin-top:1rem;padding:.5rem 1rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:8px;color:#fff;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all .2s}.wing-detail button:hover{background:var(--glass-bg-strong)}.advice-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.oracle-header{padding:1rem 1.5rem;text-align:center;border-bottom:1px solid var(--glass-border-subtle);background:var(--glass-bg-subtle);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);flex-shrink:0}.oracle-header h1{font-size:1.75rem;margin:0 0 .25rem;color:#fff;background:linear-gradient(135deg,var(--type-color),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.oracle-subtitle{color:#ffffff80;margin:0;font-size:.85rem;font-family:monospace}.shake-section{display:flex;flex-direction:column;align-items:center;padding:1rem;position:relative;flex-shrink:0}.magic-ball{width:100px;height:100px;cursor:pointer;transition:transform .2s}.magic-ball:hover{transform:scale(1.05)}.magic-ball:active{transform:scale(.95)}.ball-surface{width:100%;height:100%;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px #00000080,inset 0 -10px 20px #00000026,inset 0 10px 20px #ffffff4d;position:relative;overflow:hidden}.ball-surface .ball-stripe{position:absolute;top:20%;left:0;right:0;height:60%;background:linear-gradient(180deg,#f7dc6f,#f2c811 35%,#c9a60e);display:flex;align-items:center;justify-content:center;z-index:1}.ball-surface .ball-circle{width:46px;height:46px;border-radius:50%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.ball-surface .ball-nine{font-family:Open Sans,sans-serif;font-size:1.75rem;font-weight:800;color:#1a1a2e;line-height:1;margin-top:2px}.ball-surface .ball-smile{display:block;width:18px;height:8px;border-bottom:2.5px solid #1a1a2e;border-radius:0 0 18px 18px;margin-top:-3px}.ball-surface:after{content:"";position:absolute;top:8%;left:15%;width:35%;height:20%;background:radial-gradient(ellipse,rgba(255,255,255,.15),transparent);border-radius:50%;pointer-events:none;z-index:2}.shake-hint{margin:.75rem 0 0;font-size:.8rem;color:#fff6}@keyframes shake{0%,to{transform:translate(0) rotate(0)}10%{transform:translate(-8px) rotate(-5deg)}20%{transform:translate(8px) rotate(5deg)}30%{transform:translate(-8px) rotate(-5deg)}40%{transform:translate(8px) rotate(5deg)}50%{transform:translate(-8px) rotate(-5deg)}60%{transform:translate(8px) rotate(5deg)}70%{transform:translate(-4px) rotate(-2deg)}80%{transform:translate(4px) rotate(2deg)}90%{transform:translate(-2px) rotate(-1deg)}}.magic-ball.shaking{animation:shake 1s ease-in-out}.fortune-reveal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#0a0a1ab3;backdrop-filter:var(--glass-blur-strong);-webkit-backdrop-filter:var(--glass-blur-strong);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;max-width:300px;text-align:center;cursor:pointer;animation:fadeIn .5s ease;z-index:10;box-shadow:0 0 40px color-mix(in srgb,var(--type-color) 25%,transparent),var(--glass-shadow-elevated)}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.fortune-text{font-size:1.2rem;font-style:italic;color:#fff;margin:0 0 1rem;line-height:1.6}.fortune-dismiss{font-size:.75rem;color:#fff6}.chat-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 1rem;padding-bottom:140px;-webkit-overflow-scrolling:touch}.welcome-message{text-align:center;padding:1.5rem}.welcome-message>p{font-size:.95rem;color:#ffffffb3;line-height:1.6;margin:0 0 1.5rem}.suggested-prompts{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.suggested-prompts button{padding:.6rem 1rem;font-size:.85rem;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border-subtle);border-radius:20px;color:#fffc;cursor:pointer;transition:all .2s}.suggested-prompts button:hover{border-color:var(--type-color);background:color-mix(in srgb,var(--type-color) 12%,transparent)}.messages{display:flex;flex-direction:column;gap:1rem;padding-bottom:1rem}.message{max-width:90%}.message.user{align-self:flex-end}.message.oracle{align-self:flex-start}.user-bubble{background:color-mix(in srgb,var(--type-color) 75%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;padding:.875rem 1rem;border-radius:16px 16px 4px;border:1px solid color-mix(in srgb,var(--type-color) 30%,transparent)}.user-bubble p{margin:0}.oracle-message{background:var(--glass-bg-subtle);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:16px 16px 16px 4px;overflow:hidden;box-shadow:var(--glass-shadow)}.oracle-section{padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.05)}.oracle-section:last-child{border-bottom:none}.section-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem;font-weight:600}.oracle-section p{margin:0;font-size:.95rem;line-height:1.6;color:#ffffffe6}.oracle-section.validation{background:#22c55e0f;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.oracle-section.validation .section-label{color:#22c55e}.oracle-section.challenge{background:#eab3080f;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.oracle-section.challenge .section-label{color:#eab308}.oracle-section.action{background:#a855f714;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.oracle-section.action .section-label{color:var(--type-color)}.typing-indicator{display:flex;gap:4px;padding:1rem;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:16px 16px 16px 4px;width:fit-content}.typing-indicator span{width:8px;height:8px;background:#fff6;border-radius:50%;animation:bounce 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.oracle-input{position:fixed;bottom:70px;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(10,10,26,.9) 60%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;gap:.75rem;align-items:center}.oracle-input input{flex:1;padding:1rem;font-size:1rem;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:24px;color:#fff;outline:none;transition:border-color .2s,box-shadow .2s}.oracle-input input:focus{border-color:var(--type-color);box-shadow:0 0 16px color-mix(in srgb,var(--type-color) 20%,transparent)}.oracle-input input::placeholder{color:#fff6}.oracle-input input:disabled{opacity:.5}.send-button{width:48px;height:48px;padding:0;background:radial-gradient(circle at 30% 30%,#f7dc6f,#f2c811 50%,#c9a60e);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #0006,inset 0 -4px 8px #0006,inset 0 4px 8px #ffffff1a;transition:transform .2s,box-shadow .2s}.send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 6px 20px #00000080,inset 0 -4px 8px #0006,inset 0 4px 8px #ffffff1a,0 0 20px var(--type-color)}.send-button:active:not(:disabled){transform:scale(.95)}.send-button:disabled{opacity:.5;cursor:not-allowed}.send-ball{font-size:1.25rem;font-weight:800;color:#1a1a2e;text-shadow:none}.relationships-page{padding:1.5rem;padding-bottom:100px}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.75rem;margin:0 0 .25rem;color:#fff}.page-header p{color:#ffffff80;margin:0}section{margin-bottom:2.5rem}section h2{margin:0 0 1rem;color:#fff}.section-desc{color:#ffffff80;margin:0 0 1rem;font-size:.9rem}.crisis-alert{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.crisis-alert h3{color:#ef4444;margin:0 0 1rem}.crisis-alert>p{color:#fffc;font-size:1rem;line-height:1.6;max-width:400px;margin-bottom:1.5rem}.crisis-resources{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.crisis-resources a{color:#22c55e;text-decoration:none;font-weight:600;font-size:1rem}.crisis-alert button{padding:.75rem 1.5rem;font-size:.9rem;background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:8px;color:#fff9;cursor:pointer}.type-selector{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:16px;padding:1.5rem;box-shadow:var(--glass-shadow)}.selector-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.selector-group{display:flex;flex-direction:column;gap:.5rem}.selector-group label{font-size:.85rem;color:#fff9}.selector-group select{padding:.75rem;font-size:.9rem;background:#00000040;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border-subtle);border-radius:8px;color:#fff;cursor:pointer;transition:border-color .2s}.selector-group select:focus{border-color:var(--type-color);outline:none}.selector-group select option{background:#1a1a2e}.category-tabs{display:flex;gap:.5rem}.category-tabs button{flex:1;padding:.75rem;font-size:.9rem;background:var(--glass-bg-subtle);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border-subtle);border-radius:8px;color:#fff9;cursor:pointer;transition:all .2s}.category-tabs button:hover{border-color:var(--glass-border);background:var(--glass-bg)}.category-tabs button.active{background:color-mix(in srgb,var(--type-color) 70%,transparent);border-color:color-mix(in srgb,var(--type-color) 40%,transparent);color:#fff}.compatibility-results{display:grid;gap:1rem}.result-card{padding:1.25rem;border-radius:16px;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);box-shadow:var(--glass-shadow)}.result-card.spark{background:#22c55e14;border:1px solid rgba(34,197,94,.2)}.result-card.snag{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.result-card.neutral{background:var(--glass-bg);border:1px solid var(--glass-border-subtle)}.result-card h3{margin:0 0 .5rem;color:#fff}.result-card p{margin:0;font-size:.95rem;color:#fffc;line-height:1.5}.conflict-resolver{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:16px;padding:1.5rem;box-shadow:var(--glass-shadow)}.conflict-input{display:flex;flex-direction:column;gap:.75rem}.conflict-input label{font-size:.9rem;color:#ffffffb3}.conflict-input input,.conflict-input textarea{padding:.875rem;font-size:1rem;background:#0003;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border-subtle);border-radius:10px;color:#fff;font-family:inherit;resize:vertical;transition:border-color .2s,box-shadow .2s}.conflict-input input:focus,.conflict-input textarea:focus{border-color:var(--type-color);box-shadow:0 0 12px color-mix(in srgb,var(--type-color) 18%,transparent);outline:none}.conflict-input input::placeholder,.conflict-input textarea::placeholder{color:#fff6}.conflict-input button{padding:.875rem;font-size:1rem;font-weight:600;background:color-mix(in srgb,var(--type-color) 70%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid color-mix(in srgb,var(--type-color) 35%,transparent);border-radius:10px;color:#fff;cursor:pointer;transition:all .2s}.conflict-input button:hover:not(:disabled){background:var(--type-color);box-shadow:0 4px 20px color-mix(in srgb,var(--type-color) 30%,transparent)}.conflict-input button:disabled{opacity:.5;cursor:not-allowed}.translator-response{margin-top:1.5rem;display:grid;gap:1rem}.response-section{padding:1rem;border-radius:12px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.response-section h4{margin:0 0 .5rem;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;color:#ffffff80}.response-section p{margin:0;font-size:.95rem;color:#ffffffe6;line-height:1.5}.response-section.heard{background:#3b82f614;border:1px solid rgba(59,130,246,.2)}.response-section.heard h4{color:#3b82f6}.response-section.meant{background:#a855f714;border:1px solid rgba(168,85,247,.2)}.response-section.meant h4{color:#a855f7}.response-section.tips{background:transparent;padding:0}.tips-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.tip-card{padding:1rem;border-radius:12px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.tip-card.avoid{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.tip-card.avoid h5{color:#ef4444}.tip-card.approach{background:#22c55e14;border:1px solid rgba(34,197,94,.2)}.tip-card.approach h5{color:#22c55e}.tip-card h5{margin:0 0 .5rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.tip-card ul{margin:0;padding-left:1rem;font-size:.85rem;color:#fffc;line-height:1.6}.scripts-section{margin-top:.5rem}.scripts-section h4{margin:0 0 .25rem;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;color:#ffffff80}.scripts-intro{margin:0 0 1rem;font-size:.85rem;color:#fff9}.script-card{padding:1rem;border-radius:12px;margin-bottom:.75rem;position:relative;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.script-card:last-child{margin-bottom:0}.script-label{display:inline-block;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600;padding:.25rem .5rem;border-radius:4px;margin-bottom:.5rem}.script-card.soft{background:#22c55e14;border:1px solid rgba(34,197,94,.2)}.script-card.soft .script-label{background:#22c55e33;color:#22c55e}.script-card.balanced{background:#eab30814;border:1px solid rgba(234,179,8,.2)}.script-card.balanced .script-label{background:#eab30833;color:#eab308}.script-card.direct{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.script-card.direct .script-label{background:#ef444433;color:#ef4444}.script-card p{margin:0;font-size:.95rem;font-style:italic;color:#ffffffe6;line-height:1.5}.roleplay-section{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:16px;padding:1.5rem;box-shadow:var(--glass-shadow)}.roleplay-start{text-align:center;padding:1rem 0}.start-roleplay-btn{padding:1rem 2rem;font-size:1rem;font-weight:600;background:color-mix(in srgb,var(--type-color) 70%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid color-mix(in srgb,var(--type-color) 35%,transparent);border-radius:12px;color:#fff;cursor:pointer;transition:all .2s}.start-roleplay-btn:hover:not(:disabled){transform:scale(1.02);background:var(--type-color);box-shadow:0 4px 24px color-mix(in srgb,var(--type-color) 30%,transparent)}.start-roleplay-btn:disabled{opacity:.5;cursor:not-allowed}.helper-text{margin:.75rem 0 0;font-size:.85rem;color:#ffffff80}.roleplay-chat{display:flex;flex-direction:column;gap:1rem}.roleplay-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.75rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.08)}.roleplay-info{display:flex;flex-direction:column;gap:.5rem}.roleplay-type{font-size:.9rem;font-weight:600;color:#fff}.escalation-indicator{font-size:.75rem;padding:.25rem .5rem;border-radius:4px;font-weight:600;display:inline-block;width:fit-content}.escalation-indicator.level-0{background:#22c55e33;color:#22c55e}.escalation-indicator.level-1{background:#eab30833;color:#eab308}.escalation-indicator.level-2{background:#f9731633;color:#f97316}.escalation-indicator.level-3{background:#ef444433;color:#ef4444}.roleplay-controls{display:flex;align-items:center;gap:1rem}.feedback-toggle{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#ffffffb3;cursor:pointer}.feedback-toggle input{accent-color:var(--type-color)}.end-roleplay-btn{padding:.5rem 1rem;font-size:.85rem;background:#ef444426;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#ef4444;cursor:pointer}.roleplay-messages{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;padding:.5rem;background:#00000026;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border-subtle);border-radius:12px}.roleplay-message.system{text-align:center}.system-message{font-size:.85rem;color:#fff9;padding:.5rem 1rem;background:var(--glass-bg-subtle);border-radius:8px;font-style:italic}.roleplay-message.me{align-self:flex-end;max-width:80%}.roleplay-message.them{align-self:flex-start;max-width:80%}.message-bubble{padding:.75rem 1rem;border-radius:12px}.roleplay-message.me .message-bubble{background:color-mix(in srgb,var(--type-color) 70%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px 12px 4px}.roleplay-message.them .message-bubble{background:var(--glass-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border-subtle);border-radius:12px 12px 12px 4px}.message-sender{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem;opacity:.7}.message-bubble p{margin:0;font-size:.9rem;line-height:1.5;color:#fff}.message-feedback{display:flex;gap:.5rem;margin-top:.25rem}.feedback-trigger,.feedback-softspot{font-size:.7rem;padding:.2rem .4rem;border-radius:4px}.feedback-trigger{background:#ef444433;color:#ef4444}.feedback-softspot{background:#22c55e33;color:#22c55e}.input-warnings{display:flex;flex-direction:column;gap:.5rem}.warning{padding:.5rem .75rem;border-radius:8px;font-size:.8rem;line-height:1.4;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.warning.trigger,.warning.specific{background:#ef444414;border:1px solid rgba(239,68,68,.2);color:#fca5a5}.warning.positive{background:#22c55e14;border:1px solid rgba(34,197,94,.2);color:#86efac}.roleplay-input{display:flex;gap:.5rem}.roleplay-input input{flex:1;padding:.875rem 1rem;font-size:1rem;background:#0003;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border-subtle);border-radius:24px;color:#fff;transition:border-color .2s,box-shadow .2s}.roleplay-input input:focus{border-color:var(--type-color);box-shadow:0 0 12px color-mix(in srgb,var(--type-color) 18%,transparent);outline:none}.roleplay-input input::placeholder{color:#fff6}.roleplay-input button{padding:.875rem 1.5rem;font-size:1rem;font-weight:600;background:color-mix(in srgb,var(--type-color) 70%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid color-mix(in srgb,var(--type-color) 35%,transparent);border-radius:24px;color:#fff;cursor:pointer;transition:all .2s}.roleplay-input button:hover:not(:disabled){background:var(--type-color);box-shadow:0 4px 16px color-mix(in srgb,var(--type-color) 30%,transparent)}.roleplay-input button:disabled{opacity:.5;cursor:not-allowed}.profile-page{padding:1.5rem;padding-bottom:100px}.profile-header{text-align:center;margin-bottom:2rem}.avatar{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 4px 20px #0000004d,0 0 30px color-mix(in srgb,var(--type-color, #a855f7) 20%,transparent);border:2px solid var(--glass-border)}.avatar span{font-size:2.5rem;font-weight:700;color:#fff}.profile-header h1{font-size:1.5rem;margin:0 0 .25rem;color:#fff}.profile-header p{color:#ffffff80;margin:0}section{margin-bottom:2rem}section h2{font-size:1.1rem;margin:0 0 1rem;color:#fff}.progress-section{text-align:center}.progress-ring-container{position:relative;width:140px;height:140px;margin:0 auto;background:var(--glass-bg-subtle);border-radius:50%;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border-subtle);padding:8px}.progress-ring{width:100%;height:100%}.progress-ring-fill{transition:stroke-dasharray .5s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.progress-text .percentage{display:block;font-size:1.75rem;font-weight:700;color:#fff}.progress-text .label{display:block;font-size:.75rem;color:#ffffff80}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:12px;padding:1rem;text-align:center;box-shadow:var(--glass-shadow)}.stat-value{display:block;font-size:1.75rem;font-weight:700;color:var(--type-color)}.stat-label{display:block;font-size:.8rem;color:#ffffff80;margin-top:.25rem}.badges-grid{display:grid;gap:1rem}.badge-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--glass-shadow)}.badge-card.locked{opacity:.5}.badge-card.earned{border-color:color-mix(in srgb,var(--type-color) 50%,transparent);background:color-mix(in srgb,var(--type-color) 8%,transparent);box-shadow:0 0 20px color-mix(in srgb,var(--type-color) 15%,transparent),var(--glass-shadow)}.badge-icon{font-size:2rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--glass-bg-subtle);border-radius:12px;border:1px solid var(--glass-border-subtle)}.badge-card h3{font-size:1rem;margin:0 0 .25rem;color:#fff}.badge-card p{font-size:.8rem;margin:0;color:#ffffff80}.summary-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:16px;padding:1rem;box-shadow:var(--glass-shadow)}.summary-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.summary-row:last-child{border-bottom:none;padding-bottom:0}.summary-label{color:#ffffff80;font-size:.9rem}.summary-value{color:#fff;font-size:.9rem;text-align:right;max-width:60%}.ai-settings-section{margin-top:2rem}.ai-settings-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border-subtle);border-radius:16px;padding:1.25rem;box-shadow:var(--glass-shadow)}.ai-status{font-size:.85rem;color:var(--type-color);margin-bottom:1.25rem;padding:.5rem .75rem;background:color-mix(in srgb,var(--type-color) 8%,transparent);border:1px solid color-mix(in srgb,var(--type-color) 25%,transparent);border-radius:8px;text-align:center}.ai-label{display:block;font-size:.8rem;color:#ffffff80;margin-bottom:.5rem;margin-top:1rem}.provider-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.provider-btn{padding:.6rem .5rem;font-size:.8rem;background:var(--glass-bg-subtle);border:1px solid var(--glass-border-subtle);border-radius:10px;color:#ffffffb3;cursor:pointer;transition:all .2s}.provider-btn.active{border-color:var(--type-color);background:color-mix(in srgb,var(--type-color) 12%,transparent);color:#fff;box-shadow:0 0 12px color-mix(in srgb,var(--type-color) 20%,transparent)}.key-input-row{display:flex;gap:.5rem}.ai-input{flex:1;padding:.65rem .75rem;font-size:.9rem;background:#ffffff0d;border:1px solid var(--glass-border-subtle);border-radius:10px;color:#fff;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box}.ai-input:focus{border-color:var(--type-color)}.ai-input::placeholder{color:#ffffff40}.toggle-key-btn{padding:.65rem .75rem;font-size:.8rem;background:var(--glass-bg-subtle);border:1px solid var(--glass-border-subtle);border-radius:10px;color:#fff9;cursor:pointer;white-space:nowrap}.key-help-link{display:inline-block;font-size:.75rem;color:var(--type-color);margin-top:.4rem;opacity:.8}.ai-btn-row{display:flex;gap:.75rem;margin-top:1.25rem}.ai-save-btn{flex:1;padding:.7rem;font-size:.9rem;background:color-mix(in srgb,var(--type-color) 15%,transparent);border:1px solid color-mix(in srgb,var(--type-color) 40%,transparent);border-radius:10px;color:#fff;cursor:pointer;transition:all .2s}.ai-save-btn:hover{background:color-mix(in srgb,var(--type-color) 25%,transparent)}.ai-clear-btn{padding:.7rem 1.25rem;font-size:.9rem;background:#ffffff0d;border:1px solid var(--glass-border-subtle);border-radius:10px;color:#fff9;cursor:pointer;transition:all .2s}.ai-clear-btn:hover{background:#ffffff1a}.settings-section{margin-top:3rem}.reset-btn{width:100%;padding:1rem;font-size:1rem;background:#ef444414;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#ef4444;cursor:pointer;transition:all .2s}.reset-btn:hover{background:#ef444426;box-shadow:0 0 16px #ef444426}.app{min-height:100vh;background:#0a0a1a;position:relative;overflow:hidden}.app:before{content:"";position:fixed;inset:0;z-index:0;background:radial-gradient(ellipse 80% 60% at 10% 20%,color-mix(in srgb,var(--type-color, #a855f7) 18%,transparent) 0%,transparent 70%),radial-gradient(ellipse 60% 80% at 85% 75%,color-mix(in srgb,var(--type-color, #a855f7) 12%,transparent) 0%,transparent 70%),radial-gradient(ellipse 50% 50% at 50% 50%,rgba(88,28,135,.08) 0%,transparent 70%),radial-gradient(ellipse 70% 40% at 70% 10%,rgba(30,64,175,.1) 0%,transparent 60%);animation:gradientShift 20s ease-in-out infinite alternate;pointer-events:none}@keyframes gradientShift{0%{transform:translate(0) scale(1)}33%{transform:translate(-2%,1%) scale(1.02)}66%{transform:translate(1%,-1%) scale(.99)}to{transform:translate(-1%,2%) scale(1.01)}}.main-content{min-height:100vh;overflow-y:auto;position:relative;z-index:1}
