:root{--color-bg:#f8fafc;--color-surface:#fff;--color-primary:#3b82f6;--color-secondary:#64748b;--color-accent:#f59e0b;--color-success:#10b981;--color-text-main:#1e293b;--color-text-muted:#64748b;--color-blue:#3b82f6;--color-pink:#ec4899;--color-purple:#8b5cf6;--border-radius-sm:8px;--border-radius-md:16px;--border-radius-lg:24px}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--color-text-main);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}#root{flex-direction:column;max-width:800px;min-height:100vh;margin:0 auto;padding:1.5rem;display:flex}h1{margin-bottom:1rem;font-size:2rem;font-weight:700}h2{margin-bottom:.75rem;font-size:1.5rem;font-weight:600}h3{margin-bottom:.5rem;font-size:1.25rem;font-weight:500}.app-container{flex-direction:column;align-items:center;width:100%;display:flex}.card{background-color:var(--color-surface);border-radius:var(--border-radius-md);width:100%;margin-bottom:1.5rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.btn{border-radius:var(--border-radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s ease-in-out;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{color:var(--color-secondary);background-color:#0000;border:1px solid #cbd5e1}.btn-secondary:hover:not(:disabled){background-color:#f1f5f9}.choice-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;width:100%;display:grid}.choice-item{background-color:var(--color-bg);border-radius:var(--border-radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;border:2px solid #0000;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;transition:all .2s;display:flex}.choice-item:hover{background-color:#f1f5f9;transform:translateY(-2px)}.choice-item.selected{border-color:var(--color-primary);background-color:#eff6ff;box-shadow:0 0 0 2px #3b82f633}.choice-icon{font-size:2.5rem}.choice-label{text-align:center;font-size:.9rem;font-weight:500}input[type=text],textarea{border-radius:var(--border-radius-sm);border:1px solid #cbd5e1;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}input[type=text]:focus,textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #3b82f61a}.progress-container{background-color:#e2e8f0;border-radius:4px;width:100%;height:8px;margin-bottom:2rem;overflow:hidden}.progress-fill{background-color:var(--color-primary);border-radius:4px;height:100%;transition:width .3s cubic-bezier(.4,0,.2,1)}.theme-christian{--color-primary:var(--color-blue)}.theme-christian .progress-fill{background-color:var(--color-blue)}.theme-christian .choice-item.selected{border-color:var(--color-blue);background-color:#eff6ff;box-shadow:0 0 0 2px #3b82f633}.theme-giulia{--color-primary:var(--color-pink)}.theme-giulia .progress-fill{background-color:var(--color-pink)}.theme-giulia .choice-item.selected{border-color:var(--color-pink);background-color:#fdf2f8;box-shadow:0 0 0 2px #ec489933}.theme-parent{--color-primary:var(--color-purple)}.theme-parent .progress-fill{background-color:var(--color-purple)}.theme-parent .choice-item.selected{border-color:var(--color-purple);background-color:#f5f3ff;box-shadow:0 0 0 2px #8b5cf633}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;width:100%;display:grid}.high-legibility{--color-text-main:#000;--color-text-muted:#111;--color-bg:#fff;--color-surface:#fff;--color-primary:#00e}.high-legibility .card{box-shadow:none;border:2px solid #000}.high-legibility .choice-item{border:2px solid #000}.high-legibility .choice-item.selected{background-color:#ff0;border-color:#000}:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}@keyframes spin{to{transform:rotate(360deg)}}
