:root{--background:#1c1c31;--foreground:#fafafa;--card:#09090b;--card-foreground:#fafafa;--popover:#09090b;--popover-foreground:#fafafa;--primary:#fff;--primary-foreground:#18181b;--secondary:#27272a;--secondary-foreground:#fafafa;--muted:#27272a;--muted-foreground:#a1a1aa;--accent:#27272a;--accent-foreground:#fafafa;--destructive:#7f1d1d;--destructive-foreground:#fafafa;--border:#27272a;--input:#27272a;--ring:#d4d4d8;--radius:0.5rem;--success:#22c55e;--warning:#eab308;--info:#3b82f6;--font-sans:"Figtree",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace}*,:after,:before{box-sizing:border-box}button{font-weight:700}body,button{font-family:var(--font-sans)}body{margin:0;padding:0;background:var(--background);color:var(--foreground);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.3}h1{font-size:2.25rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p{margin:0;color:var(--muted-foreground)}a{color:var(--foreground);text-decoration:none;transition:opacity .2s}a:hover{opacity:.8}code{font-family:var(--font-mono);font-size:.875em;background:var(--secondary);padding:.2em .4em;border-radius:calc(var(--radius) - 2px)}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 1rem}.container-sm{max-width:640px}.container-md{max-width:768px}.container-lg{max-width:1024px}.container-xl{max-width:1280px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.card-header{padding:1.5rem 1.5rem 0}.card-title{font-size:1.25rem;font-weight:600}.card-description{color:var(--muted-foreground);font-size:.875rem;margin-top:.25rem}.card-content{padding:1.5rem}.card-footer{padding:0 1.5rem 1.5rem;display:flex;gap:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--font-sans);font-size:.875rem;font-weight:500;padding:.5rem 1rem;border-radius:var(--radius);border:none;cursor:pointer;transition:all .2s;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.5;pointer-events:none}.btn-primary{background:var(--primary);color:var(--primary-foreground)}.btn-primary:hover{background:hsla(0,0%,100%,.9)}.btn-secondary{background:var(--secondary);color:var(--secondary-foreground)}.btn-secondary:hover{background:#3f3f46}.btn-ghost{background:transparent;color:var(--foreground)}.btn-ghost:hover{background:var(--accent)}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--foreground)}.btn-outline:hover{background:var(--accent)}.btn-destructive{background:#dc2626;color:#fff}.btn-destructive:hover{background:#b91c1c}.btn-sm{font-size:.75rem;padding:.375rem .75rem}.btn-lg{font-size:1rem;padding:.75rem 1.5rem}.btn-icon{padding:.5rem;width:2.5rem;height:2.5rem}.btn-icon.btn-sm{width:2rem;height:2rem;padding:.375rem}.input{width:100%;font-family:var(--font-sans);font-size:.875rem;padding:.5rem .75rem;background:var(--background);border:1px solid var(--border);border-radius:var(--radius);color:var(--foreground);transition:border-color .2s,box-shadow .2s}.input:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 2px hsla(0,0%,100%,.1)}.input::placeholder{color:var(--muted-foreground)}.input:disabled{opacity:.5;cursor:not-allowed}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem;cursor:pointer}.custom-select{position:relative;width:100%}.custom-select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--background);border:1px solid var(--border);border-radius:var(--radius);color:var(--foreground);font-size:.875rem;cursor:pointer;transition:all .2s}.custom-select-trigger:hover{border-color:var(--muted-foreground)}.custom-select-trigger:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 2px hsla(0,0%,100%,.1)}.custom-select-trigger.open{border-color:var(--ring);border-bottom-left-radius:0;border-bottom-right-radius:0}.custom-select-trigger .chevron{transition:transform .2s;opacity:.6}.custom-select-trigger.open .chevron{transform:rotate(180deg)}.custom-select-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--card);border:1px solid var(--border);border-top:none;border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius);max-height:200px;overflow-y:auto;z-index:100;animation:dropdown-in .15s ease}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.custom-select-option{padding:.5rem .75rem;cursor:pointer;transition:background .15s;font-size:.875rem}.custom-select-option:hover{background:var(--secondary)}.custom-select-option.selected{background:var(--accent);color:var(--primary)}.custom-select-option:last-child{border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius)}.textarea{min-height:80px;resize:vertical}.badge{display:inline-flex;align-items:center;font-size:.75rem;font-weight:500;padding:.25rem .625rem;border-radius:9999px;border:1px solid transparent}.badge-default{background:var(--primary);color:var(--primary-foreground)}.badge-secondary{background:var(--secondary);color:var(--secondary-foreground)}.badge-outline{background:transparent;border-color:var(--border);color:var(--foreground)}.badge-success{background:rgba(34,197,94,.2);color:#4ade80}.badge-destructive{background:rgba(220,38,38,.2);color:#f87171}.separator{height:1px;background:var(--border);margin:1.5rem 0}.separator-vertical{width:1px;height:auto;margin:0 1rem}.code-block{background:rgba(0,0,0,.5);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;font-family:var(--font-mono);font-size:.875rem;overflow-x:auto}.code-block .param{color:#f472b6}.code-block .value{color:#4ade80}.code-block .path{color:#fbbf24}.code-block .muted{color:var(--muted-foreground)}.toast{position:fixed;bottom:1rem;right:1rem;background:var(--foreground);color:var(--background);padding:.75rem 1.25rem;border-radius:var(--radius);font-weight:500;font-size:.875rem;animation:toast-in .3s ease;z-index:1000}@keyframes toast-in{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s}.dropzone:hover{border-color:var(--muted-foreground);background:hsla(0,0%,100%,.02)}.dropzone.active{border-color:var(--primary);background:hsla(0,0%,100%,.05)}.dropzone-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.dropzone-text{font-size:1rem;margin-bottom:.5rem}.dropzone-subtext{font-size:.875rem;color:var(--muted-foreground)}.grid{display:grid;grid-gap:1rem;gap:1rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}@media (max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mx-auto{margin-left:auto;margin-right:auto}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-4xl{font-size:2.25rem}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-mono{font-family:var(--font-mono)}.text-muted{color:var(--muted-foreground)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-destructive{color:#f87171}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.border{border:1px solid var(--border)}.border-t{border-top:1px solid var(--border)}.border-b{border-bottom:1px solid var(--border)}.rounded{border-radius:var(--radius)}.rounded-lg{border-radius:calc(var(--radius) + 2px)}.rounded-xl{border-radius:calc(var(--radius) + 6px)}.rounded-full{border-radius:9999px}.bg-card{background:var(--card)}.bg-muted{background:var(--muted)}.bg-secondary,.progress{background:var(--secondary)}.progress{width:100%;height:.25rem;border-radius:9999px;overflow:hidden}.progress-bar{height:100%;background:var(--primary);transition:width .3s}.skeleton{background:linear-gradient(90deg,var(--secondary) 25%,var(--muted) 50%,var(--secondary) 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius)}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.checkbox{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:1rem;height:1rem;border:1px solid var(--border);border-radius:4px;background:var(--background);cursor:pointer;transition:all .2s;position:relative}.checkbox:checked{background:var(--primary);border-color:var(--primary)}.checkbox:checked:after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid var(--primary-foreground);border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox:focus{outline:none;box-shadow:0 0 0 2px hsla(0,0%,100%,.1)}.switch{position:relative;width:2.75rem;height:1.5rem;background:var(--secondary);border-radius:9999px;cursor:pointer;transition:background .2s}.switch:after{content:"";position:absolute;top:2px;left:2px;width:1.25rem;height:1.25rem;background:var(--foreground);border-radius:50%;transition:transform .2s}.switch.active{background:var(--primary)}.switch.active:after{transform:translateX(1.25rem);background:var(--primary-foreground)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:.5rem;background:var(--secondary);border-radius:9999px;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:1.25rem;height:1.25rem;background:var(--primary);border-radius:50%;cursor:pointer;-webkit-transition:transform .2s;transition:transform .2s}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}input[type=range]::-moz-range-thumb{width:1.25rem;height:1.25rem;background:var(--primary);border:none;border-radius:50%;cursor:pointer}.gallery-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}.gallery-item:hover{border-color:var(--muted-foreground)}.gallery-item img{width:100%;height:140px;object-fit:cover;display:block}.gallery-item-info{padding:.75rem}.gallery-item-name{font-size:.75rem;color:var(--muted-foreground);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:.5rem}.gallery-item-actions{display:flex;gap:.25rem}@media (max-width:640px){h1{font-size:1.75rem}h2{font-size:1.25rem}.container{padding:0 1rem}.hide-mobile{display:none}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--secondary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}::selection{background:var(--primary);color:var(--primary-foreground)}.hero{text-align:center;padding:5rem 1.5rem 4rem;border-bottom:1px solid var(--border)}.hero-icon{font-size:4rem;margin-bottom:1rem}.hero-title{font-size:3rem;font-weight:800;margin-bottom:1rem}.hero-subtitle{font-size:1.125rem;color:var(--muted-foreground);max-width:600px;margin:0 auto;line-height:1.7}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:1.25rem;gap:1.25rem;max-width:800px;margin:3rem auto 0}.feature-item{text-align:center;padding:1.5rem 1rem;background:var(--secondary);border-radius:var(--radius);border:1px solid var(--border)}.feature-icon{font-size:2rem;margin-bottom:.5rem}.feature-title{font-weight:600;margin-bottom:.25rem}.feature-desc{font-size:.875rem;color:var(--muted-foreground)}.section-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;gap:.75rem}.category-title,.section-title{display:flex;align-items:center}.category-title{font-size:1rem;font-weight:600;margin-bottom:1rem;gap:.5rem;color:var(--foreground)}.params-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));grid-gap:.75rem;gap:.75rem}.colors-list,.formats-list,.positions-list{display:flex;gap:.5rem;flex-wrap:wrap}.color-chip{padding:.25rem .75rem;border-radius:var(--radius);font-size:.75rem;font-family:var(--font-mono)}.examples-list{display:flex;flex-direction:column;gap:.5rem}.example-item{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;padding:1rem 1.25rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius)}.example-url{font-family:var(--font-mono);font-size:.875rem;color:var(--primary)}.example-desc,.footer{font-size:.875rem;color:var(--muted-foreground)}.footer{text-align:center;padding:2.5rem 1rem;border-top:1px solid var(--border)}.page-header{justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.page-header,.page-title{display:flex;align-items:center}.page-title{font-size:1.5rem;font-weight:700;gap:.5rem}.nav-links{display:flex;gap:.5rem}.upload-page{min-height:100vh;padding:2rem 1rem}.upload-container{max-width:900px;margin:0 auto}.result-box{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.5rem}.result-title{font-weight:600;color:#4ade80;margin-bottom:.5rem}.result-url{display:flex;align-items:center;gap:.75rem;background:var(--card);border-radius:var(--radius);padding:.75rem 1rem;margin-top:.75rem}.result-url code{flex:1 1;font-size:.8rem;color:var(--primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:transparent;padding:0}.preview-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.5rem}.preview-image{max-width:100%;max-height:300px;border-radius:var(--radius);margin-bottom:1rem;display:block;margin-left:auto;margin-right:auto}.preview-actions{display:flex;gap:.5rem;flex-wrap:wrap}.preview-actions .input{flex:1 1;min-width:200px}.gallery-section{margin-top:3rem}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.gallery-title{font-size:1.25rem;font-weight:600}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:1rem;gap:1rem}.gallery-empty{text-align:center;padding:3rem;color:var(--muted-foreground);background:var(--card);border:1px solid var(--border);border-radius:var(--radius)}.generator-page{min-height:100vh;padding:2rem 1rem}.generator-container{max-width:1200px;margin:0 auto}.generator-grid{display:grid;grid-template-columns:1fr 400px;grid-gap:2rem;gap:2rem}@media (max-width:900px){.generator-grid{grid-template-columns:1fr}}.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.panel-title{font-size:1rem;font-weight:600;margin-bottom:1.25rem;align-items:center}.panel-title,.tabs{display:flex;gap:.5rem}.tabs{margin-bottom:1rem}.tab{padding:.5rem 1rem;border-radius:var(--radius);background:var(--secondary);border:none;color:var(--muted-foreground);cursor:pointer;font-size:.875rem;transition:all .2s}.tab:hover{color:var(--foreground)}.tab.active{background:var(--primary);color:var(--primary-foreground)}.scroll-area{max-height:calc(100vh - 350px);overflow-y:auto;padding-right:.5rem}.param-category{font-size:.875rem;font-weight:600;margin-top:1.25rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);gap:.5rem}.param-category,.param-row{display:flex;align-items:center}.param-row{gap:.75rem;margin-bottom:.5rem;padding:.5rem .75rem;border-radius:var(--radius);background:var(--secondary);transition:background .2s}.param-row.active{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2)}.param-name{font-family:var(--font-mono);font-size:.8rem;color:var(--primary);min-width:70px}.param-input{flex:1 1}.param-label{font-size:.75rem;color:var(--muted-foreground);margin-left:auto}.preview-container{background:repeating-conic-gradient(var(--secondary) 0 25%,transparent 0 50%) 50% /20px 20px;border-radius:var(--radius);padding:1.25rem;min-height:250px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.preview-container img{max-width:100%;max-height:350px;border-radius:var(--radius)}.url-box{background:var(--secondary);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.url-text{font-family:var(--font-mono);font-size:.8rem;word-break:break-all;line-height:1.6}.url-text .param{color:#f472b6}.url-text .value{color:#4ade80}.button-row{display:flex;gap:.5rem}.button-row .btn{flex:1 1}.presets{margin-top:1.25rem}.presets-title{font-size:.875rem;font-weight:600;margin-bottom:.75rem}.presets-list{display:flex;flex-wrap:wrap;gap:.5rem}.preset-btn{padding:.375rem .75rem;border-radius:var(--radius);background:var(--secondary);border:none;color:var(--foreground);font-size:.75rem;cursor:pointer;transition:background .2s}.preset-btn:hover{background:var(--muted)}.error-box{background:rgba(220,38,38,.1);border:1px solid rgba(220,38,38,.3);border-radius:var(--radius);padding:1rem;margin-bottom:1.5rem;color:#f87171}