*,: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:rgb(59 130 246/0.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:rgb(59 130 246/0.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.17 | 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:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;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}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.fixed{position:fixed}.inset-0{inset:0}.bottom-4{bottom:1rem}.left-0{left:0}.left-4{left:1rem}.right-0{right:0}.right-2{right:.5rem}.right-4{right:1rem}.top-2{top:.5rem}.top-4{top:1rem}.top-full{top:100%}.z-1000{z-index:1000}.z-50{z-index:50}.z-\[1000\]{z-index:1000}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-8{margin-bottom:2rem}.mr-2{margin-right:.5rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.block{display:block}.hidden{display:none}.h-10{height:2.5rem}.h-12{height:3rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-\[600px\]{height:600px}.max-h-48{max-height:12rem}.max-h-56{max-height:14rem}.max-h-60{max-height:15rem}.min-h-20{min-height:5rem}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-12{width:3rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-8{width:2rem}.min-w-64{min-width:16rem}.min-w-80{min-width:20rem}.max-w-64{max-width:16rem}.max-w-80{max-width:20rem}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.rotate-180{--tw-rotate:180deg}.rotate-180,.transform{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))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.flex-wrap{flex-wrap:wrap}.gap-1{gap:.25rem}.gap-6{gap:1.5rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.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))}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-md{border-radius:.375rem}.rounded-l-lg{border-top-left-radius:.5rem;border-bottom-left-radius:.5rem}.rounded-r-lg{border-top-right-radius:.5rem;border-bottom-right-radius:.5rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-blue-200{--tw-border-opacity:1;border-color:rgb(191 219 254/var(--tw-border-opacity,1))}.border-blue-500{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.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))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-gray-800{--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity,1))}.border-green-200{--tw-border-opacity:1;border-color:rgb(187 247 208/var(--tw-border-opacity,1))}.border-green-600{--tw-border-opacity:1;border-color:rgb(22 163 74/var(--tw-border-opacity,1))}.border-red-600{--tw-border-opacity:1;border-color:rgb(220 38 38/var(--tw-border-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-gray-500{--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity,1))}.bg-green-50{--tw-bg-opacity:1;background-color:rgb(240 253 244/var(--tw-bg-opacity,1))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-purple-500{--tw-bg-opacity:1;background-color:rgb(168 85 247/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-blue-50{--tw-gradient-from:#eff6ff var(--tw-gradient-from-position);--tw-gradient-to:rgb(239 246 255/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-white{--tw-gradient-to:rgb(255 255 255/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#fff var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-indigo-50{--tw-gradient-to:#eef2ff var(--tw-gradient-to-position)}.to-slate-50{--tw-gradient-to:#f8fafc var(--tw-gradient-to-position)}.object-contain{-o-object-fit:contain;object-fit:contain}.p-3{padding:.75rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-1{padding-bottom:.25rem}.pt-2{padding-top:.5rem}.text-left{text-align:left}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-6xl{line-height:1}.text-lg{line-height:1.75rem}.text-sm{line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{line-height:1rem}.font-bold{font-weight:700}.italic{font-style:italic}.leading-tight{line-height:1.25}.text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.text-blue-900{--tw-text-opacity:1;color:rgb(30 58 138/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-green-800{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity,1))}.text-green-900{--tw-text-opacity:1;color:rgb(20 83 45/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.shadow-lg{--tw-shadow:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-md{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px rgb(0 0 0/0.1),0 2px 4px -2px rgb(0 0 0/0.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgb(0 0 0/0.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px rgb(0 0 0/0.1)) drop-shadow(0 1px 1px rgb(0 0 0/0.06))}.drop-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)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;color:#333}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-col{flex-direction:column}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.p-2{padding:.5rem}.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}.pt-3{padding-top:.75rem}.m-2{margin:.5rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-center{text-align:center}.text-blue-800{color:#1e40af}.text-blue-900{color:#1e3a8a}.text-green-700{color:#15803d}.text-green-900{color:#14532d}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-900{color:#111827}.bg-blue-50{background-color:#eff6ff}.bg-blue-600{background-color:#2563eb}.bg-green-50{background-color:#f0fdf4}.bg-gray-50{background-color:#f9fafb}.bg-gray-100{background-color:#f3f4f6}.bg-white{background-color:#ffffff}.border{border:1px solid #d1d5db}.border-t{border-top:1px solid #d1d5db}.rounded-lg{border-radius:.5rem}.relative{position:relative}.absolute{position:absolute}.overflow-hidden{overflow:hidden}.w-full{width:100%}.h-full{height:100%}.btn-base{padding:.5rem 1rem;border-radius:.5rem;border:1px solid #d1d5db;background-color:white;cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500}.btn-base:hover{background-color:#f3f4f6}.btn-blue{padding:.5rem 1rem;border-radius:.5rem;border:none;background-color:#2563eb;color:white;cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500}.btn-blue:hover{background-color:#1d4ed8}.btn-green{padding:.5rem 1rem;border-radius:.5rem;border:none;background-color:#16a34a;color:white;cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500}.btn-green:hover{background-color:#15803d}.btn-red{padding:.5rem 1rem;border-radius:.5rem;border:none;background-color:#dc2626;color:white;cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500}.btn-red:hover{background-color:#b91c1c}.floating-toolbar{position:absolute;top:20px;right:20px;background-color:white;border:1px solid #d1d5db;border-radius:.5rem;padding:1rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);z-index:1000;max-width:300px;max-height:600px;overflow-y:auto}.icon-editor-container{position:absolute;top:20px;left:20px;background:linear-gradient(145deg,#ffffff,#f8fafc);border:2px solid #e2e8f0;border-radius:16px;padding:0;box-shadow:0 12px 32px rgba(0,0,0,.1),0 4px 16px rgba(37,99,235,.08),inset 0 1px 0 rgba(255,255,255,.8);z-index:1000;min-width:280px;max-width:320px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:editorSlide .3s cubic-bezier(.4,0,.2,1)}@keyframes editorSlide{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.editor-header{padding:16px 20px;background:linear-gradient(135deg,#1f2937,#374151);color:white;font-weight:600;font-size:15px;justify-content:space-between;border-radius:14px 14px 0 0;border-bottom:1px solid rgba(255,255,255,.1)}.editor-header,.editor-title{display:flex;align-items:center}.editor-title{gap:8px}.editor-header-buttons{display:flex;gap:8px}.editor-header-buttons .close-btn,.editor-header-buttons .delete-btn{background:rgba(255,255,255,.15);border:none;color:white;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.editor-header-buttons .delete-btn:hover{background:rgba(239,68,68,.2);transform:scale(1.05)}.editor-header-buttons .close-btn:hover{background:rgba(255,255,255,.25);transform:scale(1.05)}.editor-content{padding:20px;max-height:400px;overflow-y:auto}.editor-section{margin-bottom:20px}.editor-section:last-child{margin-bottom:0}.editor-label{font-size:13px;font-weight:600;color:#374151;margin-bottom:8px;display:block}.text-input{width:100%;padding:10px 12px;border:1.5px solid #e5e7eb;border-radius:8px;font-size:14px;background:#ffffff;transition:all .2s ease}.text-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1);background:#f8fafc}.mirror-controls{display:flex;gap:8px}.mirror-btn{padding:8px 12px;border:1.5px solid #e5e7eb;border-radius:8px;background:#ffffff;color:#374151;font-size:13px;cursor:pointer;transition:all .2s ease;font-weight:500}.mirror-btn:hover{border-color:#cbd5e1;background:#f8fafc}.mirror-btn.active{border-color:#3b82f6;background:#dbeafe;color:#1e40af}.rotation-controls{margin-bottom:10px}.rotation-slider{width:100%;-webkit-appearance:none;height:6px;border-radius:3px;background:linear-gradient(90deg,#e5e7eb 0,#3b82f6 50%,#e5e7eb);outline:none;margin:8px 0}.rotation-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(145deg,#3b82f6,#2563eb);cursor:pointer;box-shadow:0 2px 8px rgba(59,130,246,.3);border:2px solid white}.rotation-buttons{display:flex;gap:6px;justify-content:space-between}.rotation-btn{flex:1;padding:6px 8px;border:1.5px solid #e5e7eb;border-radius:6px;background:#ffffff;color:#374151;font-size:11px;cursor:pointer;transition:all .2s ease;font-weight:500;min-height:32px}.rotation-btn:hover{border-color:#cbd5e1;background:#f8fafc;transform:translateY(-1px)}.rotation-btn:active{transform:translateY(0)}.position-info{margin-top:16px;padding:12px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;font-size:12px}.coordinates{color:#6b7280;margin-bottom:4px;font-family:monospace}.move-hint{color:#9ca3af;font-style:italic}.icon-preview{display:flex;align-items:center;justify-content:center;width:100%;height:80px;background:#ffffff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:4px;position:relative;overflow:hidden}.preview-svg{max-width:48px;max-height:48px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:all .3s ease}.preview-text{font-size:18px;font-weight:600;color:#374151;background:#f3f4f6;padding:8px 12px;border-radius:6px;min-width:40px;text-align:center}.preview-arrow{font-size:32px;display:flex;align-items:center;justify-content:center}.preview-fallback{font-size:24px;color:#9ca3af;font-weight:600}.context-menu{position:fixed;background:linear-gradient(145deg,#ffffff,#fafbfc);border:2px solid #e2e8f0;border-radius:16px;padding:0;box-shadow:0 20px 40px rgba(0,0,0,.15),0 8px 25px rgba(37,99,235,.1),inset 0 1px 0 rgba(255,255,255,.8);z-index:2000;max-height:500px;min-width:320px;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:contextMenuSlide .3s cubic-bezier(.4,0,.2,1)}@keyframes contextMenuSlide{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.context-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.2);z-index:1999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.context-menu-header{padding:16px 20px;background:linear-gradient(135deg,#2563eb,#3b82f6);font-weight:600;font-size:16px;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1)}.close-btn,.context-menu-header{color:white;display:flex;align-items:center}.close-btn{background:rgba(255,255,255,.2);border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;justify-content:center;font-size:18px;font-weight:700;transition:all .2s ease}.close-btn:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.context-menu-content{max-height:420px;overflow-y:auto;padding:8px}.context-category{margin-bottom:16px}.category-header,.context-category:last-child{margin-bottom:8px}.category-header{font-size:13px;font-weight:600;color:#4b5563;padding:0 8px;text-transform:uppercase;letter-spacing:.5px}.category-items{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.context-menu-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 8px;border:2px solid #e5e7eb;border-radius:12px;background:linear-gradient(145deg,#ffffff,#f8fafc);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);min-height:70px;position:relative;overflow:hidden}.context-menu-item:hover{border-color:#3b82f6;background:linear-gradient(145deg,#f0f9ff,#e0f2fe);transform:translateY(-2px);box-shadow:0 6px 20px rgba(59,130,246,.15)}.context-menu-item:active{transform:translateY(0);box-shadow:0 2px 8px rgba(59,130,246,.2)}.item-icon{margin-bottom:6px;display:flex;align-items:center;justify-content:center;min-height:28px}.item-icon img{width:24px!important;height:24px!important;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 1px 3px rgba(0,0,0,.1))}.item-label{font-size:11px;font-weight:500;color:#374151;text-align:center;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.context-menu-item:hover .item-label{color:#1e40af;font-weight:600}.search-dropdown{position:absolute;top:100%;left:0;right:0;background-color:white;border:1px solid #d1d5db;border-top:none;border-radius:0 0 .5rem .5rem;max-height:200px;overflow-y:auto;z-index:1001}.search-dropdown-item{padding:.75rem;cursor:pointer;border-bottom:1px solid #f3f4f6}.search-dropdown-item:hover{background-color:#f3f4f6}.search-dropdown-item:last-child{border-bottom:none}input{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem}input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.1)}input[type=range]{width:100%;-webkit-appearance:none;height:6px;border-radius:3px;background:#d1d5db;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#2563eb;cursor:pointer}@media print{.context-menu,.floating-toolbar,.icon-editor-container,.search-dropdown{display:none!important}.print-header{display:block!important;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #333}}@media (min-width:768px){.md\\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.lg\\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.space-y-1>:not([hidden])~:not([hidden]){margin-top:.25rem}.text-xs{font-size:.75rem}.text-6xl{font-size:3.75rem}.hover\\:bg-gray-200:hover{background-color:#e5e7eb}.toolbar-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:12px 0}.tool-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 8px;border:2px solid #e2e8f0;border-radius:12px;background:linear-gradient(145deg,#ffffff,#f8fafc);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:80px;box-shadow:0 2px 4px rgba(0,0,0,.05)}.tool-item:hover{border-color:#cbd5e1;background:linear-gradient(145deg,#f8fafc,#e2e8f0);transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.1)}.tool-item.selected{border-color:#2563eb;background:linear-gradient(145deg,#dbeafe,#bfdbfe);box-shadow:0 4px 12px rgba(37,99,235,.2);transform:translateY(-1px)}.tool-icon{margin-bottom:6px;display:flex;align-items:center;justify-content:center;min-height:32px}.tool-icon img{width:28px!important;height:28px!important;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.tool-label{font-size:11px;font-weight:500;color:#374151;text-align:center;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-item.selected .tool-label{color:#1e40af;font-weight:600}.category-dropdown-container{position:relative;margin-bottom:12px}.category-dropdown-button{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:2px solid #e2e8f0;border-radius:10px;background:linear-gradient(145deg,#ffffff,#f8fafc);cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500}.category-dropdown-button:hover{border-color:#cbd5e1;background:linear-gradient(145deg,#f8fafc,#e2e8f0)}.category-display{display:flex;align-items:center;gap:6px;color:#374151;font-weight:500}.dropdown-arrow{transition:transform .2s ease;color:#6b7280;font-size:12px}.dropdown-arrow.open{transform:rotate(180deg)}.category-dropdown-menu{position:absolute;top:100%;left:0;right:0;background:white;border:2px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 25px rgba(0,0,0,.15);z-index:1000;margin-top:4px;overflow:hidden;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.category-dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:12px;background:white;cursor:pointer;transition:all .2s ease;font-size:14px;border:none;border-bottom:1px solid #f1f5f9}.category-dropdown-item:last-child{border-bottom:none}.category-dropdown-item:hover{background:#f8fafc}.category-dropdown-item.active{background:#dbeafe;color:#1e40af;font-weight:600}.category-icon{font-size:16px;width:20px;text-align:center}.category-name{flex:1;text-align:left}.toolbar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.toolbar-title{font-weight:600;color:#374151;font-size:14px}.clear-selection{background:#ef4444;color:white;border:none;border-radius:6px;padding:4px 8px;cursor:pointer;font-size:16px;transition:all .2s ease}.clear-selection:hover{background:#dc2626}.toolbar-info{margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0;font-size:12px;color:#6b7280}.selected-tool{display:flex;align-items:center;gap:6px;font-weight:500;color:#374151;margin-bottom:4px}.instruction{font-style:italic;color:#9ca3af}.leaflet-marker-icon{visibility:visible!important;opacity:1!important;display:block!important}.custom-div-icon{background:transparent!important;border:none!important}.drawing-panel{position:absolute;top:20px;right:20px;background:linear-gradient(145deg,#ffffff,#f8fafc);border:2px solid #e2e8f0;border-radius:16px;padding:0;box-shadow:0 12px 32px rgba(0,0,0,.1),0 4px 16px rgba(37,99,235,.08),inset 0 1px 0 rgba(255,255,255,.8);z-index:1000;min-width:280px;max-width:320px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:panelSlide .3s cubic-bezier(.4,0,.2,1)}@keyframes panelSlide{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.drawing-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px 14px 0 0;margin:0;position:relative}.drawing-title{font-size:16px;font-weight:600;color:white;text-shadow:0 1px 2px rgba(0,0,0,.3)}.close-drawing{background:rgba(255,255,255,.2);color:white;border:none;border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.close-drawing:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.drawing-controls{padding:20px}.control-group{margin-bottom:20px}.control-label{display:block;font-size:14px;font-weight:600;color:#4a5568;margin-bottom:8px}.line-weight-control{display:flex;align-items:center;gap:12px}.weight-slider{flex:1;height:6px;border-radius:3px;background:#e2e8f0;outline:none;-webkit-appearance:none}.weight-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(145deg,#667eea,#764ba2);cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.2);-webkit-transition:all .2s ease;transition:all .2s ease}.weight-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(102,126,234,.4)}.weight-value{font-size:12px;font-weight:600;color:#667eea;min-width:35px}.drawing-instructions{background:#f7fafc;padding:12px;border-radius:8px;font-size:12px;color:#4a5568;text-align:center;border:1px solid #e2e8f0;margin-bottom:16px}.clear-lines-btn{width:100%;padding:10px;background:linear-gradient(145deg,#ef4444,#dc2626);color:white;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px rgba(239,68,68,.3)}.clear-lines-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(239,68,68,.4)}.color-picker{margin-top:8px}.color-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.color-swatch{width:28px;height:28px;border-radius:6px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.2);border:2px solid transparent}.color-swatch:hover{transform:scale(1.1);box-shadow:0 4px 8px rgba(0,0,0,.2)}.color-swatch.selected{border:2px solid #667eea;transform:scale(1.05);box-shadow:0 0 0 2px rgba(102,126,234,.3),0 4px 8px rgba(0,0,0,.2)}.last\:border-b-0:last-child{border-bottom-width:0}.hover\:border-gray-300:hover{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.hover\:bg-blue-50:hover{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.hover\:bg-blue-600:hover{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-gray-600:hover{--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity,1))}.hover\:bg-green-600:hover{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.hover\:bg-purple-600:hover{--tw-bg-opacity:1;background-color:rgb(147 51 234/var(--tw-bg-opacity,1))}.hover\:bg-red-600:hover{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.hover\:bg-white:hover{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.hover\:text-blue-800:hover{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.hover\:text-red-700:hover{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity,1))}.focus\:border-blue-500:focus{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.focus\:border-transparent:focus{border-color:transparent}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}