:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;background-color:#fefefe}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}.app{width:100%;max-width:800px;margin:0 auto;padding:.75rem;box-sizing:border-box}@media (min-width: 768px){.app{padding:1rem}}@media (min-width: 1024px){.app{padding:1.5rem}}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid #ccc}.app-header h1{margin:0;color:#2c3e50}.api-status{font-size:.9rem}.status{padding:.25rem .5rem;border-radius:4px;font-weight:700}.status.connected{background:#d4edda;color:#155724}.status.disconnected{background:#f8d7da;color:#721c24}.status.checking{background:#fff3cd;color:#856404}.app-nav{display:flex;gap:1rem;padding:1rem 0}.app-nav button{padding:.5rem 1rem;border:1px solid #ddd;background:#fff;cursor:pointer;border-radius:4px}.app-nav button.active{background:#007bff;color:#fff;border-color:#007bff}.app-main{padding:2rem 0}.loading{text-align:center;padding:2rem;color:#666}.error{background:#f8d7da;color:#721c24;padding:1rem;border-radius:4px;margin-bottom:1rem}.journey{width:100%}.journey-start{text-align:center;padding:2rem}.button-group{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}@media (max-width: 480px){.button-group{flex-direction:column;gap:.75rem}}.button-group button{padding:.75rem 1.5rem;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}.button-group button:hover{background:#0056b3}.button-group button:disabled{background:#6c757d;cursor:not-allowed}.journey-active{padding:1rem}.progress-section{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.progress-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}@media (max-width: 480px){.progress-header{flex-direction:column;align-items:stretch;gap:.75rem}.reset-button{align-self:flex-end}}.pillar-info h3{margin:0;color:#495057;font-size:1.2rem}.aspect-info{margin:.25rem 0 0;color:#6c757d;font-size:.9rem;font-style:italic}.reset-button{background:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s ease}.reset-button:hover:not(:disabled){background:#c82333}.reset-button:disabled{background:#6c757d;cursor:not-allowed}.progress-bar-container{display:flex;align-items:center;gap:1rem;cursor:help}.progress-bar{flex:1;height:12px;background:#e9ecef;border-radius:6px;overflow:hidden;box-shadow:inset 0 1px 3px #0000001a}.progress-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);border-radius:6px;transition:width .3s ease}.progress-text{font-size:.9rem;font-weight:600;color:#495057;min-width:85px;text-align:right}.current-question{background:#fff;border:1px solid #ddd;border-radius:4px;padding:1.5rem}.current-question h4{margin:0 0 1rem;color:#2c3e50}.guidance{color:#6c757d;font-style:italic;margin-bottom:1rem}.answer-section textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;margin-bottom:1rem;font-family:inherit;background-color:#fff!important;color:#333!important}.answer-section button{background:#28a745;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer}.answer-section button:hover{background:#218838}.answer-section button:disabled{background:#6c757d;cursor:not-allowed}.journey-complete{text-align:center;background:#d1ecf1;padding:2rem;border-radius:4px;margin-top:2rem}.elements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.element-card{border:1px solid #ddd;border-radius:4px;padding:1.5rem;background:#fff}.element-card h3{margin:0 0 .5rem;color:#2c3e50}.pillar{color:#007bff;font-weight:700;margin:0 0 1rem}.description{color:#6c757d;margin-bottom:1rem}.element-actions{display:flex;gap:.5rem;flex-wrap:wrap}.element-actions button{padding:.5rem 1rem;border:1px solid #ddd;background:#fff;cursor:pointer;border-radius:4px;font-size:.875rem}.element-actions button:hover{background:#f8f9fa}.element-details{margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.element-details ul{list-style:none;padding:0}.element-details li{margin-bottom:1rem;padding:.75rem;background:#f8f9fa;border-radius:4px}.generated-content{margin-top:2rem;padding:1.5rem;background:#f8f9fa;border-radius:4px}.generated-content pre{white-space:pre-wrap;font-family:inherit}.app-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.25rem;color:#666}.header-right{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.75rem}.user-info .username{font-size:.9rem;color:#333}.user-info .logout-btn{padding:.25rem .75rem;background:#17a2b8;color:#fff;border:1px solid #17a2b8;border-radius:4px;cursor:pointer;font-size:.85rem}.user-info .logout-btn:hover{background:#138496;border-color:#138496}.auth-form-container{max-width:400px;margin:2rem auto;padding:2rem;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #0000001a}.auth-form-container h2{margin-top:0;margin-bottom:1.5rem;text-align:center;color:#333}.auth-form .form-group{margin-bottom:1rem}.auth-form label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.auth-form input{width:100%;padding:.75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem;background-color:#fff;color:#333}.auth-form input:focus{outline:none;border-color:#4a90d9;box-shadow:0 0 0 2px #4a90d933}.auth-error{padding:.75rem;margin-bottom:1rem;background:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;font-size:.9rem}.auth-submit{width:100%;padding:.75rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;margin-top:.5rem}.auth-submit:hover{background:#3a7bc8}.auth-submit:disabled{background:#aaa;cursor:not-allowed}.auth-toggle{display:block;width:100%;margin-top:1rem;padding:.5rem;background:none;border:none;color:#4a90d9;cursor:pointer;font-size:.9rem}.auth-toggle:hover{text-decoration:underline}
