:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}.app{width:100%;min-height:100vh;display:flex;flex-direction:column;background-color:#fff}.main-content{display:flex;gap:2rem;max-width:1400px;margin:0 auto;padding:2rem;width:100%;align-items:flex-start}.main-content>*{flex:1;min-width:0}@media(max-width:768px){.main-content{flex-direction:column}}.loading-container{display:flex;justify-content:center;align-items:center;min-height:100vh;color:#6b7280;font-size:1.2rem}.todo-container{text-align:center;padding:2rem}.todo-container h1{color:#646cff;font-size:4rem;font-weight:700}.app-header{background-color:#fff;border-bottom:2px solid #ddd6fe;padding:1rem 0}.header-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.header-title-section{display:flex;align-items:center;gap:.75rem}.header-logo{height:40px;width:auto}.app-title{margin:0;font-size:1.5rem;color:#646cff}.auth-section,.user-info{display:flex;align-items:center;gap:1rem}.user-email{color:#6b7280;font-size:.9rem}.auth-button{background-color:#646cff;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.auth-button:hover{background-color:#535bf2}.auth-button:active{background-color:#4248d7}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#fff}.login-box{background-color:#fff;border:2px solid #ddd6fe;border-radius:12px;padding:3rem 4rem;text-align:center;box-shadow:0 4px 6px #646cff1a}.login-header{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2rem}.login-logo{height:60px;width:auto}.login-title{color:#646cff;font-size:3rem;margin:0;font-weight:700}.google-login-button{background-color:#646cff;color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s;min-width:200px}.google-login-button:hover{background-color:#535bf2}.google-login-button:active{background-color:#4248d7}.upload-container{width:100%}.upload-container h2{color:#646cff;margin-bottom:2rem;text-align:center}.current-selfie-section{margin-bottom:2rem;padding:1.5rem;background-color:#faf9ff;border-radius:12px;border:2px solid #ddd6fe}.current-selfie-section h3{color:#646cff;font-size:1.5rem;margin:0 0 1.5rem;text-align:center}.upload-section{display:flex;flex-direction:column;gap:1rem}.current-selfie-section .upload-section{margin-top:1rem}input[type=file]{display:none}.file-label{display:block;padding:.75rem 1.5rem;background-color:#faf9ff;color:#213547;border:2px dashed #c7d2fe;border-radius:8px;cursor:pointer;text-align:center;transition:all .3s ease;width:100%;box-sizing:border-box}.file-label:hover{background-color:#646cff;color:#fff;border-style:solid}.preview-section{margin:1rem 0;text-align:center}.preview-image{max-width:100%;max-height:300px;border-radius:8px;box-shadow:0 4px 6px #0000001a}.upload-button{padding:.75rem 1.5rem;background-color:#646cff;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.generate-button{margin-top:1rem}.upload-button:hover:not(:disabled){background-color:#535bf2;transform:translateY(-2px);box-shadow:0 4px 8px #646cff4d}.upload-button:disabled{background-color:#e5e7eb;color:#9ca3af;cursor:not-allowed;transform:none}.message{padding:1rem;border-radius:8px;margin-top:1rem}.message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.message h3{margin-top:0;margin-bottom:.5rem;font-size:1.1rem}.message p{margin:.25rem 0;font-size:.9rem}.workout-days-container{width:100%;padding:2rem;background-color:#faf9ff;border:2px solid #ddd6fe;border-radius:12px}.workout-days-container h2{color:#646cff;margin:0 0 1.5rem;text-align:center;font-size:1.5rem}.days-grid{display:flex;flex-direction:column;gap:.75rem}.day-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.75rem 1rem;background-color:#fff;border:2px solid #e5e7eb;border-radius:8px;transition:all .2s ease}.day-label:hover{border-color:#c7d2fe;background-color:#faf9ff}.day-checkbox{width:20px;height:20px;cursor:pointer;accent-color:#646cff}.day-checkbox:disabled{cursor:not-allowed;opacity:.5}.day-name{font-size:1rem;color:#213547;font-weight:500;-webkit-user-select:none;user-select:none}.error-message{margin-top:1rem;padding:.75rem;background-color:#fee;color:#c00;border:1px solid #fcc;border-radius:8px;font-size:.9rem}.saving-message{margin-top:1rem;padding:.75rem;background-color:#e0e7ff;color:#4338ca;border:1px solid #c7d2fe;border-radius:8px;font-size:.9rem;text-align:center}
