*,*:before,*:after{box-sizing:border-box}body{margin:0}:root{--color-purple: #6C5CE7;--color-purple-light: #A29BFE;--color-coral: #FF6B6B;--color-coral-light: #FF8E8E;--color-emerald: #00B894;--color-emerald-light: #55EFC4;--color-yellow: #FDCB6E;--color-yellow-light: #FFEAA7;--color-sky: #74B9FF;--color-sky-light: #A3D8FF;--color-terracotta: #E17055;--color-primary: var(--color-purple);--color-primary-hover: #5A4BD1;--color-accent: var(--color-coral);--color-accent-hover: #E85656;--color-bg: #FFF8F0;--color-surface: #FFFFFF;--color-border: #F0E6D9;--color-border-strong: #E0D2C2;--color-text: #2D3436;--color-text-muted: #636E72;--color-text-light: #B2BEC3;--font-heading: "Fredoka", sans-serif;--font-body: "Nunito", sans-serif;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(45, 52, 54, .06), 0 1px 2px rgba(45, 52, 54, .04);--shadow-md: 0 4px 16px rgba(45, 52, 54, .08), 0 2px 4px rgba(45, 52, 54, .04);--shadow-lg: 0 8px 32px rgba(45, 52, 54, .1), 0 4px 8px rgba(45, 52, 54, .04);--shadow-clay: 0 6px 20px rgba(45, 52, 54, .08), inset 0 -2px 4px rgba(45, 52, 54, .03);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-bounce: .4s cubic-bezier(.34, 1.56, .64, 1)}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:var(--font-heading)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.btn{padding:8px 18px;border-radius:var(--radius-full);font-family:var(--font-body);font-weight:600;font-size:13px;cursor:pointer;transition:transform var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast);border:2px solid transparent;display:inline-flex;align-items:center;gap:6px}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0) scale(.97)}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 4px 12px #6c5ce74d}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:0 6px 20px #6c5ce766}.btn-accent{background:var(--color-accent);color:#fff;border-color:var(--color-accent);box-shadow:0 4px 12px #ff6b6b4d}.btn-accent:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);box-shadow:0 6px 20px #ff6b6b66}.btn-ghost{background:var(--color-surface);color:var(--color-text-muted);border:2px solid var(--color-border)}.btn-ghost:hover{background:var(--color-bg);border-color:var(--color-border-strong);color:var(--color-text)}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUpDropzone{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(2deg)}}@keyframes floatReverse{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-6px) rotate(-2deg)}}@keyframes wiggle{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}@keyframes popIn{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.anim-fade-up{opacity:0;animation:fadeUp .7s cubic-bezier(.22,1,.36,1) forwards}.anim-delay-1{animation-delay:80ms}.anim-delay-2{animation-delay:.16s}.anim-delay-3{animation-delay:.28s}.anim-delay-4{animation-delay:.4s}.anim-delay-5{animation-delay:.55s}.anim-delay-6{animation-delay:.7s}.anim-fade-up-dropzone{opacity:0;animation:fadeUpDropzone .7s cubic-bezier(.22,1,.36,1) .5s forwards}.home{position:relative;overflow:hidden}.home-main{text-align:center}.home:before,.home:after{content:"";position:fixed;border-radius:50%;z-index:0;pointer-events:none;filter:blur(60px);opacity:.35}.home:before{width:400px;height:400px;background:var(--color-purple-light);top:-100px;right:-100px;animation:float 8s ease-in-out infinite}.home:after{width:350px;height:350px;background:var(--color-coral-light);bottom:100px;left:-120px;animation:floatReverse 10s ease-in-out infinite}.home-main:before,.home-main:after{content:"";position:fixed;border-radius:50%;z-index:0;pointer-events:none;filter:blur(50px);opacity:.25}.home-main:before{width:300px;height:300px;background:var(--color-yellow-light);top:200px;left:10%;animation:float 12s ease-in-out 2s infinite}.home-main:after{width:250px;height:250px;background:var(--color-emerald-light);bottom:200px;right:5%;animation:floatReverse 9s ease-in-out 1s infinite}@keyframes shapeEnter{0%{opacity:0;transform:translateY(-120px)}to{opacity:1;transform:translateY(0)}}@keyframes shapeFloat1{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(15px) rotate(1.5deg)}}@keyframes shapeFloat2{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(-1deg)}}.hero{position:relative;overflow:hidden}.hero-shapes{position:absolute;inset:0;pointer-events:none;z-index:0}.elegant-shape{position:absolute;opacity:0;animation:shapeEnter 2s cubic-bezier(.23,.86,.39,.96) forwards}.elegant-shape .shape-inner{border-radius:9999px;position:relative}.elegant-shape .shape-inner:after{content:"";position:absolute;inset:0;border-radius:9999px;background:radial-gradient(ellipse at 30% 50%,rgba(255,255,255,.2),transparent 70%)}.shape-1{left:-2%;top:12%;transform:rotate(12deg);animation-delay:.2s}.shape-1 .shape-inner{width:550px;height:130px;background:linear-gradient(135deg,#6c5ce72e,#a29bfe0f);border:2px solid rgba(108,92,231,.12);box-shadow:0 8px 40px #6c5ce71a;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:shapeFloat1 14s ease-in-out infinite}.shape-2{right:-2%;top:65%;transform:rotate(-15deg);animation-delay:.4s}.shape-2 .shape-inner{width:480px;height:110px;background:linear-gradient(135deg,#ff6b6b29,#ff8e8e0a);border:2px solid rgba(255,107,107,.1);box-shadow:0 8px 40px #ff6b6b14;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:shapeFloat2 16s ease-in-out 1s infinite}.shape-3{left:8%;bottom:5%;transform:rotate(-8deg);animation-delay:.3s}.shape-3 .shape-inner{width:350px;height:90px;background:linear-gradient(135deg,#00b89426,#55efc40a);border:2px solid rgba(0,184,148,.1);box-shadow:0 8px 32px #00b89414;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:shapeFloat1 18s ease-in-out 2s infinite}.shape-4{right:10%;top:5%;transform:rotate(20deg);animation-delay:.5s}.shape-4 .shape-inner{width:280px;height:70px;background:linear-gradient(135deg,#fdcb6e33,#ffeaa70d);border:2px solid rgba(253,203,110,.14);box-shadow:0 8px 32px #fdcb6e14;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:shapeFloat2 12s ease-in-out .5s infinite}.shape-5{left:30%;top:38%;transform:rotate(-20deg);animation-delay:.6s}.shape-5 .shape-inner{width:220px;height:55px;background:linear-gradient(135deg,#74b9ff29,#a3d8ff0a);border:2px solid rgba(116,185,255,.1);box-shadow:0 8px 32px #74b9ff14;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:shapeFloat1 20s ease-in-out 3s infinite}.shape-6{right:5%;top:35%;transform:rotate(8deg);animation-delay:.7s}.shape-6 .shape-inner{width:400px;height:95px;background:linear-gradient(135deg,#a29bfe24,#6c5ce708);border:2px solid rgba(162,155,254,.1);box-shadow:0 8px 32px #a29bfe14;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:shapeFloat2 15s ease-in-out 1.5s infinite}.shape-7{left:45%;top:2%;transform:rotate(-12deg);animation-delay:.55s}.shape-7 .shape-inner{width:180px;height:50px;background:linear-gradient(135deg,#e1705529,#e1705508);border:2px solid rgba(225,112,85,.1);box-shadow:0 8px 32px #e170550f;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:shapeFloat1 11s ease-in-out 2.5s infinite}.shape-8{right:20%;bottom:12%;transform:rotate(25deg);animation-delay:.8s}.shape-8 .shape-inner{width:250px;height:65px;background:linear-gradient(135deg,#55efc424,#00b89408);border:2px solid rgba(85,239,196,.1);box-shadow:0 8px 32px #55efc40f;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:shapeFloat2 17s ease-in-out 1s infinite}.hero-split{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;min-height:100dvh;max-width:1200px;margin:0 auto;padding:48px 40px;position:relative;z-index:2}.hero-left{display:flex;flex-direction:column;gap:24px;text-align:left}.hero-right{display:flex;flex-direction:column;align-items:center;gap:28px}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border-radius:var(--radius-full);background:#6c5ce70f;border:1.5px solid rgba(108,92,231,.12);width:fit-content;font-size:13px;font-weight:600;color:var(--color-text-muted);letter-spacing:.01em}.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--color-coral);box-shadow:0 0 8px #ff6b6b66}.hero-brand{display:flex;align-items:center;gap:10px}.hero-logo{filter:drop-shadow(0 4px 12px rgba(108,92,231,.2));transition:transform var(--transition-bounce)}.hero-logo:hover{transform:scale(1.08) rotate(-5deg)}.hero-name{font-family:var(--font-heading);font-size:18px;font-weight:600;background:linear-gradient(135deg,var(--color-purple) 0%,var(--color-coral) 50%,var(--color-yellow) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-title{font-family:var(--font-heading);font-size:clamp(36px,5vw,56px);font-weight:700;line-height:1.08;color:var(--color-text);margin:0;letter-spacing:-.03em}.hero-title-accent{background:linear-gradient(135deg,var(--color-coral) 0%,var(--color-purple) 50%,var(--color-sky) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% 100%;animation:gradientShift 6s ease-in-out infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.hero-subtitle{font-size:17px;color:var(--color-text-muted);max-width:440px;margin:0;line-height:1.75;font-weight:400;letter-spacing:.01em;text-align:center}.steps{display:flex;align-items:center;justify-content:center;gap:16px;margin:0;width:100%}.step{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.step-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:var(--color-surface);border:2.5px solid var(--color-border);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-clay);transition:transform var(--transition-bounce),box-shadow var(--transition-normal),border-color var(--transition-normal)}.step:nth-child(1) .step-icon{color:var(--color-purple)}.step:nth-child(3) .step-icon{color:var(--color-emerald)}.step:nth-child(5) .step-icon{color:var(--color-coral)}.step:hover .step-icon{transform:translateY(-5px) rotate(-3deg);box-shadow:var(--shadow-lg)}.step:nth-child(1):hover .step-icon{border-color:var(--color-purple-light)}.step:nth-child(3):hover .step-icon{border-color:var(--color-emerald-light)}.step:nth-child(5):hover .step-icon{border-color:var(--color-coral-light)}.step-label{font-size:13px;font-weight:600;color:var(--color-text-muted)}.step-arrow{color:var(--color-border-strong);display:flex;align-items:center;padding-bottom:28px}.dropzone{border:3px dashed var(--color-border-strong);border-radius:var(--radius-xl);padding:48px 24px;text-align:center;transition:border-color var(--transition-normal),background var(--transition-normal),transform var(--transition-bounce),box-shadow var(--transition-normal);cursor:pointer;max-width:580px;margin:0;width:100%;background:#ffffff80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dropzone:hover,.dropzone.dragover{border-color:var(--color-purple);background:#6c5ce70a;transform:scale(1.02);box-shadow:0 8px 32px #6c5ce71f}.dropzone.dragover{border-style:solid;background:#6c5ce714}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--color-text-muted)}.dropzone-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-purple-light) 0%,var(--color-sky-light) 100%);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 16px #6c5ce733;transition:transform var(--transition-bounce)}.dropzone:hover .dropzone-icon{transform:translateY(-4px) rotate(-5deg)}.dropzone-content p{margin:0;font-size:17px;font-weight:600;color:var(--color-text)}.dropzone-content span{font-size:13px;color:var(--color-text-light);font-weight:500}.projects-section{margin-top:0;padding:60px 40px 0;max-width:1200px;margin-left:auto;margin-right:auto;text-align:left}.projects-header{display:flex;align-items:center;gap:10px;margin-bottom:24px}.projects-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--color-yellow) 0%,var(--color-terracotta) 100%);display:flex;align-items:center;justify-content:center;color:#fff}.projects-title{font-family:var(--font-heading);font-size:22px;font-weight:600;margin:0;color:var(--color-text)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.project-card{background:var(--color-surface);border:2.5px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:transform var(--transition-bounce),box-shadow var(--transition-normal),border-color var(--transition-normal);position:relative;box-shadow:var(--shadow-sm);isolation:isolate;will-change:transform}.project-card:hover{transform:translateY(-6px) rotate(-.5deg);box-shadow:var(--shadow-lg);border-color:var(--color-purple-light)}.project-card-thumb{width:100%;aspect-ratio:4 / 3;overflow:hidden;background:var(--color-bg);display:flex;align-items:center;justify-content:center}.project-card-thumb img{width:100%;height:100%;object-fit:cover}.project-card-info{padding:12px 14px;display:flex;flex-direction:column;gap:2px}.project-card-name{font-size:14px;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-date{font-size:12px;color:var(--color-text-light);font-weight:500}.project-card-delete{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:#ffffffe6;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.project-card:hover .project-card-delete{opacity:1}.project-card-delete:hover{color:var(--color-coral);transform:scale(1.1)}.home-footer{text-align:center;color:var(--color-text-light);font-size:13px;font-weight:500;padding:40px 0 32px}.home-footer p{margin:0}.editor{display:grid;grid-template-rows:auto 1fr;height:100vh;overflow:hidden;background:var(--color-bg)}.editor-toolbar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--color-surface);border-bottom:2px solid var(--color-border);flex-wrap:wrap;z-index:5;box-shadow:0 2px 12px #2d34360a}.editor-body{display:flex;overflow:hidden;position:relative}.editor-canvas{flex:1;position:relative;overflow:hidden;background:#f5f0e8;cursor:grab}.editor-canvas:active{cursor:grabbing}.editor-canvas:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 30%,rgba(108,92,231,.03) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(255,107,107,.03) 0%,transparent 50%);pointer-events:none;z-index:0}.editor-sidebar{position:relative;width:300px;background:var(--color-surface);border-left:2px solid var(--color-border);overflow:visible;transition:width var(--transition-normal),padding var(--transition-normal)}.sidebar-inner{overflow-y:auto;height:100%}.editor-sidebar.collapsed{width:0;padding:0;border-left:none}.editor-sidebar.collapsed .sidebar-inner{display:none}.sidebar-toggle{position:absolute;left:-36px;top:50%;transform:translateY(-50%);width:32px;height:52px;border:2px solid var(--color-border);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);background:var(--color-surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:color var(--transition-fast),background var(--transition-fast);z-index:2}.sidebar-toggle:hover{color:var(--color-primary);background:var(--color-bg)}.sidebar-inner{padding:20px}.sidebar-title{font-family:var(--font-heading);font-size:16px;font-weight:600;margin-bottom:16px;color:var(--color-text);display:flex;align-items:center;gap:8px}.sidebar-title-dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary)}.legend-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);margin-bottom:2px}.legend-item:hover{background:#6c5ce70f;transform:translate(3px)}.legend-swatch{width:28px;height:28px;border-radius:var(--radius-sm);border:2px solid rgba(45,52,54,.1);flex-shrink:0;box-shadow:var(--shadow-sm);transition:transform var(--transition-bounce)}.legend-item:hover .legend-swatch{transform:scale(1.12) rotate(-5deg)}.legend-number{font-family:var(--font-heading);font-weight:600;font-size:16px;min-width:20px;color:var(--color-text)}.legend-hex{font-size:11px;color:var(--color-text-muted);font-family:Nunito,monospace;font-weight:600}.legend-count{font-size:11px;color:var(--color-text-light);margin-left:auto;font-weight:500}.sidebar-info{font-size:12px;color:var(--color-text-light);margin-top:20px;line-height:1.7;font-weight:500;padding:14px;background:var(--color-bg);border-radius:var(--radius-md);border:1.5px solid var(--color-border)}.editor-canvas canvas{position:absolute;top:0;left:0;image-rendering:pixelated;z-index:1}.canvas-loading{display:none;position:absolute;inset:0;background:#f5f0e8d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;align-items:center;justify-content:center}.canvas-loading.visible{display:flex}.loader{display:flex;flex-direction:column;align-items:center;gap:24px}.loader-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;width:72px;height:72px}.loader-pixel{border-radius:var(--radius-sm);animation:pixelPulse 1.4s ease-in-out infinite both}@keyframes pixelPulse{0%,60%,to{background:var(--color-border);transform:scale(.8);border-radius:var(--radius-sm)}30%{background:var(--color-purple);transform:scale(1.05);border-radius:var(--radius-md);box-shadow:0 0 12px #6c5ce766}}.loader-pixel:nth-child(2){animation-delay:.1s}.loader-pixel:nth-child(3){animation-delay:.2s}.loader-pixel:nth-child(4){animation-delay:.1s}.loader-pixel:nth-child(5){animation-name:pixelPulseAccent;animation-delay:.2s}.loader-pixel:nth-child(6){animation-delay:.3s}.loader-pixel:nth-child(7){animation-delay:.2s}.loader-pixel:nth-child(8){animation-name:pixelPulseAccent;animation-delay:.3s}.loader-pixel:nth-child(9){animation-delay:.4s}@keyframes pixelPulseAccent{0%,60%,to{background:var(--color-border);transform:scale(.8);border-radius:var(--radius-sm)}30%{background:var(--color-coral);transform:scale(1.05);border-radius:var(--radius-md);box-shadow:0 0 12px #ff6b6b66}}.loader-text{font-family:var(--font-heading);font-size:15px;font-weight:500;color:var(--color-text-muted);letter-spacing:.02em}.loader-dots:after{content:"";animation:dots 1.5s steps(4,end) infinite}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.toolbar-group{display:flex;align-items:center;gap:4px}.toolbar-label{font-size:11px;color:var(--color-text-light);white-space:nowrap;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-right:4px}.toolbar-value{font-size:12px;color:var(--color-text-muted);min-width:24px;text-align:center;font-weight:600;font-family:var(--font-heading)}.toolbar-divider{width:2px;height:24px;background:var(--color-border);border-radius:1px;margin:0 4px}.toolbar-spacer{flex:1}.toolbar-back{display:flex;align-items:center;gap:6px;font-weight:600}.toolbar-toggle-group{display:flex;background:var(--color-bg);border-radius:var(--radius-full);padding:3px;border:1.5px solid var(--color-border)}.toolbar-toggle-group .btn{padding:5px 14px;font-size:12px;border:none;background:transparent;color:var(--color-text-muted);border-radius:var(--radius-full);box-shadow:none}.toolbar-toggle-group .btn:hover{transform:none;color:var(--color-text)}.toolbar-toggle-group .btn.active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #6c5ce740}.toolbar-toggle-group .btn.active:hover{background:var(--color-primary-hover);color:#fff}.toolbar-checkbox{background:var(--color-surface);color:var(--color-text-muted);border:2px solid var(--color-border);border-radius:var(--radius-full);padding:5px 12px;font-size:12px;font-weight:600;gap:5px;box-shadow:none}.toolbar-checkbox:hover{border-color:var(--color-border-strong);color:var(--color-text)}.toolbar-check-indicator{display:inline-block;width:14px;height:14px;border-radius:4px;border:2px solid var(--color-border-strong);position:relative;transition:background var(--transition-fast),border-color var(--transition-fast);flex-shrink:0}.toolbar-checkbox.active .toolbar-check-indicator{background:var(--color-primary);border-color:var(--color-primary)}.toolbar-checkbox.active .toolbar-check-indicator:after{content:"";position:absolute;left:3px;top:.5px;width:4px;height:7px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.toolbar-checkbox.active{border-color:var(--color-primary);color:var(--color-primary);background:#6c5ce70f;box-shadow:none}.toolbar-checkbox.active:hover{background:#6c5ce71a;color:var(--color-primary)}input[type=range]{-webkit-appearance:none;appearance:none;height:6px;background:var(--color-border);border-radius:var(--radius-full);outline:none;width:90px;transition:background var(--transition-fast)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--color-primary);border-radius:50%;cursor:pointer;border:3px solid var(--color-surface);box-shadow:0 2px 8px #6c5ce74d;transition:transform var(--transition-bounce),box-shadow var(--transition-fast)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 3px 12px #6c5ce766}.export-wrap{position:relative}.toolbar-export{display:flex;align-items:center;gap:6px}.export-dropdown{display:none;position:absolute;top:calc(100% + 8px);right:0;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:200px;z-index:20;overflow:hidden;padding:4px}.export-dropdown.visible{display:block;animation:popIn .2s cubic-bezier(.34,1.56,.64,1)}.export-option{display:block;width:100%;padding:10px 14px;text-align:left;background:none;border:none;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);border-radius:var(--radius-sm)}.export-option:hover{background:var(--color-bg);transform:translate(2px)}.btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 2px 8px #6c5ce740}.btn.active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff}.editor-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(20px);padding:12px 24px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:14px;font-weight:600;z-index:100;opacity:0;transition:opacity var(--transition-normal),transform var(--transition-normal);pointer-events:none}.editor-toast.visible{opacity:1;transform:translate(-50%) translateY(0)}.editor-toast-error{background:var(--color-coral);color:#fff;box-shadow:0 4px 20px #ff6b6b4d}.editor-toast-info{background:var(--color-surface);color:var(--color-text);border:2px solid var(--color-border);box-shadow:var(--shadow-lg)}.dropzone-loading{pointer-events:none;border-color:var(--color-purple-light);background:#6c5ce70a}.dropzone-loading .dropzone-icon{animation:float 1.5s ease-in-out infinite}.dropzone-error{border-color:var(--color-coral)!important;background:#ff6b6b0a!important}.dropzone-error-text{color:var(--color-coral)!important;font-weight:600;margin:0}.toolbar-export-res{font-size:10px;color:var(--color-text-light);font-weight:500;white-space:nowrap;margin-left:2px}.legend-item.locked{background:#6c5ce71a;outline:2px solid var(--color-primary);outline-offset:-1px}.legend-item:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(max-width:900px){.hero-split{grid-template-columns:1fr;gap:40px;min-height:auto;padding:80px 24px 48px;text-align:center}.hero-left,.hero-right{align-items:center}.hero-brand{justify-content:center}.hero-title,.hero-subtitle{text-align:center}.steps{justify-content:center}.dropzone{margin:0 auto}.projects-section{padding:40px 24px 0}.shape-1,.shape-2,.shape-6{display:none}}@media(max-width:768px){.hero-split{padding:60px 20px 40px;gap:32px}.steps{gap:10px}.step-icon{width:52px;height:52px}.step-arrow svg{width:18px;height:18px}.dropzone{padding:36px 20px}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.editor-toolbar{gap:6px;padding:6px 10px}.toolbar-label,.toolbar-export-res{display:none}input[type=range]{width:60px}}@media(max-width:480px){.hero-split{padding:48px 16px 32px}.hero-title{font-size:28px}.step-label{font-size:11px}.step-arrow{display:none}.steps{gap:8px}.elegant-shape{display:none}}
