@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.p.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_dfbb94ae-module__cY9fIW__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_dfbb94ae-module__cY9fIW__variable{--font-inter:"Inter","Inter Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.invisible{visibility:hidden}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.hidden{display:none}.inline-block{display:inline-block}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.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,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--color-bg:#0a0f1e;--color-surface:#111827;--color-surface-2:#1a2235;--color-surface-3:#243049;--color-border:#ffffff14;--color-border-active:#6366f199;--color-text:#f1f5f9;--color-text-muted:#94a3b8;--color-text-faint:#475569;--color-accent:#6366f1;--color-accent-hover:#818cf8;--color-accent-glow:#6366f159;--color-danger:#ef4444;--color-danger-hover:#f87171;--color-success:#22c55e;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 8px 32px #0009;--shadow-glow:0 0 24px var(--color-accent-glow);--radius-sm:6px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--ease-spring:cubic-bezier(.34,1.56,.64,1);--ease-smooth:cubic-bezier(.4,0,.2,1);--font-sans:"Inter",system-ui,-apple-system,sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;min-height:100dvh;line-height:1.6;overflow-x:hidden}@keyframes markerScaleIn{0%{opacity:0;transform:translate(-50%,-50%)scale(0)rotate(-20deg)}to{opacity:1;transform:translate(-50%,-50%)scale(1)rotate(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 0 var(--color-accent-glow)}50%{box-shadow:0 0 20px 6px var(--color-accent-glow)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-surface-3);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-faint)}.app-shell{background:radial-gradient(ellipse 120% 60% at 0% 0%,#6366f11f 0%,transparent 60%),radial-gradient(ellipse 80% 50% at 100% 100%,#8b5cf614 0%,transparent 60%),var(--color-bg);flex-direction:column;min-height:100dvh;display:flex}.app-header{z-index:50;border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(16px);background:#0a0f1ed1;position:sticky;top:0}.app-header__inner{justify-content:space-between;align-items:center;gap:1rem;max-width:1400px;height:60px;margin:0 auto;padding:0 1.25rem;display:flex}.app-logo{align-items:center;gap:.5rem;text-decoration:none;display:flex}.app-logo__emoji{filter:drop-shadow(0 0 8px #ffc80099);font-size:1.6rem;line-height:1}.app-logo__text{letter-spacing:-.03em;-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#818cf8 0%,#c084fc 50%,#f472b6 100%);-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:800}.app-main{flex-direction:column;flex:1;width:100%;max-width:1400px;margin:0 auto;padding:1.5rem 1.25rem;display:flex}.upload-screen{min-height:70vh;animation:fadeInUp .5s var(--ease-smooth)both;flex:1;justify-content:center;align-items:center;display:flex}.uploader-zone{border:2px dashed var(--color-border-active);border-radius:var(--radius-xl);background:var(--color-surface);text-align:center;width:100%;max-width:540px;transition:all .2s var(--ease-smooth);padding:3.5rem 2.5rem;position:relative;overflow:hidden}.uploader-zone:before{content:"";pointer-events:none;background:linear-gradient(135deg,#6366f10a,#0000);position:absolute;inset:0}.uploader-zone--dragging{border-color:var(--color-accent);background:var(--color-surface-2);box-shadow:var(--shadow-glow);transform:scale(1.01)}.uploader-icon-wrap{background:linear-gradient(135deg,#6366f133,#8b5cf626);border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;margin:0 auto 1.5rem;animation:3s ease-in-out infinite pulse-glow;display:flex}.uploader-icon{color:var(--color-accent)}.uploader-title{color:var(--color-text);margin-bottom:.5rem;font-size:1.35rem;font-weight:700}.uploader-subtitle{color:var(--color-text-muted);margin-bottom:2rem;font-size:.9rem;line-height:1.5}.uploader-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all .18s var(--ease-smooth);white-space:nowrap;font-size:.9rem;font-weight:600;font-family:var(--font-sans);border:none;align-items:center;gap:.4rem;padding:.6rem 1.2rem;display:inline-flex}.btn:active{transform:scale(.96)}.btn--primary{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 4px 14px #6366f173}.btn--primary:hover{background:linear-gradient(135deg,#818cf8,#a78bfa);transform:translateY(-1px);box-shadow:0 6px 20px #6366f199}.btn--secondary{background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover{background:var(--color-surface-3);border-color:#ffffff26;transform:translateY(-1px)}.btn--danger-solid{color:#fff;background:linear-gradient(135deg,#dc2626,#ef4444);font-weight:700;box-shadow:0 4px 14px #dc262666}.btn--danger-solid:hover{background:linear-gradient(135deg,#ef4444,#f87171);transform:translateY(-1px);box-shadow:0 6px 20px #dc26268c}.editor-layout{animation:fadeInUp .4s var(--ease-smooth)both;flex:1;gap:1.25rem;display:flex}.side-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:220px;min-width:200px;height:fit-content;box-shadow:var(--shadow-md);flex-direction:column;flex-shrink:0;gap:0;padding:1rem .875rem;display:flex;position:sticky;top:76px}.side-panel-divider{background:var(--color-border);height:1px;margin:.75rem 0}.side-panel-hint{color:var(--color-text-faint);text-align:center;padding:0 .25rem;font-size:.72rem;line-height:1.5}.toolbar-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-faint);margin-bottom:.5rem;font-size:.7rem;font-weight:600}.icon-selector{width:100%}.icon-grid{grid-template-columns:repeat(4,1fr);gap:.3rem;display:grid}.icon-btn{border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all .15s var(--ease-smooth);font-family:var(--font-sans);background:0 0;border:1.5px solid #0000;flex-direction:column;justify-content:center;align-items:center;gap:.15rem;padding:.45rem .25rem;display:flex}.icon-btn:hover{background:var(--color-surface-2);border-color:var(--color-border)}.icon-btn--active{border-color:var(--color-accent);background:#6366f126;box-shadow:0 0 8px #6366f14d}.icon-btn__label{color:var(--color-text-faint);text-transform:uppercase;letter-spacing:.04em;font-size:.58rem;font-weight:500;line-height:1}.icon-btn--active .icon-btn__label{color:#a5b4fc}.color-selector{width:100%}.color-grid{grid-template-columns:repeat(4,1fr);gap:.4rem;display:grid}.color-swatch{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:all .15s var(--ease-smooth);box-shadow:var(--shadow-sm);border:2px solid #0000;justify-content:center;align-items:center;display:flex}.color-swatch:hover{transform:scale(1.12);box-shadow:0 4px 12px #00000080}.color-swatch--active{border-color:#fff;transform:scale(1.08);box-shadow:0 0 0 3px #fff3,0 4px 12px #00000080}.marker-count{background:var(--color-surface-2);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.5rem .75rem;display:flex}.marker-count__label{color:var(--color-text-muted);font-size:.75rem}.marker-count__value{color:var(--color-accent-hover);font-size:1rem;font-weight:700}.canvas-area{flex-direction:column;flex:1;gap:.75rem;min-width:0;display:flex}.canvas-scroll-area{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);flex:1;min-height:400px;position:relative;overflow:auto}.canvas-scale-wrapper{will-change:transform}.canvas-image{pointer-events:none;-webkit-user-select:none;user-select:none;max-width:100%;height:auto;display:block}.canvas-image-container{line-height:0;display:inline-block;position:relative}.zoom-controls{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:fit-content;box-shadow:var(--shadow-sm);align-items:center;gap:.375rem;padding:.35rem .5rem;display:flex}.zoom-btn{border-radius:var(--radius-sm);background:var(--color-surface-2);width:32px;height:32px;color:var(--color-text);cursor:pointer;transition:all .15s var(--ease-smooth);font-family:var(--font-sans);border:none;justify-content:center;align-items:center;display:flex}.zoom-btn:hover:not(:disabled){background:var(--color-surface-3);color:var(--color-accent-hover)}.zoom-btn:disabled{opacity:.35;cursor:not-allowed}.zoom-level{color:var(--color-text-muted);text-align:center;cursor:pointer;min-width:52px;font-size:.8rem;font-weight:700;font-family:var(--font-sans);background:0 0;border:none;padding:0 .5rem;transition:color .15s}.zoom-level:hover{color:var(--color-accent-hover)}.toolbar{align-items:center;gap:.375rem;display:flex}.toolbar-divider{background:var(--color-border);width:1px;height:24px;margin:0 .25rem}.toolbar-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface-2);color:var(--color-text);cursor:pointer;transition:all .15s var(--ease-smooth);white-space:nowrap;font-size:.82rem;font-weight:500;font-family:var(--font-sans);align-items:center;gap:.35rem;padding:.4rem .75rem;display:inline-flex}.toolbar-btn:hover:not(:disabled){background:var(--color-surface-3);border-color:#ffffff26;transform:translateY(-1px)}.toolbar-btn:disabled{opacity:.35;cursor:not-allowed}.toolbar-btn:active:not(:disabled){transform:scale(.96)}.toolbar-btn--accent{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-color:#0000;box-shadow:0 2px 10px #6366f166}.toolbar-btn--accent:hover:not(:disabled){background:linear-gradient(135deg,#818cf8,#a78bfa);box-shadow:0 4px 16px #6366f18c}.toolbar-btn--danger:hover:not(:disabled){color:var(--color-danger-hover);background:#ef444426;border-color:#ef444466}.toolbar-btn--warning:hover:not(:disabled){color:#facc15;background:#eab30826;border-color:#eab30873}.app-footer{border-top:1px solid var(--color-border);text-align:center;padding:.75rem 1.25rem}.app-footer p{color:var(--color-text-faint);font-size:.72rem}.marker-item{transition:opacity .18s var(--ease-smooth),filter .18s}.marker-item:hover{filter:drop-shadow(0 0 6px #fff9)brightness(1.3)!important;opacity:1!important}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.canvas-topbar{flex-wrap:wrap;align-items:center;gap:.625rem;display:flex}.current-selection-badge{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:center;gap:.4rem;padding:.35rem .75rem;display:flex}.selection-dot{border:1.5px solid #ffffff4d;border-radius:50%;flex-shrink:0;width:10px;height:10px}.selection-label{color:var(--color-text-muted);text-transform:capitalize;font-size:.78rem;font-weight:500}.settings-toggle-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:all .15s var(--ease-smooth);font-size:.82rem;font-weight:600;font-family:var(--font-sans);box-shadow:var(--shadow-sm);align-items:center;gap:.35rem;height:38px;padding:.38rem .85rem;display:inline-flex}.settings-toggle-btn:hover{background:var(--color-surface-2);border-color:var(--color-accent);color:var(--color-accent-hover)}.settings-toggle-btn--active{border-color:var(--color-accent);color:var(--color-accent-hover);box-shadow:var(--shadow-glow);background:#6366f126}.settings-icon--spin{animation:3s linear infinite spin}.settings-panel{background:var(--color-surface);border:1px solid var(--color-border-active);border-radius:var(--radius-lg);width:280px;box-shadow:var(--shadow-lg),var(--shadow-glow);animation:fadeInUp .18s var(--ease-spring)both;padding:0;overflow:hidden}.settings-panel__header{justify-content:space-between;align-items:center;padding:.75rem 1rem .5rem;display:flex}.settings-panel__title{color:var(--color-text);letter-spacing:-.01em;font-size:.85rem;font-weight:700}.settings-panel__close{border-radius:var(--radius-sm);background:var(--color-surface-2);width:24px;height:24px;color:var(--color-text-muted);cursor:pointer;font-family:var(--font-sans);border:none;justify-content:center;align-items:center;transition:all .12s;display:flex}.settings-panel__close:hover{background:var(--color-surface-3);color:var(--color-text)}.settings-panel__preview{background:var(--color-surface-2);align-items:center;gap:.45rem;padding:.4rem 1rem;display:flex}.settings-preview__label{color:var(--color-text-faint);font-size:.72rem}.settings-preview__dot{border:1.5px solid #ffffff4d;border-radius:50%;flex-shrink:0;width:12px;height:12px}.settings-preview__icon-name{color:var(--color-text-muted);text-transform:capitalize;font-size:.78rem;font-weight:600}.settings-panel__divider{background:var(--color-border);height:1px;margin:0}.settings-panel .icon-selector,.settings-panel .color-selector{padding:.625rem .875rem}.settings-panel .icon-grid{grid-template-columns:repeat(5,1fr);gap:.25rem}.settings-panel .color-grid{grid-template-columns:repeat(8,1fr);gap:.3rem}.settings-panel .color-swatch{border-radius:50%}.settings-panel__footer{text-align:center;padding:.5rem 1rem .75rem}.settings-panel__count{color:var(--color-text-faint);font-size:.75rem}.size-section{padding:.625rem .875rem}.size-presets{gap:.3rem;margin-bottom:.625rem;display:flex}.size-preset-btn{border-radius:var(--radius-sm);border:1.5px solid var(--color-border);background:var(--color-surface-2);color:var(--color-text-muted);cursor:pointer;transition:all .15s var(--ease-smooth);font-size:.7rem;font-weight:700;font-family:var(--font-sans);text-align:center;flex:1;padding:.3rem 0}.size-preset-btn:hover{background:var(--color-surface-3);color:var(--color-text);border-color:#fff3}.size-preset-btn--active{border-color:var(--color-accent);color:#a5b4fc;background:#6366f133}.size-slider-row{align-items:center;gap:.4rem;margin-bottom:.5rem;display:flex}.size-slider-min,.size-slider-max{color:var(--color-text-faint);white-space:nowrap;min-width:18px;font-size:.65rem}.size-slider-val{color:var(--color-accent-hover);white-space:nowrap;text-align:right;min-width:32px;font-size:.72rem;font-weight:700}.size-slider{appearance:none;background:linear-gradient(to right,var(--color-accent)0%,var(--color-accent)calc((var(--val,16) - 10)/(48 - 10)*100%),var(--color-surface-3)calc((var(--val,16) - 10)/(48 - 10)*100%),var(--color-surface-3)100%);cursor:pointer;border-radius:99px;outline:none;flex:1;height:4px}.size-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--color-accent);cursor:pointer;border:2px solid #fff;border-radius:50%;width:16px;height:16px;transition:transform .1s,box-shadow .1s;box-shadow:0 0 6px #6366f199}.size-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 10px #6366f1cc}.size-slider::-moz-range-thumb{background:var(--color-accent);cursor:pointer;border:2px solid #fff;border-radius:50%;width:16px;height:16px}.size-preview-wrap{background:var(--color-surface-2);border-radius:var(--radius-sm);border:1px dashed var(--color-border);justify-content:center;align-items:center;min-height:56px;display:flex}.settings-preview__size{color:var(--color-accent-hover);margin-left:auto;font-size:.7rem;font-weight:700}.confirm-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);animation:fadeInUp .18s var(--ease-smooth)both;background:#000000a6;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);text-align:center;width:100%;max-width:380px;box-shadow:var(--shadow-lg);animation:fadeInUp .22s var(--ease-spring)both;padding:2rem 2rem 1.5rem}.confirm-icon{margin-bottom:.75rem;font-size:2.5rem;line-height:1}.confirm-title{color:var(--color-text);margin-bottom:.5rem;font-size:1.15rem;font-weight:700}.confirm-body{color:var(--color-text-muted);margin-bottom:1.5rem;font-size:.875rem;line-height:1.6}.confirm-body strong{color:var(--color-text)}.confirm-actions{justify-content:center;gap:.75rem;display:flex}.btn--warning-solid{color:#111;background:linear-gradient(135deg,#d97706,#f59e0b);font-weight:700;box-shadow:0 4px 14px #d9770666}.btn--warning-solid:hover{background:linear-gradient(135deg,#f59e0b,#fbbf24);transform:translateY(-1px);box-shadow:0 6px 20px #d977068c}.hydration-loader{justify-content:center;align-items:center;min-height:100dvh;display:flex}.hydration-spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@media (max-width:768px){.app-header__inner{height:52px;padding:0 .875rem}.app-logo__text{font-size:1rem}.app-main{padding:.875rem}.toolbar-btn__label{display:none}.toolbar-btn{padding:.4rem .5rem}.uploader-zone{padding:2rem 1.25rem}.settings-panel{width:260px}.settings-panel .color-grid{grid-template-columns:repeat(4,1fr)}.current-selection-badge{display:none}}@media (max-width:480px){.canvas-topbar{gap:.4rem}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
