@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600&family=DM+Sans:wght@300;400;500&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{background:#0f1117;color:#e8e4df;font-family:DM Sans,sans-serif;min-height:100vh;padding:28px 16px 60px}h1{font-family:Playfair Display,serif;font-size:clamp(1.4rem,4vw,2rem);text-align:center;letter-spacing:.04em;color:#d4cfc9;margin-bottom:3px}.subtitle{text-align:center;font-size:.75rem;color:#7a8a9a;letter-spacing:.14em;text-transform:uppercase;margin-bottom:28px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:24px;font-family:DM Sans,sans-serif;font-size:.72rem;letter-spacing:.08em;cursor:pointer;border:none;transition:all .2s}.btn-ghost{background:transparent;border:1px solid #2a3a4a;color:#5a7a9a}.btn-ghost:hover{border-color:#4a7fa5;color:#8ab8d4}.btn-primary{background:#4a7fa5;color:#fff}.btn-primary:hover{background:#5a8fb5}.btn-danger{background:transparent;border:1px solid #4a2a2a;color:#a06060}.btn-danger:hover{background:#b43c3c33;color:#d08080}.badge{display:inline-block;font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;padding:2px 9px;border-radius:20px;margin-bottom:9px}.badge-good{background:#4a7fa526;color:#7ab0cc;border:1px solid rgba(74,127,165,.3)}.badge-avoid{background:#b4503c1f;color:#c07878;border:1px solid rgba(180,80,60,.25)}canvas#workCanvas{display:none}@keyframes spin{to{transform:rotate(360deg)}}@keyframes rip{0%{opacity:1;transform:scale(.1)}to{opacity:0;transform:scale(1)}}.spinner{width:32px;height:32px;border:3px solid #2a3a4a;border-top-color:#4a7fa5;border-radius:50%;animation:spin .8s linear infinite}.ripple{position:absolute;border-radius:50%;pointer-events:none;border:2px solid rgba(255,255,255,.7);animation:rip .4s ease-out forwards}.type-card{max-width:520px;margin:0 auto 28px;background:#181b22;border:1px solid #2a2e3a;border-radius:8px;padding:16px 20px;display:flex;align-items:center;gap:14px}.type-icon{width:40px;height:40px;border-radius:50%;flex-shrink:0;background:conic-gradient(#4a7fa5,#6e9ab8,#8fb8cc,#b0c4d4,#7b9db5,#4a7fa5)}.type-label{font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:#7a8a9a;margin-bottom:2px}.type-name{font-family:Playfair Display,serif;font-size:1.15rem;color:#c8d8e4}.type-desc{font-size:.68rem;color:#6a7a8a;margin-top:2px;line-height:1.5}.type-selector{max-width:520px;margin:0 auto 20px;display:flex;flex-direction:column;gap:8px}.type-selector label{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:#5a7a8a}.type-dropdown{width:100%;padding:10px 36px 10px 14px;border-radius:8px;background:#181b22;border:1px solid #2a3a4a;color:#c8d8e4;font-family:DM Sans,sans-serif;font-size:.82rem;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a7fa5' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.type-dropdown:focus{outline:none;border-color:#4a7fa5}.type-dropdown option{background:#181b22}.palette-section{max-width:520px;margin:16px auto 0}.section-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.section-line{flex:1;height:1px;background:#2a2e38}.section-label{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:#5a7a8a;white-space:nowrap}.swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:6px}.swatch{border-radius:6px;overflow:hidden;cursor:pointer;transition:transform .16s,box-shadow .16s}.swatch:hover{transform:translateY(-3px)}.swatch.active{box-shadow:0 0 0 2px #fff,0 0 0 4px #4a7fa5cc;transform:translateY(-3px) scale(1.05)}.avoid-section .swatch.active{box-shadow:0 0 0 2px #fff,0 0 0 4px #c8503ccc}.swatch-color{height:46px;width:100%;position:relative}.swatch-color:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.07) 0%,transparent 60%)}.avoid-section .swatch-color:before{content:"✕";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.85rem;color:#fff6;z-index:1}.swatch-name{font-size:.52rem;letter-spacing:.04em;text-transform:uppercase;padding:3px 2px;text-align:center;background:#181b22;color:#8a929e;line-height:1.3}#viewMode{max-width:420px;margin:0 auto}.stage-border{border-radius:12px;padding:3px;background:linear-gradient(135deg,#4a7fa5,#6e9ab8,#b0c4d4,#556f8a,#4a7fa5);box-shadow:0 0 28px #4a7fa54d}.stage{border-radius:10px;overflow:hidden;position:relative;width:100%;aspect-ratio:3/4}#colorBg{position:absolute;top:0;right:0;bottom:0;left:0;transition:background-color .35s ease;background-color:#1a1f2a}#faceImg{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:92%;max-height:98%;object-fit:contain;object-position:bottom center;display:none;z-index:2}#uploadZone{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;z-index:3;border:2px dashed #2a3a4a;border-radius:10px;transition:border-color .2s,background .2s}#uploadZone:hover,#uploadZone.drag-over{border-color:#4a7fa5;background:#4a7fa50f}.upload-icon{font-size:2rem;color:#3a5a78}.upload-text{font-size:.8rem;color:#6a8a9a}.upload-sub{font-size:.62rem;color:#3a5a6a}#fileInput{display:none}#procOverlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f1117e6;display:none;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:5;border-radius:10px}.proc-text{font-size:.68rem;color:#7a9ab0;letter-spacing:.1em;text-transform:uppercase}#activeLabel{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:4;background:#0f1117b8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;padding:3px 13px;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:#9db8cc;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .3s}.view-actions{display:flex;gap:8px;justify-content:center;margin-top:12px}#cameraGuide{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0a0c12eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto}#cameraGuide.open{display:flex}.guide-card{background:#181b22;border:1px solid #2a3a4a;border-radius:14px;width:100%;max-width:440px;max-height:calc(100dvh - 40px);overflow-y:auto;overflow-x:hidden;box-shadow:0 24px 60px #0009;margin:auto;-webkit-overflow-scrolling:touch}.guide-header{padding:18px 20px 14px;border-bottom:1px solid #1e2530;display:flex;align-items:center;justify-content:space-between}.guide-title{font-family:Playfair Display,serif;font-size:1.1rem;color:#c8d8e4;letter-spacing:.02em}.guide-close{background:transparent;border:none;color:#5a7a8a;font-size:1.1rem;cursor:pointer;padding:2px 6px;border-radius:4px;transition:color .2s}.guide-close:hover{color:#c8d8e4}.guide-viewfinder{position:relative;margin:18px auto 0;width:200px;height:260px}.guide-viewfinder svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.vf-corner{position:absolute;width:100%;height:100%;top:0;left:0}.guide-tips{padding:16px 20px 6px;display:grid;grid-template-columns:1fr 1fr;gap:8px}.tip{background:#1e2530;border-radius:8px;padding:10px 12px;display:flex;gap:9px;align-items:flex-start}.tip-icon{font-size:1.1rem;flex-shrink:0;line-height:1.3}.tip-text{font-size:.66rem;color:#8a9eaa;line-height:1.5}.tip-text strong{display:block;color:#b8c8d4;margin-bottom:2px;font-size:.68rem}.guide-checklist{padding:10px 20px 4px;display:flex;flex-wrap:wrap;gap:6px}.check-item{display:flex;align-items:center;gap:5px;font-size:.62rem;color:#6a8a9a;background:#1a1f2a;border-radius:20px;padding:4px 10px;border:1px solid #2a3a4a}.check-item:before{content:"✓";color:#4a7fa5;font-weight:600}.guide-actions{padding:14px 20px 18px;display:flex;gap:8px;justify-content:flex-end}#liveCameraModal{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000;flex-direction:column;align-items:center;justify-content:center}#liveCameraModal.open{display:flex}.cam-wrap{position:relative;width:100%;max-width:500px;flex:1;max-height:100dvh;overflow:hidden}#camVideo{width:100%;height:100%;object-fit:cover;display:block}#camVideo.mirror{transform:scaleX(-1)}#camOverlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.cam-flip{position:absolute;top:14px;right:14px;z-index:5;background:#00000073;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:40px;height:40px;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.cam-bar{width:100%;max-width:500px;padding:16px 24px 28px;display:flex;align-items:center;justify-content:space-between;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cam-cancel{background:transparent;border:1px solid rgba(255,255,255,.25);border-radius:24px;color:#ffffffb3;font-family:DM Sans,sans-serif;font-size:.75rem;padding:8px 18px;cursor:pointer}.cam-shutter{width:64px;height:64px;border-radius:50%;background:#fff;border:4px solid rgba(255,255,255,.4);cursor:pointer;transition:transform .1s,background .1s;box-shadow:0 0 0 3px #fff3;display:flex;align-items:center;justify-content:center}.cam-shutter:active{transform:scale(.9);background:#d0d8e4}.cam-shutter-inner{width:48px;height:48px;border-radius:50%;background:#fff;border:2px solid #ccc}.cam-hint{font-size:.62rem;color:#ffffff73;text-align:center;letter-spacing:.06em;width:80px}#cropWrap{position:relative;width:100%;background:#0a0d12;border-radius:8px;overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none}#cropSourceImg{display:block;width:100%;pointer-events:none}#cropBox{position:absolute;border:2px solid #fff;box-shadow:0 0 0 9999px #0000008c;cursor:move}.crop-handle{position:absolute;width:14px;height:14px;border:2px solid #fff;background:#4a7fa5;border-radius:2px}#h-tl{top:-7px;left:-7px;cursor:nw-resize}#h-tr{top:-7px;right:-7px;cursor:ne-resize}#h-bl{bottom:-7px;left:-7px;cursor:sw-resize}#h-br{bottom:-7px;right:-7px;cursor:se-resize}.panel-hint{font-size:.62rem;color:#3a5a6a;text-align:center;margin-top:8px;line-height:1.5}#touchupPanel{display:none}#touchupWrap{position:relative;width:100%;border-radius:8px;overflow:hidden;background:repeating-conic-gradient(#1e2230,#1e2230 25%,#262b38 0%,#262b38 50%) 0 0 / 20px 20px;touch-action:none}#touchupWrap canvas{position:absolute;top:0;left:0}#touchupCanvas{display:block;width:100%;cursor:crosshair}.tu-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;background:#181b22;border:1px solid #2a2e38;border-radius:8px;padding:10px 12px}.tool-btn{padding:6px 14px;border-radius:20px;font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:1px solid #2a3a4a;background:transparent;color:#7a9ab0;transition:all .18s}.tool-btn.active{background:#4a7fa5;color:#fff;border-color:#4a7fa5}.tool-btn.erase.active{background:#a05050;border-color:#a05050;color:#fff}.sep{width:1px;height:20px;background:#2a2e38;margin:0 2px}label.sl{font-size:.58rem;color:#5a7a8a;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;gap:4px}input[type=range]{width:68px;accent-color:#4a7fa5}#editMode{display:none;max-width:520px;margin:0 auto}.edit-tabs{display:flex;margin-bottom:16px;border:1px solid #2a2e38;border-radius:8px;overflow:hidden}.tab{flex:1;padding:9px;text-align:center;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;background:#181b22;color:#5a7a8a;transition:all .18s;border:none}.tab.active{background:#4a7fa5;color:#fff}.edit-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}#compareMode{display:none;max-width:520px;margin:0 auto 32px}.compare-stage-wrap{position:relative;border-radius:12px;padding:3px;background:linear-gradient(135deg,#4a7fa5,#6e9ab8,#b0c4d4,#556f8a,#4a7fa5);box-shadow:0 0 28px #4a7fa540;margin-bottom:14px}.compare-stage{border-radius:10px;overflow:hidden;position:relative;width:100%;aspect-ratio:3/4;cursor:ew-resize;-webkit-user-select:none;user-select:none;touch-action:none}#cmpBgLeft{position:absolute;top:0;bottom:0;left:0;right:50%;transition:background .3s}#cmpBgRight{position:absolute;top:0;right:0;bottom:0;left:50%;transition:background .3s}#cmpGradLeft{position:absolute;top:0;bottom:0;left:0;right:50%;opacity:0;transition:opacity .3s}#cmpGradRight{position:absolute;top:0;right:0;bottom:0;left:50%;opacity:0;transition:opacity .3s}#cmpFaceImg{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:92%;max-height:98%;object-fit:contain;object-position:bottom center;z-index:3}#cmpDivider{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;z-index:5;transform:translate(-50%);cursor:ew-resize}#cmpDivider:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:28px;height:28px;border-radius:50%;background:#fff;box-shadow:0 2px 8px #0006}#cmpDivider:after{content:"◀ ▶";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.55rem;color:#555;letter-spacing:-.05em;line-height:1;pointer-events:none}.cmp-label{position:absolute;top:10px;z-index:6;background:#0f1117b8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;padding:3px 12px;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:#9db8cc;white-space:nowrap}#cmpLabelLeft{left:10px}#cmpLabelRight{right:10px}.compare-controls{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.cmp-side{background:#181b22;border:1px solid #2a2e38;border-radius:8px;padding:10px 12px}.cmp-side-title{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:#5a7a8a;margin-bottom:8px}.cmp-side.left .cmp-side-title{color:#7ab0cc}.cmp-side.right .cmp-side-title{color:#c07878}.cmp-select{width:100%;padding:6px 8px;border-radius:6px;background:#0f1117;border:1px solid #2a3a4a;color:#c8d8e4;font-family:DM Sans,sans-serif;font-size:.68rem;cursor:pointer;margin-bottom:6px}.cmp-select:focus{outline:none;border-color:#4a7fa5}.cmp-swatches{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}.cmp-swatch{width:22px;height:22px;border-radius:3px;cursor:pointer;transition:transform .15s;border:1px solid rgba(255,255,255,.08)}.cmp-swatch:hover{transform:scale(1.2);z-index:1}.cmp-swatch.active{box-shadow:0 0 0 2px #fff;transform:scale(1.15)}.gradient-toggle{display:flex;align-items:center;gap:6px;margin-top:6px}.gradient-toggle input{accent-color:#4a7fa5}.gradient-toggle label{font-size:.58rem;color:#5a7a8a;cursor:pointer}
