:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;min-width:320px}a{color:inherit}button{font-family:inherit}:root{--bg: #f7fafc;--panel: #ffffff;--muted: #475569;--text: #1f2937;--primary: #2563eb;--primary-600: #1e40af;--border: #e5e7eb}body{background:var(--bg);color:var(--text)}.app-container{display:flex;min-height:100dvh;flex-direction:column}.app-main{flex:1}.container{width:min(960px,92vw);margin:0 auto}.page{padding:16px}.header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.header-inner{display:flex;justify-content:space-between;align-items:center;padding:12px 0}.brand{color:var(--text);font-weight:700;text-decoration:none}.nav a{color:var(--muted);margin-left:16px;text-decoration:none}.nav a.active{color:var(--text);font-weight:600}.footer{border-top:1px solid var(--border);padding:16px 0;text-align:center;color:var(--muted);background:#fff}.btn{background:#fff;color:var(--text);border:2px solid var(--border);border-radius:12px;padding:12px 20px;text-decoration:none;display:inline-block;font-weight:600;font-size:14px;transition:all .3s ease;cursor:pointer;box-shadow:0 2px 4px #0000000d}.btn:hover{background:#f8fafc;border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 8px #0000001a}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 2px 4px #0000000d}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-600);border-color:var(--primary-600);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.actions{display:flex;gap:12px;margin-top:16px}.list{line-height:1.9;color:var(--muted)}.question-card,.result-card,.info-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 4px 6px #0000000d;transition:box-shadow .3s ease}.question-card:hover{box-shadow:0 8px 25px #0000001a}.question-title{font-size:18px;margin-bottom:6px}.question-help{color:var(--muted);margin-bottom:12px;font-size:14px}.question-input input{background:#fff;color:var(--text);border:2px solid var(--border);border-radius:12px;padding:14px 16px;min-width:260px;font-size:16px;font-weight:500;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.question-input input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;transform:translateY(-1px)}.question-input input:hover{border-color:var(--primary);box-shadow:0 4px 8px #0000001a}.custom-select{width:100%}.custom-select-label{font-size:14px;font-weight:600;color:var(--muted);margin-bottom:12px}.custom-select-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;width:100%}.custom-select-option{background:#fff;border:2px solid var(--border);border-radius:12px;padding:16px 20px;text-align:left;cursor:pointer;transition:all .3s ease;font-size:15px;font-weight:500;color:var(--text);position:relative;min-height:60px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 4px #0000000d;font-family:inherit}.custom-select-option:hover{border-color:var(--primary);background:#f8fafc;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.custom-select-option.selected{border-color:var(--primary);background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb40}.custom-select-option.selected:hover{background:var(--primary-600);border-color:var(--primary-600)}.custom-select-option.disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:0 2px 4px #0000000d!important}.option-text{flex:1;line-height:1.4}.option-check{font-size:18px;font-weight:700;margin-left:8px;opacity:.9}@media (max-width: 768px){.custom-select-options{grid-template-columns:1fr;gap:8px}.custom-select-option{min-height:50px;padding:14px 16px;font-size:14px}}.error{color:#b91c1c;margin-top:10px}.progress{margin:10px 0 16px}.progress-info{display:flex;justify-content:space-between;color:var(--muted);font-size:14px;margin-bottom:6px}.progress-bar{height:10px;background:#f1f5f9;border-radius:999px;overflow:hidden;border:1px solid var(--border)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#38bdf8);width:0}.hero-section{text-align:center;padding:60px 0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:0 0 20px 20px}.hero-title{font-size:48px;font-weight:700;margin-bottom:16px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.hero-subtitle{font-size:20px;margin-bottom:16px;opacity:.9}.hero-description{font-size:16px;line-height:1.6;margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto;opacity:.9}.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.section-title{text-align:center;font-size:32px;font-weight:600;margin-bottom:40px;color:var(--text)}.features-section{padding:60px 0}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1200px;margin:0 auto}.feature-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:32px 24px;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001a}.feature-icon{font-size:48px;margin-bottom:16px}.feature-card h3{font-size:20px;font-weight:600;margin-bottom:12px;color:var(--text)}.feature-card p{color:var(--muted);line-height:1.6}.process-section{padding:60px 0;background:#f8fafc}.process-steps{display:flex;justify-content:center;gap:40px;max-width:900px;margin:0 auto;flex-wrap:wrap}.step{display:flex;align-items:center;gap:16px;flex:1;min-width:250px}.step-number{width:48px;height:48px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:20px;flex-shrink:0}.step-content h3{font-size:18px;font-weight:600;margin-bottom:8px;color:var(--text)}.step-content p{color:var(--muted);line-height:1.5}.stats-section{padding:60px 0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;max-width:800px;margin:0 auto}.stat-item{text-align:center}.stat-number{font-size:48px;font-weight:700;color:var(--primary);margin-bottom:8px}.stat-label{color:var(--muted);font-size:16px;font-weight:500}.benefits-section{padding:60px 0;background:#f8fafc}.benefits-list{max-width:800px;margin:0 auto;display:grid;gap:20px}.benefit-item{display:flex;align-items:flex-start;gap:16px;background:#fff;padding:24px;border-radius:12px;border:1px solid var(--border)}.benefit-icon{font-size:24px;flex-shrink:0;margin-top:4px}.benefit-text h4{font-size:18px;font-weight:600;margin-bottom:8px;color:var(--text)}.benefit-text p{color:var(--muted);line-height:1.5}.cta-section{padding:60px 0;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-top:40px;border-radius:20px 20px 0 0}.cta-section h2{font-size:32px;font-weight:600;margin-bottom:16px}.cta-section p{font-size:18px;margin-bottom:32px;opacity:.9}.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.btn.large{padding:14px 28px;font-size:16px;font-weight:600}.btn.secondary{background:transparent;color:#fff;border:2px solid white}.btn.secondary:hover{background:#fff;color:var(--primary)}.happiness-score-card{background:var(--panel);border:2px solid #e5e7eb;border-radius:20px;padding:40px 32px;text-align:center;margin-bottom:24px;box-shadow:0 8px 25px #0000001a;transition:all .3s ease}.happiness-score-card:hover{transform:translateY(-2px);box-shadow:0 12px 35px #00000026}.score-emoji{font-size:64px;margin-bottom:16px;line-height:1}.score-main{margin-bottom:20px}.score-number{font-size:72px;font-weight:800;line-height:1;margin-bottom:8px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.score-level{font-size:28px;font-weight:600;margin-bottom:4px}.score-description{font-size:16px;color:var(--muted);line-height:1.5;max-width:400px;margin:0 auto}.result-row{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid #f3f4f6;font-size:16px}.result-row:last-child{border-bottom:none}.result-row span{color:var(--muted);font-weight:500}.result-row strong{font-weight:600;font-size:16px}.recommendations-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:0 4px 6px #0000000d}.recommendations-card h3{margin-bottom:20px;color:var(--text);font-size:20px;font-weight:600}.recommendation{display:flex;gap:16px;align-items:flex-start}.rec-icon{font-size:28px;flex-shrink:0;margin-top:4px}.rec-content h4{font-size:18px;font-weight:600;margin-bottom:12px;color:var(--text)}.rec-content ul{margin:0;padding-left:20px;color:var(--muted);line-height:1.6}.rec-content li{margin-bottom:8px}.rec-content li:last-child{margin-bottom:0}.info-card{margin-bottom:24px}.info-card h3{margin-bottom:16px;color:var(--text);font-size:18px;font-weight:600}.info-card div{padding:8px 0;color:var(--muted);border-bottom:1px solid #f3f4f6}.info-card div:last-child{border-bottom:none}@media (max-width: 768px){.hero-title{font-size:36px}.hero-actions{flex-direction:column;align-items:center}.process-steps{flex-direction:column;gap:24px}.step{min-width:auto}.features-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.cta-actions{flex-direction:column;align-items:center}.question-input input{min-width:100%;font-size:16px}.question-card{padding:20px}.actions{flex-direction:column;gap:8px}.btn{width:100%;text-align:center}.happiness-score-card{padding:32px 20px;margin-bottom:20px}.score-emoji{font-size:48px;margin-bottom:12px}.score-number{font-size:56px}.score-level{font-size:22px}.score-description{font-size:14px}.result-row{flex-direction:column;align-items:flex-start;gap:8px;padding:12px 0}.result-row span{font-size:14px}.result-row strong{font-size:15px}.recommendation{flex-direction:column;gap:12px}.rec-icon{align-self:flex-start;margin-top:0}.rec-content h4{font-size:16px}.rec-content ul{padding-left:16px}}
