:root{--midnight: #1a1a2e;--slate-900: #1E293B;--slate-800: #1e3a5f;--slate-700: #334155;--slate-600: #475569;--slate-500: #64748B;--slate-400: #94A3B8;--slate-300: #CBD5E1;--slate-200: #E2E8F0;--slate-100: #F1F5F9;--slate-50: #F8FAFC;--white: #FFFFFF;--page-bg: #f5f7fa;--primary-blue: #2563eb;--primary-blue-dark: #1d4ed8;--primary-blue-light: #dbeafe;--primary-blue-lighter: #eff6ff;--kicker-bg: #f0f4ff;--emerald: #10B981;--emerald-dark: #059669;--emerald-light: #D1FAE5;--rose: #F43F5E;--rose-light: #FFE4E6;--amber-bg: #fef3c7;--amber-text: #92400e;--card-shadow: 0 1px 3px rgba(0, 0, 0, .04), 0 4px 12px rgba(0, 0, 0, .06);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;font-weight:400;color:#374151;line-height:1.6;background-color:var(--page-bg);min-height:100vh}h1{font-size:2.5rem;font-weight:700;color:#111827}h2{font-size:1.375rem;font-weight:700;color:#111827;line-height:1.3}h3{font-size:1rem;font-weight:600;color:#374151}a{color:var(--primary-blue);text-decoration:none}a:hover{text-decoration:underline}code{background:#f3f4f6;padding:2px 6px;border:1px solid #e5e7eb;border-radius:var(--radius-sm);font-size:.8125rem;font-family:Monaco,Consolas,Courier New,monospace;color:#374151}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.emoji-bounce{display:inline-block;animation:bounce 2s ease-in-out infinite}.app-container{min-height:100vh;display:flex;flex-direction:column}.header-bar{background:var(--white);padding:8px 24px}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}.header-logo{flex-shrink:0;padding:0}.logo-image{height:90px;width:auto}.header-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.header-line-1{font-size:.8125rem;font-weight:500;color:#6b7280}.header-line-2{font-size:.75rem;font-weight:700;color:#9ca3af}.kicker-section{background-color:var(--kicker-bg);padding:18px 0;border-bottom:1px solid var(--slate-200);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.kicker-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:var(--slate-800);color:var(--white);border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.kicker-subtext{font-size:.75rem;color:var(--slate-500);margin:0;text-align:center}.kicker-subtext a{color:var(--primary-blue);font-weight:500}.main-content{flex:1;max-width:720px;margin:0 auto;padding:32px 24px 48px;width:100%}.steps-container{display:flex;flex-direction:column;gap:24px}.section-divider{margin:32px 0;text-align:center}.section-divider hr{border:0;border-top:1px solid #E5E7EB;margin:0}.section-divider-content{padding:24px 0}.section-divider-icon{display:block;font-size:1.75rem;margin-bottom:8px}.section-divider h3{margin:0 0 6px;font-size:1rem;font-weight:600;color:#374151}.section-divider p{margin:0;font-size:.875rem;color:#6b7280}.footer{padding:48px 24px;text-align:center;border-top:1px solid #e5e7eb;margin-top:64px;background:var(--white)}.footer-content{display:flex;flex-direction:column;align-items:center;gap:8px}.footer-brand{font-size:1.125rem;font-weight:700;color:#374151}.footer-tagline{font-size:.875rem;color:#6b7280}.step-card{background:var(--white);border:1px solid #e8ecf0;border-radius:var(--radius-xl);padding:28px;box-shadow:var(--card-shadow)}.step-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}.step-number{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;background:var(--primary-blue);color:var(--white);font-size:.9375rem;font-weight:700;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 4px #2563eb1f}.step-number--green{background:var(--emerald);box-shadow:0 0 0 4px #10b9811f}.step-header h2{margin:0;font-size:1.1875rem;font-weight:700;color:#111827}.step-description{color:#374151;margin-bottom:20px;line-height:1.7;font-size:.9375rem}.card-divider{border:0;border-top:1px solid #f0f0f0;margin:20px 0}.upload-area{border:2px dashed #d1d5db;border-radius:var(--radius-lg);padding:40px 24px;text-align:center;transition:all .2s ease;cursor:pointer;margin-bottom:16px;background:#f9fafb}.upload-area:hover,.upload-area.drag-over{border-color:var(--primary-blue);background:var(--primary-blue-lighter)}.upload-area:focus{outline:2px solid var(--primary-blue);outline-offset:2px}.upload-area input[type=file]{display:none}.upload-label{display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer}.upload-icon{font-size:3rem;color:var(--primary-blue-light)}.upload-area:hover .upload-icon{color:var(--primary-blue)}.upload-text{font-size:.9375rem;font-weight:500;color:#374151}.upload-hint{font-size:.8125rem;color:#6b7280}.file-list{background:#f9fafb;border-radius:var(--radius-md);padding:14px;margin-bottom:16px}.file-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.8125rem;font-weight:500;color:#374151}.btn-clear{background:none;border:none;color:var(--rose);font-size:.8125rem;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background .15s ease}.btn-clear:hover{background:var(--rose-light)}.file-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.file-item{display:flex;justify-content:space-between;align-items:center;background:var(--white);padding:8px 12px;border-radius:6px;border:1px solid #e8ecf0}.file-name{font-size:.8125rem;color:#374151;font-family:Monaco,Consolas,monospace}.btn-remove{background:none;border:none;color:#9ca3af;font-size:1.125rem;cursor:pointer;line-height:1;padding:4px 6px;border-radius:var(--radius-sm);transition:all .15s ease}.btn-remove:hover{color:var(--rose);background:var(--rose-light)}.step-actions{display:flex;gap:12px;margin-top:20px}.btn-primary{background:var(--primary-blue);color:var(--white);border:none;padding:10px 20px;font-size:.875rem;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;box-shadow:0 1px 2px #0000000d}.btn-primary:hover:not(:disabled){background:var(--primary-blue-dark);transform:translateY(-1px);box-shadow:0 2px 8px #2563eb4d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{background:#d1d5db;cursor:not-allowed;box-shadow:none}.btn-secondary{background:var(--white);color:#374151;border:1px solid #d1d5db;padding:10px 20px;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.btn-secondary:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-download{background:var(--primary-blue);color:var(--white);border:none;padding:10px 20px;font-size:.875rem;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.btn-download:hover{background:var(--primary-blue-dark);transform:translateY(-1px);box-shadow:0 2px 8px #2563eb4d}.prompt-instructions{background:#f9fafb;border-radius:var(--radius-md);padding:18px 20px;margin-bottom:16px}.prompt-instructions h3{margin:0 0 10px;font-size:.875rem;font-weight:600;color:#374151}.prompt-instructions ol{margin:0;padding-left:20px;line-height:1.8}.prompt-instructions li{margin-bottom:8px;color:#374151;font-size:.875rem}.prompt-instructions li:last-child{margin-bottom:0}.prompt-instructions ul{margin:6px 0 0;padding-left:18px}.prompt-instructions ul li{margin-bottom:4px;list-style-type:disc}.thinking-badge{display:inline-flex;align-items:center;background:var(--amber-bg);color:var(--amber-text);font-size:.6875rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);margin-left:6px;vertical-align:middle;white-space:nowrap}.important-emphasis{font-weight:700;color:#b45309}.download-area{margin-top:16px;padding:18px 20px;background:var(--emerald-light);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;gap:14px}.download-success{display:flex;align-items:center;gap:8px;color:var(--emerald-dark);font-weight:500;font-size:.875rem}.success-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--emerald);color:var(--white);border-radius:50%;font-size:.6875rem;font-weight:700}.output-preview{margin-top:20px;padding:16px 20px;background:#f9fafb;border-radius:8px;border-left:3px solid var(--primary-blue)}.output-preview h3{margin:0 0 10px;font-size:.875rem;font-weight:700;color:#374151}.output-preview ul{margin:0;padding-left:18px;line-height:1.7}.output-preview li{margin-bottom:6px;color:#374151;font-size:.875rem}.output-preview li:last-child{margin-bottom:0}.output-preview strong{color:#111827;font-weight:600}.swim-info-box{margin-bottom:16px;padding:12px;background-color:var(--white);border:1px solid #e5e7eb;border-radius:var(--radius-sm);font-size:.875rem;color:#4b5563}.swim-info-box h4{margin:0 0 6px;font-size:.875rem;font-weight:700;color:#111827}.swim-info-box p{margin:0;line-height:1.5}.error-message{background:var(--rose-light);color:var(--rose);padding:10px 14px;border-radius:var(--radius-md);font-size:.8125rem;margin-bottom:14px;border:1px solid var(--rose)}@media (max-width: 768px){.header-bar{padding:12px 16px}.header-content{flex-direction:column;gap:12px}.header-logo{order:1}.header-meta{order:2;align-items:center}.logo-image{height:48px}.main-content{padding:24px 16px 40px}.step-card{padding:20px}.step-header{gap:12px}.step-number{min-width:32px;height:32px;font-size:.875rem}.step-header h2{font-size:1.0625rem}.step-actions{flex-direction:column}.step-actions button{width:100%}.upload-area{padding:28px 16px}}@media (max-width: 480px){.logo-image{height:40px}.step-number{min-width:28px;height:28px;font-size:.8125rem}.step-header h2{font-size:1rem}.file-item{flex-direction:column;align-items:flex-start;gap:6px}.file-name{word-break:break-all}.prompt-instructions,.output-preview{padding:14px}}
