.hidden{display:none!important}.file-input-native{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;opacity:0;pointer-events:none}.file-input-overlay{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}:root{--emerald-50: #ecfdf5;--emerald-100: #d1fae5;--emerald-200: #a7f3d0;--emerald-300: #6ee7b7;--emerald-400: #34d399;--emerald-500: #10b981;--emerald-600: #059669;--emerald-700: #047857;--emerald-800: #065f46;--stone-50: #fafaf9;--stone-100: #f5f5f4;--stone-200: #e7e5e4;--stone-300: #d6d3d1;--stone-400: #a8a29e;--stone-500: #78716c;--stone-600: #57534e;--stone-700: #44403c;--stone-800: #292524;--stone-900: #1c1917;--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1)}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--stone-50);color:var(--stone-800);-webkit-font-smoothing:antialiased}.heading{font-family:Sora,-apple-system,BlinkMacSystemFont,sans-serif}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--stone-300);border-radius:99px}.nav-blur{background:#ffffffd9;backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border-bottom:1px solid rgba(0,0,0,.06)}.hero-gradient{background:linear-gradient(135deg,#059669,#10b981,#34d399)}.hero-glow{position:absolute;inset:0;pointer-events:none;overflow:hidden}.hero-glow:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);top:-200px;right:-100px}.hero-glow:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(52,211,153,.2) 0%,transparent 70%);bottom:-150px;left:10%}.upload-zone{position:relative;z-index:10;border:2px dashed var(--stone-200);border-radius:24px;background:#fff;transition:border-color .25s var(--ease-smooth),box-shadow .25s var(--ease-smooth),transform .25s var(--ease-smooth);cursor:pointer}.upload-zone:hover{border-color:var(--emerald-400);box-shadow:0 0 0 4px #10b98114,0 8px 32px #0596691a;transform:translateY(-2px)}.upload-zone.dragover{border-color:var(--emerald-500);background:var(--emerald-50);box-shadow:0 0 0 4px #10b98126,0 12px 40px #05966926;transform:scale(1.01)}.upload-icon-wrap{width:80px;height:80px;background:linear-gradient(135deg,var(--emerald-100),var(--emerald-200));border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;transition:transform .3s var(--ease-spring)}.upload-zone:hover .upload-icon-wrap{transform:scale(1.08) rotate(-3deg)}.upload-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px}.camera-only-action{display:none}.input-trigger{position:relative;overflow:hidden}@media(hover:none),(pointer:coarse){.camera-only-action{display:inline-flex}}.btn-emerald{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;background:linear-gradient(135deg,var(--emerald-600),var(--emerald-700));color:#fff;border-radius:14px;font-weight:600;font-size:15px;border:none;cursor:pointer;transition:all .2s var(--ease-smooth);box-shadow:0 4px 14px #05966959}.btn-emerald:hover{transform:translateY(-2px);box-shadow:0 8px 24px #05966966}.btn-emerald:active{transform:translateY(0)}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;background:transparent;color:var(--stone-600);border-radius:14px;font-weight:500;font-size:15px;border:1.5px solid var(--stone-200);cursor:pointer;transition:all .2s var(--ease-smooth)}.btn-ghost:hover{border-color:var(--emerald-400);color:var(--emerald-600);background:var(--emerald-50)}.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:#fff;color:var(--stone-700);border-radius:14px;font-weight:600;font-size:15px;border:1.5px solid var(--stone-200);cursor:pointer;transition:all .2s var(--ease-smooth)}.btn-outline:hover{border-color:var(--stone-400);box-shadow:0 2px 8px #0000000f}.card{background:#fff;border:1px solid var(--stone-100);border-radius:20px;overflow:hidden;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008;transition:box-shadow .2s var(--ease-smooth)}.card:hover{box-shadow:0 4px 16px #00000014,0 1px 3px #0000000a}.card-header{padding:20px 24px;border-bottom:1px solid var(--stone-100);display:flex;align-items:center;gap:12px}.card-badge{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.modal-backdrop{position:fixed;inset:0;background:#00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .25s var(--ease-smooth)}.modal-backdrop.open{opacity:1;pointer-events:all}.modal-panel{background:#fff;border-radius:24px;padding:32px;max-width:440px;width:100%;box-shadow:0 24px 64px #0000002e,0 4px 16px #00000014;transform:scale(.95) translateY(8px);transition:transform .3s var(--ease-spring);position:relative}.modal-backdrop.open .modal-panel{transform:scale(1) translateY(0)}.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:10px;border:none;background:var(--stone-100);color:var(--stone-500);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:var(--stone-200);color:var(--stone-800)}.loading-ring{width:56px;height:56px;border-radius:50%;border:3px solid var(--emerald-100);border-top-color:var(--emerald-500);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-orbs{display:flex;align-items:center;gap:8px}.loading-orbs span{width:10px;height:10px;background:var(--emerald-500);border-radius:50%;animation:orb-bounce 1.4s var(--ease-smooth) infinite}.loading-orbs span:nth-child(2){animation-delay:.2s}.loading-orbs span:nth-child(3){animation-delay:.4s}@keyframes orb-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.loading-pulse-ring{position:relative;width:120px;height:120px;margin:0 auto 32px}.loading-pulse-ring .ring{position:absolute;inset:0;border-radius:50%;border:2px solid transparent;border-top-color:var(--emerald-500);animation:spin 1.2s linear infinite}.loading-pulse-ring .ring:nth-child(2){inset:8px;border-top-color:var(--emerald-400);animation-duration:.9s;animation-direction:reverse}.loading-pulse-ring .ring:nth-child(3){inset:18px;border-top-color:var(--emerald-300);animation-duration:1.5s}.loading-pulse-ring .icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:32px;animation:icon-pulse 1.4s ease-in-out infinite}@keyframes icon-pulse{0%,to{opacity:.7;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}}.loading-progress-track{width:200px;height:4px;background:var(--stone-200);border-radius:99px;overflow:hidden;margin:0 auto 20px}.loading-progress-fill{height:100%;background:linear-gradient(90deg,var(--emerald-400),var(--emerald-600));border-radius:99px;animation:progress-move 2.5s ease-in-out infinite}@keyframes progress-move{0%{width:0%;margin-left:0}50%{width:70%;margin-left:15%}to{width:0%;margin-left:100%}}.loading-steps{display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:20px;flex-wrap:wrap}.loading-step{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;font-size:12px;font-weight:500;transition:all .3s ease}.loading-step.active{background:var(--emerald-100);color:var(--emerald-700)}.loading-step.pending{background:var(--stone-100);color:var(--stone-400)}.loading-step.done{background:var(--emerald-50);color:var(--emerald-600)}.loading-step .step-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.loading-step.active .step-dot{animation:pulse-dot 1s ease-in-out infinite}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.loading-step-sep{color:var(--stone-300);font-size:10px}.image-frame{border-radius:16px;overflow:hidden;background:var(--stone-100);position:relative;touch-action:pan-x pan-y pinch-zoom}.image-frame img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease-smooth)}.image-frame.zoomable,.image-frame.zoomed{cursor:default;overflow:auto}.image-frame.zoomed img{transform:scale(2)}.degraded-card{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1.5px solid #f59e0b;border-radius:20px;padding:20px}.degraded-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:#fef3c7;border:1px solid #f59e0b;border-radius:99px;font-size:12px;font-weight:600;color:#b45309;margin-bottom:12px}.upgrade-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:linear-gradient(135deg,var(--emerald-600),var(--emerald-700));color:#fff;border-radius:99px;font-size:13px;font-weight:600}.price-slash{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:20px}.price-slash .now{font-size:36px;font-weight:800;font-family:Sora,sans-serif;color:var(--emerald-600)}.price-slash .was{font-size:20px;font-weight:500;color:var(--stone-400);text-decoration:line-through}.user-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px 6px 8px;background:#ffffff26;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:99px;font-size:13px;font-weight:500;color:#fff}.anim-fade-up{animation:fadeUp .45s var(--ease-smooth) both}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.anim-stagger>*{animation:fadeUp .45s var(--ease-smooth) both}.anim-stagger>*:nth-child(1){animation-delay:0ms}.anim-stagger>*:nth-child(2){animation-delay:80ms}.anim-stagger>*:nth-child(3){animation-delay:.16s}.feature-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 16px}.canvas-container{position:relative;border-radius:16px;overflow:hidden;background:var(--stone-100)}.canvas-container canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.labels-overlay{position:absolute;inset:0;pointer-events:none}.label-item{position:absolute;width:24px;height:24px;background:#3b82f6;border:2px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;font-family:Sora,Outfit,sans-serif;color:#fff;box-shadow:0 2px 6px #00000040;transform:translate(-50%,-50%);z-index:10;line-height:1}.legend-panel{background:#fff;border:1px solid var(--stone-100);border-radius:16px;padding:16px 20px;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008}.legend-title{font-family:Sora,sans-serif;font-size:12px;font-weight:600;color:var(--stone-400);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.legend-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}.legend-item{display:flex;align-items:center;gap:10px;font-size:13px}.legend-num{width:22px;height:22px;background:#3b82f6;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;font-family:Sora,sans-serif}.legend-name{font-weight:600;color:var(--stone-800);flex-shrink:0}.legend-arrow{color:var(--stone-300);flex-shrink:0}.legend-target{color:var(--stone-500);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.desk-mapping-sidebar{background:#fff;border-radius:16px;padding:16px;max-height:400px;overflow-y:auto;box-shadow:0 4px 20px #00000014}.mapping-title{font-size:14px;font-weight:700;color:var(--stone-800);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--stone-100)}.mapping-list{display:flex;flex-direction:column;gap:12px}.mapping-item{background:var(--stone-50);border-radius:10px;padding:12px;transition:all .2s}.mapping-item:hover{background:var(--emerald-50);transform:translate(4px)}.mapping-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.mapping-num{width:20px;height:20px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}.mapping-category{font-weight:600;font-size:13px;color:var(--stone-800)}.mapping-details{display:flex;flex-direction:column;gap:4px;padding-left:28px}.mapping-row{display:flex;gap:6px;font-size:11px}.mapping-label{font-weight:600;color:var(--stone-500);flex-shrink:0}.mapping-label:first-child:after{content:":"}.mapping-value{color:var(--stone-600);line-height:1.4}.canvas-container img{width:100%;height:100%;object-fit:cover;display:block}.result-grid{display:grid;grid-template-columns:1fr;gap:16px}@media(min-width:640px){.result-grid{grid-template-columns:repeat(2,1fr);gap:20px}}.result-scroll{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:12px;margin:0 -20px;padding-left:20px;padding-right:20px}.result-scroll>.card{flex:0 0 85vw;max-width:320px;scroll-snap-align:center}@media(min-width:640px){.result-scroll{display:contents;overflow:visible;padding:0;margin:0}.result-scroll>.card{flex:none;max-width:none}}.svg-overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.svg-overlay svg{width:100%;height:100%}.arrow-path{fill:none;stroke-linecap:round;stroke-linejoin:round}.arrow-outline{stroke:#fff;stroke-linecap:round;stroke-linejoin:round}.arrow-green{stroke:#10b981}.arrow-red{stroke:#ef4444}.label-bg{fill:#fff;rx:6}.label-text{font-family:Sora,Outfit,sans-serif;font-size:12px;font-weight:600;fill:#0f172a;text-anchor:middle;dominant-baseline:middle}.label-shadow{fill:#00000026}@media(max-width:640px){.arrow-outline{stroke-width:7px}.arrow-path{stroke-width:4px}.label-text{font-size:11px}}.input-field{width:100%;padding:12px 16px;border:1.5px solid var(--stone-200);border-radius:12px;font-size:15px;font-family:inherit;color:var(--stone-800);background:#fff;transition:border-color .15s,box-shadow .15s;outline:none}.input-field:focus{border-color:var(--emerald-400);box-shadow:0 0 0 3px #10b9811f}.input-field::placeholder{color:var(--stone-400)}.divider{display:flex;align-items:center;gap:12px;color:var(--stone-400);font-size:13px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--stone-200)}.pulse-dot{width:8px;height:8px;background:var(--emerald-300);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.plan-badge{position:absolute;top:12px;right:12px;background:#ffffffe6;backdrop-filter:blur(8px);border-radius:10px;padding:6px 12px;font-size:12px;font-weight:600;color:var(--emerald-700);display:flex;align-items:center;gap:4px}footer{background:var(--stone-900);color:#fff}.comparison-container{position:relative;width:100%;border-radius:16px;overflow:hidden;background:var(--stone-100)}.comparison-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:20px;align-items:start}.comparison-panel{position:relative;border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 2px 8px #0000000f;transition:transform .3s var(--ease-out-quart),box-shadow .3s}.comparison-panel:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001a}.panel-label{position:absolute;top:12px;left:12px;z-index:20;display:flex;align-items:center;gap:8px;padding:6px 12px 6px 6px;background:#fffffff2;backdrop-filter:blur(8px);border-radius:99px;box-shadow:0 2px 8px #0000001a}.panel-badge{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px}.before-badge{background:var(--stone-200)}.after-badge{background:var(--emerald-100)}.panel-title{font-size:13px;font-weight:600;color:var(--stone-700)}.panel-image-wrapper{position:relative;width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:var(--stone-50)}.panel-image{width:100%;height:100%;object-fit:cover;display:block}.comparison-grid:after{content:"→";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;box-shadow:0 4px 16px #0596694d;z-index:30}.comparison-container{position:relative}@media(max-width:768px){.comparison-grid{grid-template-columns:1fr;gap:16px}.comparison-grid:after{display:none}.panel-image-wrapper{aspect-ratio:16/10}.result-with-sidebar{flex-direction:column!important}.tidy-log-container{width:100%!important}}.hotspot-container{position:absolute;inset:0;pointer-events:none;z-index:10}.hotspot{position:absolute;width:32px;height:32px;transform:translate(-50%,-50%);pointer-events:auto;cursor:pointer}.hotspot-dot{width:100%;height:100%;background:var(--emerald-500);border:3px solid white;border-radius:50%;box-shadow:0 2px 8px #0003;transition:transform .2s var(--ease-out-quart),background .2s;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;font-family:Sora,sans-serif}.hotspot:hover .hotspot-dot,.hotspot.active .hotspot-dot{transform:scale(1.2);background:var(--emerald-600)}.hotspot-pulse{position:absolute;inset:-6px;border-radius:50%;background:var(--emerald-400);opacity:0;animation:hotspot-pulse 2s ease-out infinite}.hotspot:hover .hotspot-pulse,.hotspot.active .hotspot-pulse{animation:hotspot-pulse-active 1s ease-out infinite}@keyframes hotspot-pulse{0%{transform:scale(1);opacity:.5}to{transform:scale(1.8);opacity:0}}@keyframes hotspot-pulse-active{0%{transform:scale(1);opacity:.6}to{transform:scale(2);opacity:0}}.tooltip{position:absolute;padding:0;background:transparent;color:#fff;border-radius:16px;font-size:13px;line-height:1.5;max-width:260px;min-width:200px;box-shadow:none;opacity:0;pointer-events:none;z-index:100;bottom:calc(100% + 16px);left:50%;transform:translate(-50%) translateY(8px)}.tooltip.tooltip-above{bottom:calc(100% + 16px);top:auto;transform:translate(-50%) translateY(8px)}.tooltip.tooltip-below{top:calc(100% + 16px);bottom:auto;transform:translate(-50%) translateY(-8px)}.tooltip.tooltip-left{right:calc(100% + 16px);left:auto;top:50%;bottom:auto;transform:translateY(-50%) translate(8px)}.tooltip.tooltip-right{left:calc(100% + 16px);top:50%;bottom:auto;transform:translateY(-50%) translate(-8px)}.tooltip.tooltip-left:after,.tooltip.tooltip-right:after{top:50%;bottom:auto;transform:translateY(-50%);border-top-color:transparent}.tooltip.tooltip-above:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:10px solid transparent;border-top-color:#1e293beb}.tooltip.tooltip-below:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:10px solid transparent;border-bottom-color:#1e293beb}.tooltip.tooltip-left:after{content:"";position:absolute;left:100%;border:10px solid transparent;border-left-color:#1e293beb}.tooltip.tooltip-right:after{content:"";position:absolute;right:100%;border:10px solid transparent;border-right-color:#1e293beb}.tooltip-content{background:#1e293beb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:16px;padding:16px 18px;box-shadow:0 8px 32px #0000004d,0 2px 8px #00000026,inset 0 1px #ffffff14;border:1px solid rgba(255,255,255,.1)}.tooltip-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.12)}.tooltip-emoji{font-size:22px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.tooltip-name{font-weight:700;font-size:15px;color:#fff;letter-spacing:-.01em}.tooltip-section{margin-top:10px}.tooltip-label{font-size:10px;font-weight:700;color:var(--emerald-400);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;display:flex;align-items:center;gap:6px}.tooltip-label:before{content:"";display:inline-block;width:4px;height:4px;background:var(--emerald-400);border-radius:50%}.tooltip-value{font-size:13px;color:#ffffffe0;line-height:1.5}.tooltip-preview{font-size:12px;color:#ffffffc7;line-height:1.45}.tooltip{display:none!important}.tooltip.tooltip-above{animation:tooltip-enter-above .25s var(--ease-out-quart) forwards}@keyframes tooltip-enter-above{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.tooltip-hint{display:none;position:absolute;top:50%;transform:translateY(-50%);right:-24px;width:20px;height:20px;background:#ffffffe6;border-radius:50%;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000026}.tooltip-hint svg{width:12px;height:12px;color:var(--stone-600)}@media(max-width:768px){.tooltip-hint{display:flex}.tooltip{max-width:200px;min-width:160px}.tooltip-content{padding:12px 14px}.tooltip-header{margin-bottom:8px;padding-bottom:8px}.tooltip-emoji{font-size:18px}.tooltip-name{font-size:13px}.tooltip-value{font-size:12px}}.tidy-log{background:#fff;border-radius:16px;border:1px solid var(--stone-100);overflow:hidden;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008;max-height:450px;display:flex;flex-direction:column}.tidy-log-header{padding:12px 14px;border-bottom:1px solid var(--stone-100);display:flex;align-items:center;gap:10px;flex-shrink:0}.tidy-log-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--emerald-100),var(--emerald-200));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.tidy-log-title{font-family:Sora,sans-serif;font-size:14px;font-weight:700;color:var(--stone-800)}.tidy-log-subtitle{font-size:11px;color:var(--stone-400);margin-top:1px}.tidy-log-list{max-height:350px;overflow-y:auto;padding:8px;flex:1}.tidy-log-item{display:flex;align-items:flex-start;gap:10px;padding:10px;border-radius:10px;cursor:pointer;transition:background .15s var(--ease-out-quart),transform .15s}.tidy-log-item:hover{background:var(--stone-50)}.tidy-log-item.active{background:var(--emerald-50)}.tidy-log-item.highlight{animation:highlight-flash .8s var(--ease-out-quart)}@keyframes highlight-flash{0%,to{background:var(--stone-50)}25%{background:var(--emerald-100)}50%{background:var(--emerald-50)}75%{background:var(--emerald-100)}}.tidy-log-num{width:26px;height:26px;background:var(--emerald-500);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;font-family:Sora,sans-serif;transition:background .15s,transform .15s}.tidy-log-item:hover .tidy-log-num,.tidy-log-item.active .tidy-log-num{background:var(--emerald-600);transform:scale(1.1)}.tidy-log-content{flex:1;min-width:0}.tidy-log-name{font-weight:600;font-size:12px;color:var(--stone-800);display:flex;align-items:center;gap:5px}.tidy-log-name .emoji{font-size:13px}.tidy-log-story{font-size:10px;color:var(--stone-500);margin-top:3px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tidy-log-arrow{color:var(--stone-300);font-size:14px;margin-top:2px;flex-shrink:0}@media(max-width:768px){.tidy-log{max-height:200px}}.tidy-log-item{opacity:0;transform:translate(-12px);animation:slide-in-log .3s var(--ease-out-quart) forwards}@keyframes slide-in-log{to{opacity:1;transform:translate(0)}}.split-workspace{display:flex;gap:0;height:calc(100vh - 140px);min-height:540px;max-height:900px;background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #00000014,0 1px 4px #0000000a;border:1px solid var(--stone-100)}.action-sidebar{width:28%;min-width:240px;max-width:320px;flex-shrink:0;border-right:1px solid var(--stone-100);display:flex;flex-direction:column;background:var(--stone-50);overflow:hidden}.sidebar-top{padding:16px 16px 12px;border-bottom:1px solid var(--stone-100);background:#fff;flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:8px;margin-bottom:10px}.sidebar-logo{width:32px;height:32px;background:linear-gradient(135deg,var(--emerald-600),var(--emerald-700));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px}.sidebar-title{font-family:Sora,sans-serif;font-size:14px;font-weight:700;color:var(--stone-800)}.score-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:linear-gradient(135deg,var(--emerald-50),var(--emerald-100));border:1px solid var(--emerald-200);border-radius:99px;font-size:12px;font-weight:600;color:var(--emerald-700)}.sidebar-subtitle{font-size:11px;color:var(--stone-400);margin-top:6px}.sidebar-scroll{flex:1;overflow-y:auto;padding:8px}.item-card{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);margin-bottom:6px;border:1px solid transparent;background:transparent}.item-card:hover{background:#fffc;transform:translate(4px)}.item-card.active{background:#fff;border-color:var(--emerald-200);box-shadow:0 8px 24px #10b98126,0 2px 6px #0000000a;transform:translate(6px)}.item-card.dimmed{opacity:.4;transform:scale(.98);filter:grayscale(.2)}.card-num{width:26px;height:26px;background:var(--stone-200);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--stone-600);flex-shrink:0;font-family:Sora,sans-serif;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.item-card:hover .card-num{background:var(--stone-300);color:var(--stone-800)}.item-card.active .card-num{background:var(--emerald-500);color:#fff;transform:scale(1.15);box-shadow:0 4px 12px #10b98166}.card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.card-name{font-size:13px;font-weight:700;color:var(--stone-800);display:flex;align-items:center;gap:6px;transition:color .3s}.item-card.active .card-name{color:var(--emerald-700)}.card-action{appearance:none;width:100%;padding:10px 12px;border:1px solid rgba(16,185,129,.12);border-radius:12px;background:linear-gradient(135deg,#fffffffa,#ecfdf5b8);cursor:copy;text-align:left;transition:border-color .2s var(--ease-smooth),background .2s var(--ease-smooth),transform .2s var(--ease-smooth),box-shadow .2s var(--ease-smooth)}.card-action:hover{border-color:#10b98147;background:linear-gradient(135deg,#fff,#dcfce7d1);transform:translateY(-1px)}.card-action:focus-visible{outline:2px solid var(--emerald-300);outline-offset:2px}.card-action-text{display:block;font-size:12px;color:var(--stone-500);line-height:1.5;white-space:pre-wrap;overflow-wrap:anywhere;transition:color .3s}.card-action-meta{display:block;margin-top:8px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--emerald-700);opacity:.76;transition:opacity .2s var(--ease-smooth),color .2s var(--ease-smooth)}.item-card.active .card-action{border-color:var(--emerald-200);background:linear-gradient(135deg,#ecfdf5f5,#d1fae5c2)}.item-card.active .card-action-text{color:var(--emerald-900)}.card-action.copied{border-color:var(--emerald-400);background:linear-gradient(135deg,#dcfce7f5,#a7f3d0b8);box-shadow:0 8px 18px #10b98124}.card-action.copied .card-action-meta{opacity:1}.card-arrow{color:var(--stone-300);font-size:16px;flex-shrink:0;margin-top:2px;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.item-card.active .card-arrow{color:var(--emerald-500);transform:translate(2px)}.item-card{opacity:0;animation:card-enter .3s var(--ease-smooth) forwards}@keyframes card-enter{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.guidance-loading-card{display:flex;gap:12px;padding:14px;margin:4px 0 10px;border:1px solid var(--emerald-100);border-radius:8px;background:linear-gradient(135deg,#ecfdf5f0,#fffffff5);box-shadow:0 10px 24px #10b98114}.guidance-loading-spinner{width:22px;height:22px;border:2px solid var(--emerald-100);border-top-color:var(--emerald-600);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0;margin-top:1px}.guidance-loading-body{min-width:0}.guidance-loading-title{font-size:13px;font-weight:700;color:var(--stone-800);line-height:1.35}.guidance-loading-text{margin-top:5px;font-size:12px;color:var(--stone-500);line-height:1.45}.map-loading-pill{position:absolute;top:12px;left:12px;z-index:25;display:inline-flex;align-items:center;gap:8px;max-width:min(260px,calc(100% - 24px));padding:8px 10px;border-radius:8px;border:1px solid rgba(16,185,129,.22);background:#ffffffeb;color:var(--stone-700);box-shadow:0 10px 26px #1c19171f;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);font-size:12px;font-weight:700;line-height:1.25;pointer-events:none}.map-loading-pill:before{content:"";width:12px;height:12px;border:2px solid var(--emerald-100);border-top-color:var(--emerald-600);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.guidance-unavailable-card{padding:14px;margin:4px 0 10px;border:1px solid var(--stone-200);border-radius:8px;background:#ffffffeb;color:var(--stone-600);font-size:12px;line-height:1.45}.copy-toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,18px);padding:10px 14px;border-radius:999px;background:#1c1917f0;color:#fff;font-size:12px;font-weight:600;letter-spacing:.01em;box-shadow:0 14px 32px #1c19172e;opacity:0;pointer-events:none;transition:opacity .18s var(--ease-smooth),transform .18s var(--ease-smooth);z-index:120}.copy-toast.visible{opacity:1;transform:translate(-50%)}.sidebar-actions{padding:12px 16px;border-top:1px solid var(--stone-100);background:#fff;flex-shrink:0;display:flex;gap:8px}.visual-workspace{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--stone-50);position:relative}.view-toggle-bar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 16px;background:#fff;border-bottom:1px solid var(--stone-100);flex-shrink:0}.view-status-slot{flex:1;min-width:0;display:flex;align-items:flex-start;gap:12px}.seg-control{display:none;background:var(--stone-100);border-radius:10px;padding:3px;gap:2px}.seg-btn{padding:5px 14px;border-radius:8px;border:none;background:transparent;font-size:12px;font-weight:600;color:var(--stone-500);cursor:pointer;transition:all .15s}.seg-btn.active{background:#fff;color:var(--stone-800);box-shadow:0 1px 4px #0000001a}.ws-tools{display:flex;align-items:center;gap:4px;pointer-events:auto;margin-left:auto;flex-shrink:0}.tool-btn{width:40px;height:40px;border-radius:12px;border:1px solid var(--stone-200);background:#fffffff2;backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000000d;color:var(--stone-600);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.tool-btn:hover,.tool-btn:active{transform:translateY(-2px);box-shadow:0 6px 16px #0000001a;background:#fff;color:var(--stone-900);border-color:var(--stone-300)}.image-stage{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.image-viewport{width:100%;height:100%;display:flex;flex-direction:column;gap:12px;padding:12px;transition:transform .3s var(--ease-smooth);transform-origin:center center}.image-panel-ws{flex:1;position:relative;min-height:0;border-radius:12px;background:var(--stone-100);overflow:hidden;transition:opacity .3s var(--ease-smooth);display:flex;align-items:center;justify-content:center}.image-wrapper{position:relative;display:inline-flex;max-width:100%;max-height:100%;flex-shrink:1;min-width:0;min-height:0}.image-wrapper img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:8px}.panel-bg-label{position:absolute;top:12px;left:12px;background:#ffffffd9;backdrop-filter:blur(8px);padding:6px 12px;border-radius:99px;font-size:13px;font-weight:700;color:var(--stone-700);z-index:10;pointer-events:none;box-shadow:0 2px 8px #0000000f}.mobile-focus-card{position:static;display:none;min-width:0;max-width:100%;padding:6px 10px;border-radius:999px;background:linear-gradient(135deg,#f8fafcfa,#f0fdf4f5);border:1px solid rgba(16,185,129,.14);box-shadow:inset 0 1px #ffffffe0}.mobile-focus-card.open{display:flex;align-items:flex-start;gap:10px;flex:1;min-width:0}.mobile-focus-number{width:28px;height:28px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-600));color:#fff;font-family:Sora,sans-serif;font-size:13px;font-weight:700;box-shadow:0 5px 12px #05966924;flex-shrink:0}.mobile-focus-body{min-width:0;display:flex;align-items:flex-start;flex-wrap:wrap;gap:8px;flex:1}.mobile-focus-eyebrow{display:none}.mobile-focus-title{font-size:13px;font-weight:700;color:var(--stone-800);line-height:1.2;white-space:normal;overflow:visible;flex:0 1 auto;max-width:220px}.mobile-focus-sections{display:flex;align-items:flex-start;gap:8px;min-width:0;flex:1}.mobile-focus-section[hidden],.mobile-focus-label{display:none}.mobile-focus-text{font-size:12px;line-height:1.35;color:var(--stone-600);overflow:visible;white-space:normal;word-break:break-word}.mobile-focus-close{display:none}.image-panel-empty{display:none;width:100%;height:100%;align-items:center;justify-content:center;text-align:left;padding:24px}.image-panel-empty.open{display:flex}.image-panel-empty-card{max-width:360px;padding:20px 22px;border-radius:20px;background:linear-gradient(135deg,#fffffffa,#f8fafcf2);border:1px solid rgba(148,163,184,.18);box-shadow:0 14px 30px #0f172a14}.image-panel-empty-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#f59e0b1f;color:#b45309;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.image-panel-empty-title{margin-top:12px;font-size:18px;font-weight:700;line-height:1.3;color:var(--stone-800)}.image-panel-empty-text{margin-top:8px;font-size:14px;line-height:1.55;color:var(--stone-600)}@media(min-width:769px){.image-panel-ws.hidden-view{opacity:1!important;pointer-events:auto!important}}.image-panel-ws.hidden-view{opacity:0;pointer-events:none}.anchor-dot{position:absolute;width:28px;height:28px;transform:translate(-50%,-50%);cursor:pointer;z-index:20;opacity:0;animation:anchor-enter .5s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes anchor-enter{0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.anchor-ring{position:absolute;inset:-14px;border-radius:50%;border:2px solid var(--emerald-400);animation:sonar-breathe 2.5s cubic-bezier(.25,1,.5,1) infinite;z-index:-1;opacity:0}@keyframes sonar-breathe{0%{transform:scale(.4);opacity:.8;border-width:4px}to{transform:scale(1.1);opacity:0;border-width:1px}}.anchor-core{position:absolute;inset:0;border-radius:50%;background:#fffffff2;backdrop-filter:blur(8px);box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:var(--emerald-700);font-family:Sora,sans-serif;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.anchor-dot:hover,.anchor-dot.active{z-index:50}.anchor-dot:hover .anchor-core{transform:scale(1.2);background:#fff;color:var(--emerald-600);box-shadow:0 6px 16px #0003,0 0 0 1px #0000000d}.anchor-dot.active .anchor-ring{animation:none;opacity:1;inset:-6px;background:#10b98140;border:3px solid var(--emerald-400);transform:scale(1);transition:all .3s cubic-bezier(.34,1.56,.64,1)}.anchor-dot.active .anchor-core{transform:scale(1.4);background:var(--emerald-600);color:#fff;box-shadow:0 8px 30px #05966999,0 0 0 4px #fff}.anchor-dot.dimmed{opacity:.4;filter:grayscale(.5)}.anchor-dot.dimmed .anchor-ring{animation:none;opacity:0}.ping-dot{position:absolute;width:28px;height:28px;transform:translate(-50%,-50%);pointer-events:none;z-index:20;opacity:0}.ping-core{position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 0 0 2.5px #fffffff2,0 4px 12px #2563eb80;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;font-family:Sora,sans-serif;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.ping-dot.active{opacity:1}.ping-dot.echo{opacity:1;animation:ping-pop .6s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes ping-pop{0%{transform:translate(-50%,-50%) scale(.5);opacity:0}60%{transform:translate(-50%,-50%) scale(1.2);opacity:1}to{transform:translate(-50%,-50%) scale(1)}}.ping-ripple{position:absolute;inset:-14px;border-radius:50%;border:3px solid #3b82f6;animation:radar-ping .8s cubic-bezier(.25,1,.5,1) forwards;opacity:0}.ping-ripple-2{position:absolute;inset:-20px;border-radius:50%;border:2px solid #60a5fa;animation:radar-ping .8s .15s cubic-bezier(.25,1,.5,1) forwards;opacity:0}@keyframes radar-ping{0%{transform:scale(.3);opacity:1;border-width:4px}to{transform:scale(1.2);opacity:0;border-width:1px}}@media(max-width:768px){body{overflow-x:hidden}.split-workspace{flex-direction:column;height:auto;max-height:none;box-shadow:none;background:transparent}.visual-workspace{flex:none;width:100%;height:auto;min-height:0;order:-1;border-radius:16px;box-shadow:0 4px 20px #0000000f;margin-bottom:16px;border:1px solid var(--stone-100);display:flex;flex-direction:column}.image-stage{flex:none;position:relative;min-height:auto;align-items:stretch;justify-content:stretch}.image-viewport{position:static;inset:auto;height:auto;display:flex;flex-direction:column;gap:12px;padding:12px}.image-panel-ws{position:relative;inset:auto;flex:none;width:100%;min-height:220px;aspect-ratio:4 / 3;border-radius:12px}.image-panel-ws.hidden-view{opacity:1;pointer-events:auto}.image-wrapper{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;max-width:100%;max-height:100%}.image-wrapper img{width:100%;height:100%;object-fit:contain}.seg-control{display:none}.mobile-focus-card{padding:6px 10px;border-radius:16px}.mobile-focus-number{font-size:12px}.mobile-focus-body{gap:6px}.mobile-focus-title{max-width:100%}.mobile-focus-sections{min-width:0;flex-basis:100%}.mobile-focus-text{font-size:12px;line-height:1.45}.tooltip{display:none!important}.action-sidebar{width:100%;height:auto;max-height:none;flex:none;border:1px solid var(--stone-100);border-radius:16px;box-shadow:0 4px 20px #0000000f;padding-bottom:80px}.sidebar-scroll{overflow-y:visible}.sidebar-actions{position:sticky;bottom:0;border-radius:0 0 16px 16px;box-shadow:0 -4px 16px #0000000d;z-index:50;background:#fff}.sidebar-top{pointer-events:none}.sidebar-handle{display:none!important}.panel-bg-label{display:none}.view-toggle-bar{padding:10px;border-radius:16px 16px 0 0;flex-shrink:0}}
