*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--font-sans),system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.fixed{position:fixed}.inset-0{inset:0}.z-50{z-index:50}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.block{display:block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-48{height:12rem}.min-h-screen{min-height:100vh}.w-14{width:3.5rem}.w-20{width:5rem}.w-full{width:100%}.min-w-0{min-width:0}.max-w-3xl{max-width:48rem}.max-w-7xl{max-width:80rem}.max-w-\[180px\]{max-width:180px}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.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}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded-2xl{border-radius:1rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.bg-\[\#FAFAFA\]{--tw-bg-opacity:1;background-color:rgb(250 250 250/var(--tw-bg-opacity,1))}.bg-black\/60{background-color:rgba(0,0,0,.6)}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.object-contain{-o-object-fit:contain;object-fit:contain}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.text-center{text-align:center}.text-right{text-align:right}.text-2xl{font-size:1.5rem;line-height:2rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.shadow-2xl{--tw-shadow:0 25px 50px -12px rgba(0,0,0,.25);--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--color-primary:#7c5cff;--color-primary-light:#a78bfa;--color-primary-dark:#5b3fd9;--color-accent:#ffb84d;--color-accent-light:#ffd08a;--color-bg:#f8f6fc;--color-text:#2d2a3a;--color-border:#e8e5f0;--color-card:#fff;--radius-lg:20px;--radius-md:14px;--radius-sm:10px;--shadow-card:0 2px 16px rgba(124,92,255,.06),0 1px 3px rgba(0,0,0,.04);--shadow-card-hover:0 4px 24px rgba(124,92,255,.1),0 2px 6px rgba(0,0,0,.06)}body{background-color:#ffefcc;color:#2d2a3a;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.page-upper-bg{background-image:linear-gradient(180deg,transparent 75%,#ffefcc),url(/pin-bead-bg-upper-full-1920x1300.png);background-size:100% auto;background-position:top;background-repeat:no-repeat;padding-bottom:48px}.card{border-radius:20px;--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding:1.25rem;border:1px solid #e8e5f0;box-shadow:var(--shadow-card);transition:box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-card-hover)}.btn-primary{cursor:pointer;border-radius:14px;padding:.625rem 1.5rem;font-weight:600;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.btn-primary:active{--tw-scale-x:0.98;--tw-scale-y:0.98;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.btn-primary{background:linear-gradient(135deg,#7c5cff,#6a4fe0 50%,#5b3fd9);box-shadow:0 4px 14px rgba(124,92,255,.25)}.btn-primary:hover{box-shadow:0 6px 20px rgba(124,92,255,.35);transform:translateY(-1px)}.btn-primary:active{box-shadow:0 2px 8px rgba(124,92,255,.2);transform:translateY(0)}.btn-primary:disabled{background:#c4bfd8;box-shadow:none;transform:none;cursor:not-allowed}.btn-outline{cursor:pointer;border-radius:14px;--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding:.625rem 1.5rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.btn-outline:active{--tw-scale-x:0.98;--tw-scale-y:0.98;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.btn-outline{border:2px solid #7c5cff;color:#7c5cff}.btn-outline:hover{background:rgba(124,92,255,.04);border-color:#5b3fd9;color:#5b3fd9}.zoom-btn{display:flex;height:2.25rem;width:2.25rem;cursor:pointer;align-items:center;justify-content:center;border-radius:10px;--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));font-size:.875rem;line-height:1.25rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;border:1px solid #e8e5f0;color:#6b6488}.zoom-btn:hover{background:#f8f6fc;border-color:#c4bfd8;color:#5b3fd9}.zoom-btn:active{transform:scale(.95);background:#ede9f7}.label-text{margin-bottom:.25rem;display:block;font-weight:500;color:#6b6488}.input-field,.label-text{font-size:.875rem;line-height:1.25rem}.input-field{border-radius:14px;--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding:.625rem .75rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;border:1.5px solid #e8e5f0;color:#2d2a3a}.input-field:focus{outline:none;border-color:#7c5cff;box-shadow:0 0 0 3px rgba(124,92,255,.1)}.input-field:hover{border-color:#c4bfd8}.tab-btn{border-radius:10px;padding:.5rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;border:1.5px solid #e8e5f0;color:#6b6488;background:#fff}.tab-btn:hover{border-color:#a78bfa;color:#5b3fd9;background:#faf8ff}.tab-btn.active{border-color:#7c5cff;color:#7c5cff;background:linear-gradient(135deg,rgba(124,92,255,.06),rgba(167,139,250,.06));box-shadow:0 2px 8px rgba(124,92,255,.1)}.toggle-btn-group{display:flex;background:#f4f2f8;border-radius:12px;padding:3px;gap:3px}.toggle-btn{flex:1 1 0%;border-radius:10px;padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;color:#6b6488;background:transparent}.toggle-btn:hover{color:#5b3fd9}.toggle-btn.active{color:#7c5cff;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.03)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d4d0e2;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#b8b2cc}.table-row-stripe:nth-child(2n){background:#faf9fd}.section-divider{height:1px;background:linear-gradient(90deg,transparent,#e8e5f0 20%,#e8e5f0 80%,transparent);margin:0}.color-dot{display:inline-block;border-radius:9999px;width:22px;height:22px;border:2px solid rgba(0,0,0,.06);box-shadow:inset 0 1px 2px hsla(0,0%,100%,.3),0 1px 2px rgba(0,0,0,.08)}.stat-card{border-radius:16px;padding:1rem;text-align:center;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;border:1px solid #e8e5f0}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.06)}.empty-state{padding-top:4rem;padding-bottom:4rem;text-align:center;color:#a9a3c1}.empty-state-icon{margin-left:auto;margin-right:auto;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#f4f2f8,#ede9f7);font-size:24px;font-weight:700;color:#c4bfd8;letter-spacing:2px}.site-header{background:transparent;border-bottom:1px solid hsla(0,0%,100%,.3)}.site-header-inner{margin-left:auto;margin-right:auto;max-width:80rem;padding:1rem}@media (min-width:640px){.site-header-inner{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width:1024px){.site-header-inner{padding-left:2rem;padding-right:2rem}}.site-logo{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#7c5cff,#a78bfa);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:#fff;letter-spacing:1px;box-shadow:0 4px 12px rgba(124,92,255,.2)}.site-title{font-size:22px;font-weight:700;color:#2d2a3a;letter-spacing:-.3px}.site-subtitle{font-size:13px;color:#9b95b5;margin-top:1px;font-weight:400}.image-preview-wrapper{position:relative;border-radius:16px;overflow:hidden;background:linear-gradient(135deg,#f8f6fc,#ede9f7);border:2px dashed #d4d0e2;transition:all .2s ease}.image-preview-wrapper:hover{border-color:#a78bfa}.upload-zone{border:2px dashed #d4d0e2;border-radius:20px;padding:32px 24px;text-align:center;cursor:pointer;transition:all .25s ease;background:linear-gradient(135deg,#fafafd,#f8f6fc)}.upload-zone:hover{border-color:#a78bfa;background:linear-gradient(135deg,#faf8ff,#f4f2f8);transform:translateY(-1px)}.upload-zone.dragging{border-color:#7c5cff;background:rgba(124,92,255,.03);transform:scale(1.02);box-shadow:0 0 0 4px rgba(124,92,255,.08)}.upload-zone-icon{width:56px;height:56px;margin:0 auto 12px;border-radius:50%;background:linear-gradient(135deg,#f4f2f8,#ede9f7);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#a78bfa}.sample-btn{width:100%;padding:14px;border-radius:14px;border:2px dashed #ffd08a;background:linear-gradient(135deg,#fffbf5,#fff6e8);color:#d4952a;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}.sample-btn:hover{background:linear-gradient(135deg,#fff8ed,#fff0d6);border-color:#ffb84d;color:#b87a1e;transform:translateY(-1px)}.sample-btn:active{transform:scale(.98)}.generate-btn{width:100%;padding:15px;border-radius:14px;border:none;color:#fff;font-weight:700;font-size:15px;cursor:pointer;background:linear-gradient(135deg,#8b6bff,#7c5cff 30%,#6a4fe0);box-shadow:0 4px 18px rgba(124,92,255,.3);transition:all .2s ease;letter-spacing:.5px}.generate-btn:hover{box-shadow:0 6px 24px rgba(124,92,255,.4);transform:translateY(-2px)}.generate-btn:active{box-shadow:0 2px 8px rgba(124,92,255,.2);transform:translateY(0)}.generate-btn:disabled{background:#d4d0e2;box-shadow:none;transform:none;color:#a9a3c1;cursor:not-allowed}.wave-divider{height:24px;background:repeating-linear-gradient(90deg,transparent,transparent 6px,#e8e5f0 0,#e8e5f0 7px);opacity:.5}.tip-box{background:linear-gradient(135deg,#fffbeb,#fff7d6);border:1px solid #ffe8a0;border-radius:12px;color:#9b7a20}.tip-box,.warning-box{padding:10px 14px;font-size:12px;line-height:1.5}.warning-box{background:linear-gradient(135deg,#fff5f5,#ffeded);border:1px solid #ffd4d4;border-radius:12px;color:#b04747}.canvas-container{border-radius:18px;border:1px solid #e8e5f0;background:#fafafd;overflow:hidden;box-shadow:inset 0 2px 8px rgba(0,0,0,.03)}.site-footer{text-align:center;padding:32px 0 24px;font-size:12px;color:#b8b2cc;border-top:1px solid #ede9f7;margin-top:40px}.data-table{width:100%;font-size:.875rem;line-height:1.25rem;border-collapse:separate;border-spacing:0}.data-table th{padding:.75rem;text-align:left;font-size:.75rem;line-height:1rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:#9b95b5;border-bottom:2px solid #ede9f7}.data-table td{padding:.75rem;border-bottom:1px solid #f4f2f8}.data-table tr:hover td{background:#faf9fd}@media (max-width:640px){.card{border-radius:16px;padding:16px}.upload-zone{padding:24px 16px;border-radius:16px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeInUp .4s ease-out}@keyframes pulse-glow{0%,to{box-shadow:0 4px 18px rgba(124,92,255,.3)}50%{box-shadow:0 4px 28px rgba(124,92,255,.45)}}.pulse-glow{animation:pulse-glow 2s ease-in-out infinite}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}@media (min-width:640px){.sm\:table-cell{display:table-cell}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width:1024px){.lg\:w-80{width:20rem}.lg\:flex-row{flex-direction:row}.lg\:px-8{padding-left:2rem;padding-right:2rem}}