:root{--bg: #0a0a0f;--surface: #111118;--surface2: #18181f;--surface3: #1e1e28;--border: #252530;--border-hover: #35354a;--accent: #7fff6e;--accent2: #4fc3f7;--accent3: #ff6b9d;--text: #e8e8f0;--text-secondary: #a0a0b8;--muted: #6b6b80;--error: #ff5252;--success: #7fff6e;--warning: #ffb347;--font-display: "Syne", sans-serif;--font-mono: "DM Mono", monospace;--font-serif: "Instrument Serif", serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 100px;--shadow-glow: 0 0 32px rgba(127, 255, 110, .15);--shadow-glow-lg: 0 0 60px rgba(127, 255, 110, .25);--shadow-card: 0 4px 24px rgba(0, 0, 0, .3);--shadow-deep: 0 20px 60px rgba(0, 0, 0, .5);--transition-fast: .2s ease;--transition-base: .3s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-mono);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:0;opacity:.5}.orb{position:fixed;border-radius:50%;filter:blur(120px);pointer-events:none;z-index:0;opacity:.12}.orb1{width:600px;height:600px;background:var(--accent);top:-200px;left:-200px;animation:float1 12s ease-in-out infinite}.orb2{width:400px;height:400px;background:var(--accent2);bottom:-100px;right:-100px;animation:float2 15s ease-in-out infinite}.orb3{width:300px;height:300px;background:var(--accent3);top:50%;left:50%;animation:float3 10s ease-in-out infinite}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@keyframes float1{0%,to{transform:translate(0)}50%{transform:translate(60px,40px)}}@keyframes float2{0%,to{transform:translate(0)}50%{transform:translate(-40px,-60px)}}@keyframes float3{0%,to{transform:translate(-50%,-50%)}50%{transform:translate(-45%,-55%)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.badge{display:inline-flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-full);padding:6px 14px;font-size:11px;color:var(--muted)}.badge .dot{width:6px;height:6px;border-radius:50%;background:var(--muted)}.badge.active .dot{background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 2s infinite}.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:.02em;cursor:pointer;border:none;transition:all var(--transition-fast);text-decoration:none;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:.05}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:disabled:after{display:none}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover:not(:disabled){box-shadow:0 0 32px #7fff6e66}.btn-secondary{background:var(--surface2);border:1px solid var(--border);color:var(--text)}.btn-secondary:hover{border-color:var(--muted)}.btn-ghost{background:none;border:1px solid var(--border);color:var(--muted);font-size:12px;padding:8px 16px}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:#ff525226;border:1px solid rgba(255,82,82,.3);color:var(--error)}.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}.spinner{width:16px;height:16px;border:2px solid rgba(127,255,110,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.alert{border-radius:var(--radius-md);padding:14px 18px;font-size:12px;line-height:1.6;margin-bottom:16px;display:flex;gap:10px;align-items:flex-start}.alert-info{background:#4fc3f714;border:1px solid rgba(79,195,247,.2);color:var(--accent2)}.alert-success{background:#7fff6e14;border:1px solid rgba(127,255,110,.2);color:var(--accent)}.alert-warn{background:#ffb34714;border:1px solid rgba(255,179,71,.2);color:var(--warning)}.alert-error{background:#ff525214;border:1px solid rgba(255,82,82,.2);color:var(--error)}.tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--surface2);padding:4px;border-radius:var(--radius-md)}.tab{flex:1;padding:10px;text-align:center;font-size:12px;cursor:pointer;border-radius:var(--radius-sm);color:var(--muted);transition:all var(--transition-fast);border:none;background:none;font-family:var(--font-mono)}.tab.active{background:var(--surface);color:var(--text)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}.toggle-label{font-size:13px}.toggle-sub{font-size:11px;color:var(--muted);margin-top:2px}.toggle{width:44px;height:24px;background:var(--border);border-radius:12px;position:relative;cursor:pointer;transition:background var(--transition-base);flex-shrink:0;border:none}.toggle.on{background:var(--accent)}.toggle:after{content:"";position:absolute;width:18px;height:18px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform var(--transition-base)}.toggle.on:after{transform:translate(20px)}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:32px}.template-card{border:2px solid var(--border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:border-color var(--transition-base),transform var(--transition-fast),box-shadow var(--transition-base);background:var(--surface);text-align:center;position:relative;overflow:hidden}.template-card:hover{border-color:var(--accent2);transform:translateY(-3px)}.template-card.selected{border-color:var(--accent);box-shadow:0 0 24px #7fff6e26}.template-card.selected:after{content:"✓";position:absolute;top:8px;right:8px;width:20px;height:20px;background:var(--accent);color:#000;border-radius:50%;font-size:11px;display:flex;align-items:center;justify-content:center;font-weight:700}.template-preview{width:100%;aspect-ratio:.71;border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden}.template-name{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.model-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:center;gap:16px;margin-bottom:16px}.model-icon{width:48px;height:48px;background:var(--surface2);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.model-info{flex:1}.model-name{font-family:var(--font-display);font-size:15px;font-weight:700;margin-bottom:2px}.model-meta{font-size:11px;color:var(--muted)}.model-status{font-size:11px;color:var(--muted);text-align:right}.model-status.ready{color:var(--accent)}.model-status.loading{color:var(--accent2)}.json-preview{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;font-size:11px;line-height:1.7;max-height:300px;overflow-y:auto;scrollbar-width:thin;color:var(--muted);margin-bottom:24px}.json-key{color:var(--accent2)}.json-str{color:var(--accent)}.json-num{color:var(--accent3)}.cv-preview-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;margin-bottom:24px}#cvPreviewCanvas{width:100%;border-radius:var(--radius-md);box-shadow:0 20px 60px #00000080;display:block}.app{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 24px 80px}header{padding:48px 0 40px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;border-bottom:1px solid var(--border);margin-bottom:48px}.logo-tag{font-family:var(--font-mono);font-size:10px;color:var(--accent);letter-spacing:.2em;text-transform:uppercase;margin-bottom:8px}.logo-title{font-family:var(--font-display);font-size:clamp(36px,6vw,64px);font-weight:800;line-height:.95;letter-spacing:-.03em;color:var(--text)}.logo-title span{color:var(--accent)}.logo-sub{font-family:var(--font-serif);font-size:16px;font-style:italic;color:var(--muted);margin-top:8px}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;padding-top:8px}.header-badges{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.header-user{display:flex;align-items:center;gap:10px;margin-top:8px}.header-user-name{font-size:12px;color:var(--accent);font-weight:600}.header-user-btn{background:none;border:1px solid var(--border);color:var(--muted);padding:4px 12px;border-radius:var(--radius-sm);font-size:10px;cursor:pointer;font-family:var(--font-mono);transition:all var(--transition-fast)}.header-user-btn:hover{border-color:var(--error);color:var(--error)}.pipeline{display:flex;align-items:center;gap:0;overflow-x:auto;padding:20px 0;margin-bottom:48px;scrollbar-width:none}.pipeline::-webkit-scrollbar{display:none}.pipe-step{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:100px;position:relative;opacity:.35;transition:opacity var(--transition-slow)}.pipe-step.active{opacity:1}.pipe-step.done{opacity:.7}.pipe-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:20px;transition:border-color var(--transition-slow),box-shadow var(--transition-slow)}.pipe-step.active .pipe-icon{border-color:var(--accent);box-shadow:0 0 20px #7fff6e33}.pipe-step.done .pipe-icon{border-color:var(--accent2);background:#4fc3f714}.pipe-label{font-size:9px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;text-align:center;max-width:90px;line-height:1.3}.pipe-arrow{color:var(--border);font-size:18px;padding:0 4px;margin-top:-28px;flex-shrink:0}.section{display:none;animation:fadeUp var(--transition-slow)}.section.visible{display:block}.section-label{font-size:10px;color:var(--accent);letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px}.section-title{font-family:var(--font-display);font-size:28px;font-weight:700;margin-bottom:8px}.section-desc{color:var(--muted);font-size:13px;line-height:1.7;margin-bottom:32px}@media(max-width:768px){header{flex-direction:column}.header-right{align-items:flex-start}}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-xl);padding:64px 32px;text-align:center;cursor:pointer;transition:border-color var(--transition-base),background var(--transition-base);background:var(--surface);position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(127,255,110,.04) 0%,transparent 70%);pointer-events:none}.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent);background:#7fff6e08}.upload-icon{font-size:48px;margin-bottom:16px}.upload-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:8px}.upload-sub{color:var(--muted);font-size:12px}.upload-privacy{margin-top:16px;display:inline-flex;align-items:center;gap:6px;background:#7fff6e14;border:1px solid rgba(127,255,110,.2);border-radius:var(--radius-full);padding:4px 12px;font-size:11px;color:var(--accent)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}@media(max-width:640px){.form-grid{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full{grid-column:1/-1}label{font-size:10px;color:var(--muted);letter-spacing:.15em;text-transform:uppercase}input,textarea,select{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--text);font-family:var(--font-mono);font-size:13px;transition:border-color var(--transition-base);outline:none;width:100%}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #7fff6e14}textarea{resize:vertical;min-height:100px}select option{background:var(--surface2)}.repeater{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.repeater-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;position:relative}.repeater-item .remove-btn{position:absolute;top:12px;right:12px;background:none;border:1px solid var(--border);color:var(--muted);width:24px;height:24px;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.repeater-item .remove-btn:hover{border-color:var(--error);color:var(--error)}.progress-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.progress-title{font-family:var(--font-display);font-size:16px;font-weight:700}.progress-pct{color:var(--accent);font-size:13px}.progress-bar{height:4px;background:var(--surface2);border-radius:2px;overflow:hidden;margin-bottom:16px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;transition:width .5s ease;width:0%}.log-stream{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:16px;max-height:200px;overflow-y:auto;font-size:11px;line-height:1.8;color:var(--muted);scrollbar-width:thin;scrollbar-color:var(--border) transparent}.log-line{display:flex;gap:8px}.log-time{color:var(--border);flex-shrink:0}.log-line.info .log-text{color:var(--muted)}.log-line.success .log-text{color:var(--accent)}.log-line.ai .log-text{color:var(--accent2)}.log-line.warn .log-text{color:var(--warning)}.log-line.error .log-text{color:var(--error)}.ai-output{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}.ai-output-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.ai-badge{background:#4fc3f71a;border:1px solid rgba(79,195,247,.3);color:var(--accent2);font-size:10px;padding:3px 10px;border-radius:var(--radius-full);letter-spacing:.1em;text-transform:uppercase}.ai-text{font-family:var(--font-mono);font-size:12px;line-height:1.9;color:var(--text);white-space:pre-wrap;max-height:300px;overflow-y:auto;scrollbar-width:thin}.cursor-blink{display:inline-block;width:8px;height:14px;background:var(--accent);animation:blink .8s step-end infinite;vertical-align:text-bottom;margin-left:2px}.auth-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.auth-backdrop.open{opacity:1;pointer-events:all}.auth-box{background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:40px;max-width:420px;width:90vw;transform:scale(.95);transition:transform var(--transition-base);position:relative}.auth-backdrop.open .auth-box{transform:scale(1)}.auth-header{text-align:center;margin-bottom:32px}.auth-icon{font-size:40px;margin-bottom:12px}.auth-title{font-family:var(--font-display);font-size:24px;font-weight:800;margin-bottom:4px}.auth-title span{color:var(--accent)}.auth-subtitle{font-size:12px;color:var(--muted)}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-form .form-group{display:flex;flex-direction:column;gap:6px}.auth-form input{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;color:var(--text);font-family:var(--font-mono);font-size:13px;transition:border-color var(--transition-base);outline:none;width:100%}.auth-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #7fff6e14}.auth-submit{width:100%;padding:16px;margin-top:8px}.auth-error{background:#ff52521a;border:1px solid rgba(255,82,82,.3);color:var(--error);padding:10px 14px;border-radius:var(--radius-sm);font-size:12px;display:none;animation:fadeIn var(--transition-fast)}.auth-error.visible{display:block}.auth-switch{text-align:center;margin-top:20px;font-size:12px;color:var(--muted)}.auth-switch a{color:var(--accent);cursor:pointer;text-decoration:none;font-weight:600}.auth-switch a:hover{text-decoration:underline}.auth-divider{display:flex;align-items:center;gap:12px;margin:8px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-divider span{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--transition-base);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-backdrop.open{opacity:1;pointer-events:all}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:28px;max-width:480px;width:90vw;transform:scale(.95);transition:transform var(--transition-base)}.modal-backdrop.open .modal-box{transform:scale(1)}.modal-title{font-family:var(--font-display);font-size:18px;font-weight:700;margin-bottom:4px}.modal-sub{font-size:11px;color:var(--muted);margin-bottom:20px}.crop-canvas-wrap{position:relative;width:100%;aspect-ratio:1;overflow:hidden;border-radius:var(--radius-lg);border:1px solid var(--border);cursor:crosshair;-webkit-user-select:none;user-select:none;margin-bottom:16px;background:#000}#cropCanvas{display:block;width:100%;height:100%}.crop-zone{position:absolute;border:2px solid var(--accent);box-shadow:0 0 0 9999px #0000008c;cursor:move}.crop-zone.circle{border-radius:50%}.crop-handle{position:absolute;width:12px;height:12px;background:var(--accent);border-radius:50%;transform:translate(-50%,-50%);cursor:nwse-resize}.crop-controls{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.crop-controls label{font-size:10px;color:var(--muted);margin-right:4px}.crop-controls input[type=range]{flex:1;min-width:80px;accent-color:var(--accent)}.modal-footer{display:flex;gap:10px;justify-content:flex-end}.photo-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;margin-bottom:24px;display:flex;gap:28px;align-items:flex-start;flex-wrap:wrap}.photo-left{display:flex;flex-direction:column;align-items:center;gap:14px;flex-shrink:0}.photo-preview-wrap{position:relative;width:110px;height:110px;cursor:pointer}.photo-preview-wrap:hover .photo-overlay{opacity:1}.photo-circle{width:110px;height:110px;border-radius:50%;border:3px solid var(--border);overflow:hidden;background:var(--surface2);display:flex;align-items:center;justify-content:center;transition:border-color var(--transition-base);position:relative}.photo-circle.has-photo{border-color:var(--accent);box-shadow:0 0 20px #7fff6e26}.photo-circle img{width:100%;height:100%;object-fit:cover;display:block}.photo-placeholder{font-size:36px;opacity:.4}.photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast);font-size:22px}.photo-square-preview{width:90px;height:110px;border-radius:var(--radius-sm);border:3px solid var(--border);overflow:hidden;background:var(--surface2);display:none;align-items:center;justify-content:center;transition:border-color var(--transition-base)}.photo-square-preview.has-photo{border-color:var(--accent);display:flex}.photo-square-preview img{width:100%;height:100%;object-fit:cover;display:block}.photo-right{flex:1;min-width:200px}.photo-right-title{font-family:var(--font-display);font-size:15px;font-weight:700;margin-bottom:6px}.photo-right-sub{font-size:11px;color:var(--muted);line-height:1.7;margin-bottom:16px}.photo-shape-row{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.shape-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface2);color:var(--muted);font-size:11px;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-mono)}.shape-btn:hover{border-color:var(--accent2);color:var(--text)}.shape-btn.active{border-color:var(--accent);color:var(--accent);background:#7fff6e0d}.photo-actions{display:flex;gap:8px;flex-wrap:wrap}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px}.history-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all var(--transition-fast)}.history-card:hover{border-color:var(--accent2);transform:translateY(-2px);box-shadow:var(--shadow-card)}.history-card-title{font-family:var(--font-display);font-size:14px;font-weight:700;margin-bottom:4px}.history-card-meta{font-size:11px;color:var(--muted);display:flex;gap:12px;flex-wrap:wrap}.history-card-actions{display:flex;gap:8px;margin-top:12px}
