/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--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-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-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;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:host,:root{--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;--spacing:.25rem;--ease-in:cubic-bezier(.4,0,1,1);--ease-out:cubic-bezier(0,0,.2,1);--ease-in-out:cubic-bezier(.4,0,.2,1);--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{*,::backdrop,:after,:before{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}:host,html{-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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{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}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,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,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-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,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden}.absolute,.sr-only{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.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}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.flex-shrink,.shrink{flex-shrink:1}.flex-grow,.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.px-\[20px\]{padding-inline:20px}.break-all{word-break:break-all}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal}.ordinal,.tabular-nums{font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.tabular-nums{--tw-numeric-spacing:tabular-nums}.overline{text-decoration-line:overline}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px)}.blur,.drop-shadow{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,)}.drop-shadow{--tw-drop-shadow-size:drop-shadow(0 1px 2px var(--tw-drop-shadow-color,#0000001a)) drop-shadow(0 1px 1px var(--tw-drop-shadow-color,#0000000f));--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f)}.grayscale{--tw-grayscale:grayscale(100%)}.grayscale,.invert{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,)}.invert{--tw-invert:invert(100%)}.sepia{--tw-sepia:sepia(100%)}.filter,.sepia{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,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.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))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.first\:mt-0:first-child{margin-top:calc(var(--spacing) * 0)}.last\:mb-0:last-child{margin-bottom:calc(var(--spacing) * 0)}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}:root{--color-background:#f6f7f9;--color-foreground:#111318;--color-muted:#6b7280;--color-border:#e2e4e9;--color-card:#fff;--color-primary:#4f6ef7;--color-primary-foreground:#fff;--color-accent:#f0f2f7;--color-danger:#ef4444;--color-success:#22c55e;color-scheme:light}.dark{--color-background:#0a0b0f;--color-foreground:#f0f1f4;--color-muted:#9ca3af;--color-border:#1f2937;--color-card:#151720;--color-primary:#6b8aff;--color-primary-foreground:#0a0b0f;--color-accent:#1a1d2e;--color-danger:#f87171;--color-success:#4ade80;color-scheme:dark}body{font-family:var(--font-sora),var(--font-noto-sans-kr),ui-sans-serif,system-ui,sans-serif;background:var(--color-background);color:var(--color-foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}#root{flex-direction:column;min-height:100svh;display:flex}.top-nav{z-index:50;background:var(--color-background);height:64px;position:fixed;top:0;left:0;right:0}@supports (color:color-mix(in lab,red,red)){.top-nav{background:color-mix(in srgb,var(--color-background) 80%,transparent)}}.top-nav{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);justify-content:space-between;padding:0 24px}.nav-logo,.top-nav{align-items:center;display:flex}.nav-logo{color:var(--color-foreground);gap:10px;font-size:20px;font-weight:600;text-decoration:none}.nav-logo svg{width:28px;height:28px}.nav-link{color:var(--color-muted);border-radius:8px;align-items:center;padding:8px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:color .15s,background .15s;display:inline-flex}.nav-link:hover{color:var(--color-foreground);background:var(--color-foreground)}@supports (color:color-mix(in lab,red,red)){.nav-link:hover{background:color-mix(in srgb,var(--color-foreground) 6%,transparent)}}.nav-right{flex-shrink:0;gap:8px;margin-left:auto}.nav-right,.theme-toggle{align-items:center;display:flex}.theme-toggle{border:1px solid var(--color-border);cursor:pointer;width:40px;height:40px;color:var(--color-foreground);background:0 0;border-radius:8px;justify-content:center;transition:background-color .2s,border-color .2s}.theme-toggle:hover{background:var(--color-accent)}.theme-toggle:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.lang-select{background:var(--color-card);border:1px solid var(--color-border);color:var(--color-foreground);cursor:pointer;border-radius:8px;padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.lang-select:hover{border-color:var(--color-primary)}.lang-select:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.main-content{box-sizing:border-box;flex:1;width:100%;max-width:1200px;margin-top:64px;margin-left:auto;margin-right:auto;padding:0 24px}.hero{text-align:center;padding:60px 0 40px}.hero h1{letter-spacing:-1px;color:var(--color-foreground);margin:0 0 16px;font-size:48px;font-weight:700}.hero p{color:var(--color-muted);max-width:600px;margin:0 auto;font-size:18px;line-height:1.6}.search-box{max-width:480px;margin:0 auto 48px}.search-box input{border:1px solid var(--color-border);background:var(--color-card);width:100%;color:var(--color-foreground);box-sizing:border-box;border-radius:12px;padding:14px 60px 14px 48px;font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s}.search-kbd{border:1px solid var(--color-border);background:var(--color-accent);color:var(--color-muted);pointer-events:none;-webkit-user-select:none;user-select:none;border-radius:6px;padding:3px 8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;font-weight:600;position:absolute;top:50%;right:12px;transform:translateY(-50%)}@media (hover:none),(max-width:720px){.search-kbd{display:none}.search-box input{padding-right:20px}}.search-box input::placeholder{color:var(--color-muted)}.search-box input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary);outline:none}@supports (color:color-mix(in lab,red,red)){.search-box input:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 20%,transparent)}}.search-icon{color:var(--color-muted);pointer-events:none;width:20px;height:20px;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.category-tabs{gap:8px;margin-bottom:32px;padding-bottom:4px;display:flex;overflow-x:auto}.category-tab{border:1px solid var(--color-border);color:var(--color-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:20px;gap:8px;padding:8px 14px 8px 16px;font-family:inherit;font-size:14px;transition:background-color .2s,color .2s,border-color .2s}.category-tab,.category-tab-count{align-items:center;display:inline-flex}.category-tab-count{background:var(--color-foreground);border-radius:9px;justify-content:center;min-width:20px;height:18px;padding:0 6px}@supports (color:color-mix(in lab,red,red)){.category-tab-count{background:color-mix(in srgb,var(--color-foreground) 8%,transparent)}}.category-tab-count{color:var(--color-muted);font-variant-numeric:tabular-nums;font-size:11px;font-weight:600}.category-tab.active .category-tab-count{background:var(--color-primary-foreground)}@supports (color:color-mix(in lab,red,red)){.category-tab.active .category-tab-count{background:color-mix(in srgb,var(--color-primary-foreground) 18%,transparent)}}.category-tab.active .category-tab-count{color:var(--color-primary-foreground)}.category-tab:hover{background:var(--color-accent);color:var(--color-foreground)}.category-tab.active{background:var(--color-primary);color:var(--color-primary-foreground);border-color:var(--color-primary)}.category-tab:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.tool-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;max-width:1280px;margin-left:auto;margin-right:auto;padding-bottom:60px;display:grid}.cat-image{--cat-color:#3b82f6}.cat-document{--cat-color:#ef4444}.cat-video{--cat-color:#8b5cf6}.cat-audio{--cat-color:#f59e0b}.cat-developer{--cat-color:#10b981}.cat-calculator{--cat-color:#6366f1}.cat-utility{--cat-color:#64748b}.tool-card{--cat-color:#6366f1;background:var(--color-card);border:1px solid var(--color-border);color:var(--color-foreground);isolation:isolate;border-radius:10px;flex-direction:column;gap:10px;padding:14px 16px;text-decoration:none;transition:border-color .18s,box-shadow .18s,transform .18s;display:flex;overflow:hidden}.tool-card:after{content:"";border-radius:inherit;background:radial-gradient(circle at 100% 0,var(--cat-color),transparent 55%);position:absolute;inset:0}@supports (color:color-mix(in lab,red,red)){.tool-card:after{background:radial-gradient(circle at 100% 0,color-mix(in srgb,var(--cat-color) 14%,transparent),transparent 55%)}}.tool-card:after{opacity:.65;pointer-events:none;z-index:-1;transition:opacity .25s}.tool-card:hover{border-color:var(--cat-color);transform:translateY(-1px)}@supports (color:color-mix(in lab,red,red)){.tool-card:hover{border-color:color-mix(in srgb,var(--cat-color) 50%,var(--color-border))}}.tool-card:hover{box-shadow:0 1px 2px #1113180a,0 6px 20px var(--cat-color)}@supports (color:color-mix(in lab,red,red)){.tool-card:hover{box-shadow:0 1px 2px #1113180a,0 6px 20px color-mix(in srgb,var(--cat-color) 12%,transparent)}}.tool-card:hover:after{opacity:1}.dark .tool-card:hover{box-shadow:0 1px 2px #0006,0 6px 20px var(--cat-color)}@supports (color:color-mix(in lab,red,red)){.dark .tool-card:hover{box-shadow:0 1px 2px #0006,0 6px 20px color-mix(in srgb,var(--cat-color) 18%,transparent)}}.tool-card:focus-visible{border-color:var(--cat-color);box-shadow:0 0 0 3px var(--cat-color);outline:none}@supports (color:color-mix(in lab,red,red)){.tool-card:focus-visible{box-shadow:0 0 0 3px color-mix(in srgb,var(--cat-color) 25%,transparent)}}.tool-card-icon{background:var(--cat-color);border-radius:9px;width:38px;height:38px}@supports (color:color-mix(in lab,red,red)){.tool-card-icon{background:color-mix(in srgb,var(--cat-color) 14%,var(--color-card))}}.tool-card-icon{color:var(--cat-color);border:1px solid var(--cat-color)}@supports (color:color-mix(in lab,red,red)){.tool-card-icon{border:1px solid color-mix(in srgb,var(--cat-color) 18%,transparent)}}.tool-card-icon{flex-shrink:0;justify-content:center;align-items:center;transition:background .18s,transform .18s;display:flex}.tool-card:hover .tool-card-icon{background:var(--cat-color)}@supports (color:color-mix(in lab,red,red)){.tool-card:hover .tool-card-icon{background:color-mix(in srgb,var(--cat-color) 22%,var(--color-card))}}.tool-card:hover .tool-card-icon{transform:scale(1.03)}.tool-card h3{letter-spacing:-.015em;color:var(--color-foreground);margin:0;font-size:15px;font-weight:600;line-height:1.3}.tool-card p{color:var(--color-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:12.5px;line-height:1.5;display:-webkit-box;overflow:hidden}.tool-card-badge{background:var(--cat-color);border-radius:999px;align-items:center;gap:5px;padding:2px 8px 2px 6px;font-size:10.5px;font-weight:500;display:inline-flex}@supports (color:color-mix(in lab,red,red)){.tool-card-badge{background:color-mix(in srgb,var(--cat-color) 12%,var(--color-card))}}.tool-card-badge{color:var(--cat-color);border:1px solid var(--cat-color)}@supports (color:color-mix(in lab,red,red)){.tool-card-badge{border:1px solid color-mix(in srgb,var(--cat-color) 22%,transparent)}}.tool-card-badge{letter-spacing:.02em;text-transform:capitalize;width:fit-content;margin-top:auto}.tool-card-badge:before{content:"";background:var(--cat-color);border-radius:50%;width:6px;height:6px;display:inline-block}.tool-card{position:relative}.tool-card-star{color:var(--color-muted);cursor:pointer;z-index:2;background:0 0;border:0;border-radius:5px;padding:3px;font-size:16px;line-height:1;transition:color .15s,background .15s;position:absolute;top:10px;right:10px}.tool-card-star:hover{color:#facc15;background:#facc150f}.tool-card-star.active{color:#facc15}.featured-section{margin:32px 0}.featured-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;max-width:1280px;margin-top:14px;display:grid}@media (max-width:520px){.featured-grid{grid-template-columns:minmax(0,1fr)}}.featured-card{--cat-color:#6366f1;color:var(--color-foreground);background:var(--color-card);border:1px solid var(--cat-color);border-radius:12px;align-items:center;gap:14px;padding:16px 18px;text-decoration:none;display:flex;position:relative}@supports (color:color-mix(in lab,red,red)){.featured-card{border:1px solid color-mix(in srgb,var(--cat-color) 20%,var(--color-border))}}.featured-card{isolation:isolate;min-height:84px;transition:border-color .18s,box-shadow .18s,transform .18s;overflow:hidden}.featured-card:after{content:"";border-radius:inherit;background:radial-gradient(circle at 100% 0,var(--cat-color),transparent 55%);position:absolute;inset:0}@supports (color:color-mix(in lab,red,red)){.featured-card:after{background:radial-gradient(circle at 100% 0,color-mix(in srgb,var(--cat-color) 18%,transparent),transparent 55%)}}.featured-card:after{opacity:1;pointer-events:none;z-index:-1;transition:opacity .25s}.featured-card:hover{border-color:var(--cat-color);transform:translateY(-1px)}@supports (color:color-mix(in lab,red,red)){.featured-card:hover{border-color:color-mix(in srgb,var(--cat-color) 55%,var(--color-border))}}.featured-card:hover{box-shadow:0 2px 4px #1113180d,0 10px 28px var(--cat-color)}@supports (color:color-mix(in lab,red,red)){.featured-card:hover{box-shadow:0 2px 4px #1113180d,0 10px 28px color-mix(in srgb,var(--cat-color) 14%,transparent)}}.dark .featured-card:hover{box-shadow:0 2px 4px #0006,0 10px 28px var(--cat-color)}@supports (color:color-mix(in lab,red,red)){.dark .featured-card:hover{box-shadow:0 2px 4px #0006,0 10px 28px color-mix(in srgb,var(--cat-color) 22%,transparent)}}.featured-card-icon{background:var(--cat-color);border-radius:10px;width:44px;height:44px}@supports (color:color-mix(in lab,red,red)){.featured-card-icon{background:color-mix(in srgb,var(--cat-color) 16%,var(--color-card))}}.featured-card-icon{color:var(--cat-color);border:1px solid var(--cat-color)}@supports (color:color-mix(in lab,red,red)){.featured-card-icon{border:1px solid color-mix(in srgb,var(--cat-color) 22%,transparent)}}.featured-card-icon{flex-shrink:0;justify-content:center;align-items:center;transition:background .18s,transform .18s;display:flex}.featured-card:hover .featured-card-icon{background:var(--cat-color)}@supports (color:color-mix(in lab,red,red)){.featured-card:hover .featured-card-icon{background:color-mix(in srgb,var(--cat-color) 24%,var(--color-card))}}.featured-card:hover .featured-card-icon{transform:scale(1.03)}.featured-card-body{flex-direction:column;gap:4px;min-width:0;display:flex}.featured-card-body h3{letter-spacing:-.01em;margin:0;font-size:15px;font-weight:600;line-height:1.35}.featured-card-body p{color:var(--color-muted);-webkit-line-clamp:1;-webkit-box-orient:vertical;margin:0;font-size:12.5px;line-height:1.5;display:-webkit-box;overflow:hidden}.search-box{position:relative}.search-dropdown{background:var(--color-card);border:1px solid var(--color-border);z-index:50;border-radius:12px;max-height:440px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden auto;box-shadow:0 12px 36px #00000059}.search-suggestion{color:var(--color-foreground);cursor:pointer;border-bottom:1px solid #ffffff0a;grid-template-columns:36px 1fr auto;align-items:center;gap:12px;padding:12px 14px;text-decoration:none;transition:background .1s;display:grid}.search-suggestion:last-child{border-bottom:0}.search-suggestion.active,.search-suggestion:hover{background:#7c5cfc1a}.search-suggestion-icon{background:var(--color-accent);border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:22px;display:flex}.search-suggestion-body{flex-direction:column;gap:2px;min-width:0;display:flex}.search-suggestion-title{font-size:14px;font-weight:600}.search-suggestion-desc,.search-suggestion-title{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.search-suggestion-desc{color:var(--color-muted);font-size:12px}.search-suggestion-cat{text-transform:uppercase;letter-spacing:.04em;background:var(--color-accent);color:var(--color-muted);border-radius:4px;padding:3px 8px;font-size:10px}.dev-subgroup{margin-top:20px}.dev-subgroup:first-child{margin-top:6px}.dev-subgroup-head{color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:10px;margin:0 0 10px;padding-left:2px;font-size:14px;font-weight:600;display:flex}.dev-subgroup-count{background:var(--color-accent);border-radius:10px;padding:1px 8px;font-size:11px;font-weight:500}.tool-section{margin-bottom:36px}.tool-section .tool-grid{padding-bottom:0}.tool-section-head{text-align:left;cursor:default;width:100%;color:var(--color-foreground);background:0 0;border:none;align-items:center;gap:10px;margin:0 0 16px;padding:8px 4px;display:flex}.tool-section-toggle{cursor:pointer;border-radius:8px;transition:background-color .15s}.tool-section-toggle:hover{background:var(--color-foreground)}@supports (color:color-mix(in lab,red,red)){.tool-section-toggle:hover{background:color-mix(in srgb,var(--color-foreground) 4%,transparent)}}.tool-section-toggle:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.tool-section-head h2{margin:0;font-size:18px;font-weight:600}.tool-section-count{background:var(--color-foreground);border-radius:10px;justify-content:center;align-items:center;min-width:22px;height:20px;padding:0 7px;display:inline-flex}@supports (color:color-mix(in lab,red,red)){.tool-section-count{background:color-mix(in srgb,var(--color-foreground) 8%,transparent)}}.tool-section-count{color:var(--color-muted);font-variant-numeric:tabular-nums;font-size:12px;font-weight:600}.tool-section-chevron{width:16px;color:var(--color-muted);font-size:14px;transition:transform .18s;display:inline-block}.tool-section-chevron.collapsed{transform:rotate(-90deg)}.recent-section .tool-section-head{cursor:default}.tool-empty{text-align:center;color:var(--color-muted);background:var(--color-card);border:1px dashed var(--color-border);border-radius:12px;padding:60px 20px;font-size:15px}.features{border-top:1px solid var(--color-border);grid-template-columns:repeat(3,1fr);gap:24px;padding:60px 0;display:grid}.feature-item{text-align:center;padding:24px}.feature-icon{margin-bottom:16px;font-size:32px}.feature-item h3{margin:0 0 8px;font-size:18px;font-weight:600}.feature-item p{color:var(--color-muted);margin:0;font-size:14px;line-height:1.5}.site-footer{border-top:1px solid var(--color-border);text-align:center;padding:32px 24px}.footer-tools{flex-wrap:wrap;justify-content:center;gap:24px;margin-bottom:16px;display:flex}.footer-tools a{color:var(--color-muted);font-size:14px;text-decoration:none;transition:color .2s}.footer-tools a:hover{color:var(--color-primary)}.footer-links{flex-wrap:wrap;justify-content:center;gap:8px 20px;margin-bottom:8px;display:flex}.footer-links a{color:var(--color-muted);font-size:13px;text-decoration:underline;transition:color .2s}.footer-links a:hover{color:var(--color-primary)}.footer-copy{color:var(--color-muted);font-size:13px}.cookie-banner{background:var(--color-card);border-top:1px solid var(--color-border);z-index:9999;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;padding:16px 24px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #00000014}.cookie-banner p{color:var(--color-foreground);margin:0;font-size:14px}.cookie-actions{gap:8px;display:flex}.cookie-btn{cursor:pointer;border:none;border-radius:8px;padding:8px 20px;font-size:14px;font-weight:500}.cookie-accept{background:var(--color-primary);color:var(--color-primary-foreground)}.cookie-decline{background:var(--color-border);color:var(--color-foreground)}.tool-page{padding:40px 0 60px}.tool-page h1{margin:0 0 8px;font-size:32px;font-weight:700}.tool-page .tool-desc{color:var(--color-muted);margin:0 0 32px;font-size:16px}.drop-zone{border:2px dashed var(--color-border);text-align:center;cursor:pointer;border-radius:16px;max-width:640px;margin:0 auto;padding:48px 24px;transition:border-color .2s,background-color .2s}.drop-zone.drag-over,.drop-zone:hover{border-color:var(--color-primary);background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.drop-zone.drag-over,.drop-zone:hover{background:color-mix(in srgb,var(--color-primary) 5%,transparent)}}.drop-zone-icon{color:var(--color-muted);justify-content:center;margin-bottom:16px;font-size:48px;display:flex}.drop-zone p{color:var(--color-muted);margin:4px 0;font-size:14px}.drop-zone .browse-link{color:var(--color-primary)}.btn,.drop-zone .browse-link{cursor:pointer;font-weight:500}.btn{border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-family:inherit;font-size:15px;transition:background-color .2s,transform .1s;display:inline-flex}.btn:active{transform:scale(.98)}.btn:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.btn-primary{color:var(--color-primary-foreground)}.btn-primary,.btn-primary:hover{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.btn-primary:hover{background:color-mix(in srgb,var(--color-primary) 85%,black)}}.btn-secondary{background:var(--color-accent);color:var(--color-foreground)}.btn-secondary:hover{background:var(--color-border)}.btn-danger{color:#fff}.btn-danger,.btn-danger:hover{background:var(--color-danger)}@supports (color:color-mix(in lab,red,red)){.btn-danger:hover{background:color-mix(in srgb,var(--color-danger) 85%,black)}}.range-control{align-items:center;gap:12px;display:flex}.range-control input[type=range]{accent-color:var(--color-primary);flex:1}.range-control .range-value{text-align:center;min-width:48px;font-size:14px;font-weight:500}.wm-editor{grid-template-columns:1fr 320px;align-items:start;gap:24px;margin-bottom:24px;display:grid}.wm-preview-area{min-width:0}.wm-controls{background:var(--color-card);border:1px solid var(--color-border);border-radius:14px;flex-direction:column;gap:16px;padding:20px;display:flex}.wm-label{font-weight:500}.wm-input,.wm-label{color:var(--color-foreground);font-size:14px}.wm-input{border:1px solid var(--color-border);background:var(--color-background);border-radius:10px;outline:none;padding:10px 14px;font-family:inherit;transition:border-color .2s,box-shadow .2s}.wm-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.wm-input:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 20%,transparent)}}@media (max-width:768px){.wm-editor{grid-template-columns:1fr}}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin:24px 0;display:grid}.preview-item{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.preview-item img{object-fit:cover;width:100%;height:160px}.preview-info{color:var(--color-muted);padding:12px;font-size:13px}.compress-controls{flex-wrap:wrap;align-items:center;gap:16px;max-width:640px;margin:20px auto 0;display:flex}.compress-quality{flex:1;align-items:center;gap:10px;min-width:200px;display:flex}.compress-quality label{white-space:nowrap;font-size:14px;font-weight:500}.compress-quality input[type=range]{accent-color:var(--color-primary);flex:1}.compress-quality-value{text-align:center;min-width:32px;color:var(--color-primary);font-size:14px;font-weight:600}.compress-actions{gap:8px;display:flex}.btn-sm{padding:8px 16px;font-size:13px}.compress-errors{background:var(--color-danger)}@supports (color:color-mix(in lab,red,red)){.compress-errors{background:color-mix(in srgb,var(--color-danger) 10%,transparent)}}.compress-errors{border:1px solid var(--color-danger);color:var(--color-danger);border-radius:10px;margin:16px 0;padding:12px 16px;font-size:14px}.compress-processing{text-align:center;color:var(--color-muted);padding:16px}.compress-list{border:1px solid var(--color-border);background:var(--color-card);border-radius:12px;margin:24px 0;overflow:hidden}.compress-summary{background:var(--color-accent);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:14px 20px;font-size:14px;font-weight:500;display:flex}.compress-summary-saved{color:var(--color-success);font-weight:600}.compress-row{border-bottom:1px solid var(--color-border);align-items:center;gap:14px;padding:12px 20px;transition:background-color .15s;display:flex}.compress-row:last-child{border-bottom:none}.compress-row:hover{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.compress-row:hover{background:color-mix(in srgb,var(--color-primary) 3%,transparent)}}.compress-row-thumb{object-fit:cover;border:1px solid var(--color-border);border-radius:8px;flex-shrink:0;width:44px;height:44px}.compress-row-info{flex:1;min-width:0}.compress-row-name{color:var(--color-foreground);text-overflow:ellipsis;white-space:nowrap;margin-bottom:6px;font-size:14px;font-weight:500;overflow:hidden}.compress-row-bar{background:var(--color-accent);border-radius:3px;height:6px;overflow:hidden}.compress-row-bar-fill{border-radius:3px;height:100%;transition:width .4s}.compress-row-bar-fill.success{background:var(--color-success)}.compress-row-bar-fill.neutral{background:var(--color-muted)}.compress-row-sizes{color:var(--color-muted);flex-shrink:0;align-items:center;gap:6px;font-size:13px;display:flex}.compress-row-original{opacity:.6;text-decoration:line-through}.compress-row-compressed{color:var(--color-foreground);font-weight:600}.compress-row-pct{text-align:right;flex-shrink:0;min-width:52px;font-size:13px;font-weight:700}.compress-row-pct.success{color:var(--color-success)}.compress-row-pct.neutral{color:var(--color-muted);font-size:11px}.compress-row-dl{border:1px solid var(--color-border);width:36px;height:36px;color:var(--color-primary);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background-color .15s,border-color .15s;display:flex}.compress-row-dl:hover{background:var(--color-primary);color:var(--color-primary-foreground);border-color:var(--color-primary)}@media (max-width:640px){.compress-controls{flex-direction:column;align-items:stretch}.compress-row{flex-wrap:wrap;gap:8px;padding:12px 14px}.compress-row-sizes{order:3;justify-content:center;width:100%}.compress-row-pct{order:4}}.drop-zone-hint{color:var(--color-muted);font-size:12px}@media (max-width:1024px){.features{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.hero h1{font-size:32px}.hero p{font-size:16px}.tool-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:560px){.features,.tool-grid{grid-template-columns:1fr}.top-nav{gap:4px;padding:0 12px}.nav-logo{gap:6px;font-size:17px}.nav-logo svg{width:24px;height:24px}.lang-select{max-width:90px;padding:6px 8px;font-size:13px}.theme-toggle{width:36px;height:36px}.main-content{padding:0 16px}}@media (max-width:640px){.hero{padding:40px 0 24px}}.base64-panels{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.base64-panel{flex-direction:column;gap:6px;display:flex}.base64-panel-header{justify-content:space-between;align-items:center;display:flex}.base64-label{color:var(--color-foreground);font-size:14px;font-weight:500}.base64-charcount{color:var(--color-muted);font-size:12px}.base64-textarea{border:1px solid var(--color-border);background:var(--color-card);width:100%;height:200px;color:var(--color-foreground);resize:vertical;box-sizing:border-box;border-radius:10px;padding:12px;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:13px;line-height:1.5;transition:border-color .2s,box-shadow .2s}.base64-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary);outline:none}@supports (color:color-mix(in lab,red,red)){.base64-textarea:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 20%,transparent)}}.base64-textarea[readonly]{background:var(--color-accent);cursor:default}.base64-actions{flex-wrap:wrap;gap:10px;margin-top:8px;display:flex}@media (max-width:640px){.base64-panels{grid-template-columns:1fr}}.hash-tabs{background:var(--color-accent);border-radius:10px;gap:4px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.hash-tab{cursor:pointer;color:var(--color-muted);background:0 0;border:none;border-radius:8px;padding:8px 20px;font-family:inherit;font-size:14px;font-weight:500;transition:background-color .2s,color .2s}.hash-tab--active,.hash-tab:hover{color:var(--color-foreground)}.hash-tab--active{background:var(--color-card);box-shadow:0 1px 3px #0000001a}.hash-tab:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.hash-results{flex-direction:column;gap:16px;margin-top:24px;display:flex}.hash-file-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:20px}.hash-file-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.hash-file-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:15px;font-weight:600;overflow:hidden}.hash-file-size{color:var(--color-muted);white-space:nowrap;font-size:13px}.hash-computing{color:var(--color-muted);font-size:14px}.hash-error{color:var(--color-danger,#ef4444);font-size:14px}.hash-rows{flex-direction:column;gap:10px;display:flex}.hash-row{align-items:center;gap:12px;display:flex}.hash-algo{color:var(--color-primary);min-width:72px;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:12px;font-weight:600}.hash-value{background:var(--color-accent);border:1px solid var(--color-border);cursor:pointer;text-align:left;border-radius:8px;flex:1;align-items:center;gap:8px;min-width:0;padding:8px 12px;font-family:inherit;transition:background-color .15s,border-color .15s;display:flex}.hash-value:hover{border-color:var(--color-primary);background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.hash-value:hover{background:color-mix(in srgb,var(--color-primary) 5%,var(--color-accent))}}.hash-value:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.hash-value--copied{background:#22c55e;border-color:#22c55e}@supports (color:color-mix(in lab,red,red)){.hash-value--copied{background:color-mix(in srgb,#22c55e 8%,var(--color-accent))}}.hash-hex{color:var(--color-foreground);text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:12px;overflow:hidden}.hash-copy-icon{color:var(--color-muted);flex-shrink:0;font-size:14px}.hash-actions{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.hash-text-mode{flex-direction:column;gap:16px;display:flex}.hash-textarea{border:1px solid var(--color-border);background:var(--color-card);width:100%;color:var(--color-foreground);resize:vertical;box-sizing:border-box;border-radius:10px;padding:12px;font-family:inherit;font-size:14px;line-height:1.6;transition:border-color .2s,box-shadow .2s}.hash-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary);outline:none}@supports (color:color-mix(in lab,red,red)){.hash-textarea:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 20%,transparent)}}.hash-compare-section{align-items:center;gap:12px;margin-bottom:24px;display:flex}.hash-compare-label{white-space:nowrap;color:var(--color-foreground);font-size:14px;font-weight:600}.hash-compare-input{border:1px solid var(--color-border);background:var(--color-card);color:var(--color-foreground);border-radius:8px;flex:1;padding:8px 12px;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:13px;transition:border-color .2s,box-shadow .2s}.hash-compare-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary);outline:none}@supports (color:color-mix(in lab,red,red)){.hash-compare-input:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 20%,transparent)}}.hash-remove-btn{width:28px;height:28px;color:var(--color-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-family:inherit;font-size:18px;line-height:1;transition:background-color .15s,color .15s;display:flex}.hash-remove-btn:hover{background:var(--color-danger,#ef4444)}@supports (color:color-mix(in lab,red,red)){.hash-remove-btn:hover{background:color-mix(in srgb,var(--color-danger,#ef4444) 12%,transparent)}}.hash-remove-btn:hover{color:var(--color-danger,#ef4444)}.hash-remove-btn:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.hash-match-icon{text-align:center;flex-shrink:0;width:24px;font-size:18px;font-weight:700}.hash-match-icon--yes{color:#22c55e}.hash-match-icon--no{color:var(--color-danger,#ef4444)}.hash-value--match{background:#22c55e;border-color:#22c55e}@supports (color:color-mix(in lab,red,red)){.hash-value--match{background:color-mix(in srgb,#22c55e 8%,var(--color-accent))}}.hash-md5-warn{background:var(--color-danger,#ef4444);border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex}@supports (color:color-mix(in lab,red,red)){.hash-md5-warn{background:color-mix(in srgb,var(--color-danger,#ef4444) 15%,transparent)}}.hash-md5-warn{color:var(--color-danger,#ef4444);vertical-align:middle;cursor:help;margin-left:4px;font-size:10px;font-weight:700}@media (max-width:640px){.hash-row{flex-direction:column;align-items:flex-start;gap:6px}.hash-algo{min-width:unset}.hash-value{width:100%}.hash-compare-section{flex-direction:column;align-items:stretch;gap:6px}}.convert-controls{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;gap:16px;margin-bottom:24px;padding:20px;display:flex}.control-row{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.control-label{color:var(--color-foreground);min-width:120px;font-size:14px;font-weight:500}.convert-actions{flex-wrap:wrap;gap:12px;margin:16px 0;display:flex}.preview-thumb{position:relative}.preview-thumb img{object-fit:cover;width:100%;height:160px;display:block}.preview-badge{background:var(--color-foreground);position:absolute;top:8px;right:8px}@supports (color:color-mix(in lab,red,red)){.preview-badge{background:color-mix(in srgb,var(--color-foreground) 70%,transparent)}}.preview-badge{color:var(--color-primary-foreground);border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600}.preview-filename{color:var(--color-foreground);white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;font-size:13px;font-weight:500;overflow:hidden}.preview-sizes{color:var(--color-muted);flex-direction:column;gap:2px;margin-bottom:10px;font-size:12px;display:flex}.preview-converting{color:var(--color-primary);font-style:italic}.preview-error{color:var(--color-danger)}.preview-item-actions{gap:8px;display:flex}.resize-controls{flex-direction:column;gap:16px;max-width:640px;margin:24px auto 0;display:flex}.resize-info-bar{background:var(--color-card);border:1px solid var(--color-border);border-radius:10px;align-items:center;gap:12px;padding:12px 16px;display:flex}.resize-info-thumb{object-fit:cover;border:1px solid var(--color-border);border-radius:6px;flex-shrink:0;width:40px;height:40px}.resize-info-text{flex-direction:column;gap:2px;min-width:0;display:flex}.resize-info-name{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.resize-info-dims{color:var(--color-muted);font-size:12px}.resize-tabs{background:var(--color-accent);border-radius:10px;gap:4px;padding:4px;display:flex}.resize-tab{cursor:pointer;color:var(--color-muted);background:0 0;border:none;border-radius:8px;flex:1;padding:8px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background-color .2s,color .2s}.resize-tab.active,.resize-tab:hover{color:var(--color-foreground)}.resize-tab.active{background:var(--color-card);box-shadow:0 1px 3px #0000001a}.resize-tab:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.resize-percent-section{flex-direction:column;gap:12px;display:flex}.resize-percent-presets{gap:8px;display:flex}.resize-pct-btn{cursor:pointer;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-foreground);border-radius:8px;padding:8px 20px;font-family:inherit;font-size:14px;font-weight:500;transition:background-color .2s,border-color .2s}.resize-pct-btn.active,.resize-pct-btn:hover{border-color:var(--color-primary)}.resize-pct-btn.active{background:var(--color-primary);color:var(--color-primary-foreground)}.resize-pct-btn:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.resize-percent-slider{align-items:center;gap:12px;display:flex}.resize-percent-slider input[type=range]{accent-color:var(--color-primary);flex:1}.resize-percent-value{text-align:center;min-width:48px;color:var(--color-primary);font-size:14px;font-weight:600}.resize-percent-preview{color:var(--color-muted);text-align:center;font-size:13px}.resize-dim-section{flex-direction:column;gap:12px;display:flex}.resize-dim-row{align-items:flex-end;gap:12px;display:flex}.resize-dim-field{flex-direction:column;flex:1;gap:6px;display:flex}.resize-dim-field label{color:var(--color-muted);font-size:13px;font-weight:500}.resize-dim-field input[type=number]{border:1px solid var(--color-border);background:var(--color-card);width:100%;color:var(--color-foreground);box-sizing:border-box;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.resize-dim-field input[type=number]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary);outline:none}@supports (color:color-mix(in lab,red,red)){.resize-dim-field input[type=number]:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 20%,transparent)}}.resize-lock-btn{border:1px solid var(--color-border);width:36px;height:36px;color:var(--color-muted);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-bottom:2px;transition:background-color .15s,border-color .15s,color .15s;display:flex}.resize-lock-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.resize-lock-btn.locked{background:var(--color-primary);color:var(--color-primary-foreground);border-color:var(--color-primary)}.resize-lock-btn:focus-visible{box-shadow:0 0 0 2px var(--color-primary);outline:none}.resize-action-row{align-items:center;gap:10px;display:flex}.resize-error{color:var(--color-danger);margin-top:4px;font-size:14px}.resize-row-dims{color:var(--color-muted);white-space:nowrap;flex-shrink:0;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:12px}@media (max-width:640px){.resize-dim-row{flex-direction:column;align-items:stretch;gap:8px}.resize-lock-btn{align-self:center;margin-bottom:0}.resize-percent-presets{flex-wrap:wrap}}.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}@media (prefers-reduced-motion:reduce){.btn,.drop-zone,.lang-select,.theme-toggle,.tool-card{transition:none}}.not-found{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;padding:2rem;display:flex}.not-found-icon{margin-bottom:1rem;font-size:4rem}.not-found-heading{color:var(--color-primary);margin:0 0 1rem;font-size:6rem;font-weight:700;line-height:1}.not-found-desc{color:var(--color-muted);margin:0 0 2rem;font-size:1.25rem}.not-found-link{background:var(--color-primary);color:var(--color-primary-foreground);border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;text-decoration:none;transition:opacity .2s;display:inline-flex}.not-found-link:hover{opacity:.9}.not-found-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.breadcrumbs ol{flex-wrap:wrap;align-items:center;gap:8px;margin:0;padding:0;font-size:13px;list-style:none;display:flex}.breadcrumbs li{align-items:center;display:inline-flex}.breadcrumbs a{color:var(--color-muted);text-decoration:none;transition:color .2s}.breadcrumbs a:hover{color:var(--color-primary)}.breadcrumbs-sep{color:var(--color-border);-webkit-user-select:none;user-select:none}.breadcrumbs-category{color:var(--color-muted)}.breadcrumbs-current{color:var(--color-foreground);font-weight:500}.related-tools{max-width:960px;margin:64px auto 32px;padding:0 20px}.related-tools h2{color:var(--color-foreground);margin-bottom:16px;font-size:20px}.related-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.related-card{background:var(--color-card);border:1px solid var(--color-border);color:inherit;border-radius:12px;gap:12px;padding:16px;text-decoration:none;transition:transform .18s,border-color .18s;display:flex}.related-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.related-icon{width:36px;height:36px;color:var(--color-foreground);background:#ffffff0a;border:1px solid #ffffff0f;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.related-body{flex-direction:column;gap:4px;min-width:0;display:flex}.related-body h3{color:var(--color-foreground);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:15px;font-weight:600;overflow:hidden}.related-body p{color:var(--color-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:12px;line-height:1.45;display:-webkit-box;overflow:hidden}@media (max-width:720px){.search-box{z-index:20;background:var(--color-background);border-bottom:1px solid var(--color-border);margin-left:-20px;margin-right:-20px;padding:8px 20px;position:sticky;top:56px}}.faq-section{max-width:820px;margin:48px auto 32px;padding:0 20px}.faq-section h2{color:var(--color-foreground);margin-bottom:20px;font-size:22px}.faq-section dl{flex-direction:column;gap:8px;margin:0;display:flex}.faq-item{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:0;overflow:hidden}.faq-item summary{cursor:pointer;color:var(--color-foreground);padding:16px 44px 16px 20px;font-weight:600;list-style:none;transition:background .15s;position:relative}.faq-item summary::-webkit-details-marker{display:none}.faq-item summary:after{content:"+";color:var(--color-muted);font-size:20px;transition:transform .2s;position:absolute;top:50%;right:20px;transform:translateY(-50%)}.faq-item[open] summary:after{content:"−"}.faq-item summary:hover{background:var(--color-background)}.faq-item summary dt{font-size:15px;display:inline}.faq-item dd{color:var(--color-muted);margin:0;padding:0 20px 20px;font-size:14px;line-height:1.7}.category-link{background:var(--color-card);border:1px solid var(--color-border);color:var(--color-primary);border-radius:10px;padding:10px 20px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s;display:inline-block}.category-link:hover{background:var(--color-background)}.mega-menu{align-items:center;display:flex}.mm-bar{gap:2px;margin:0;padding:0;list-style:none;display:flex}.mm-item{position:relative}.mm-trigger{color:var(--color-foreground);cursor:pointer;white-space:nowrap;background:0 0;border:0;border-radius:8px;align-items:center;gap:6px;padding:10px 14px;font-size:14px;font-weight:500;transition:background .15s;display:flex}.mm-item.open .mm-trigger,.mm-trigger:hover{background:var(--color-accent)}.mm-cat-icon{font-size:16px}.mm-cat-count{color:var(--color-muted);background:var(--color-background);border-radius:10px;padding:1px 7px;font-size:11px}.mm-panel{background:var(--color-card);border:1px solid var(--color-border);visibility:hidden;opacity:0;z-index:60;border-radius:12px;min-width:560px;max-width:780px;max-height:calc(100vh - 80px);padding:16px;transition:opacity .12s,transform .12s,visibility 0s linear .12s;position:absolute;top:calc(100% + 4px);left:0;overflow-y:auto;transform:translateY(-4px);box-shadow:0 12px 36px #00000040}.mm-item.open .mm-panel{visibility:visible;opacity:1;transition:opacity .12s,transform .12s;transform:translateY(0)}.mm-item-right .mm-panel{left:auto;right:0}.mm-panel-wide{max-height:calc(100vh - 80px);position:fixed;top:68px;overflow-y:auto;transform:translate(-50%)translateY(-4px);left:50%!important;right:auto!important}.mm-item.open .mm-panel-wide{transform:translate(-50%)translateY(0)}.mm-panel-wide{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px 28px;min-width:920px;max-width:min(1200px,96vw);display:grid}.mm-panel-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 12px;margin:0;padding:0;list-style:none;display:grid}.mm-panel-list li a,.mm-subgroup ul li a{color:var(--color-foreground);border-radius:8px;align-items:center;gap:10px;padding:8px 10px;text-decoration:none;transition:background .1s;display:flex}.mm-panel-list li a:hover,.mm-subgroup ul li a:hover{background:var(--color-accent)}.mm-tool-icon{background:var(--color-background);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:18px;display:flex}.mm-tool-body{flex-direction:column;gap:2px;min-width:0;display:flex}.mm-tool-title{font-size:13px;font-weight:500}.mm-tool-desc,.mm-tool-title{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.mm-tool-desc{color:var(--color-muted);font-size:11px}.mm-subgroup{min-width:0}.mm-subgroup-head{color:var(--color-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;padding:0 10px;font-size:10px;font-weight:700}.mm-subgroup ul{margin:0;padding:0;list-style:none}.mm-mobile-toggle{color:var(--color-foreground);cursor:pointer;background:0 0;border:0;border-radius:8px;padding:8px 10px;font-size:22px;line-height:1;display:none}.mm-mobile-toggle:hover{background:var(--color-accent)}.mm-backdrop{z-index:250;background:#00000080;position:fixed;inset:0}.mega-menu-drawer{background:var(--color-card);border-right:1px solid var(--color-border);z-index:260;width:82%;max-width:340px;padding:0 8px 24px;animation:mm-slide-in .2s ease-out;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;box-shadow:4px 0 24px #0006}@keyframes mm-slide-in{0%{transform:translate(-100%)}to{transform:translate(0)}}.mm-drawer-head{border-bottom:1px solid var(--color-border);text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);justify-content:space-between;align-items:center;margin-bottom:8px;padding:16px 14px 12px;font-size:12px;font-weight:700;display:flex}.mm-drawer-close{color:var(--color-foreground);cursor:pointer;background:0 0;border:0;border-radius:8px;width:32px;height:32px;font-size:20px;line-height:1}.mm-drawer-close:hover{background:var(--color-accent)}.mega-menu-drawer .mm-bar{flex-direction:column;gap:2px}.mega-menu-drawer .mm-item{width:100%;position:relative}.mega-menu-drawer .mm-trigger{justify-content:flex-start;gap:10px;width:100%}.mega-menu-drawer .mm-cat-count{margin-left:auto}.mega-menu-drawer .mm-panel,.mega-menu-drawer .mm-panel-wide{visibility:visible;opacity:1;box-shadow:none;background:0 0;border:0;border-radius:0;grid-template-columns:1fr;padding:4px 8px 8px;display:none;overflow-x:hidden;min-width:0!important;max-width:100%!important;max-height:none!important;position:static!important;top:auto!important;left:auto!important;right:auto!important;transform:none!important}.mega-menu-drawer .mm-item.open .mm-panel,.mega-menu-drawer .mm-item.open .mm-panel-wide{display:block}.mega-menu-drawer .mm-panel-list{grid-template-columns:1fr}.mega-menu-drawer .mm-subgroup+.mm-subgroup{margin-top:8px}.mega-menu-drawer .mm-tool-title{white-space:normal;text-overflow:unset;overflow:visible}.mega-menu-drawer .mm-panel-list li a,.mega-menu-drawer .mm-subgroup ul li a{padding:6px 8px}@media (max-width:1100px){.mega-menu{display:none}.mm-mobile-toggle{order:-1;display:inline-flex}}.cmdk-overlay{z-index:300;justify-content:center;align-items:flex-start;padding:80px 20px 20px;display:flex;position:fixed;inset:0}.cmdk-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;position:absolute;inset:0}.cmdk-panel{background:var(--color-card);border:1px solid var(--color-border);border-radius:14px;flex-direction:column;width:100%;max-width:640px;max-height:calc(100vh - 120px);display:flex;position:relative;overflow:hidden;box-shadow:0 24px 72px #00000080}.cmdk-input-wrap{border-bottom:1px solid var(--color-border);align-items:center;gap:10px;padding:14px 16px;display:flex}.cmdk-icon{width:18px;height:18px;color:var(--color-muted)}.cmdk-input{color:var(--color-foreground);background:0 0;border:0;outline:none;flex:1;font-family:inherit;font-size:16px}.cmdk-esc{background:var(--color-background);border:1px solid var(--color-border);color:var(--color-muted);border-radius:4px;padding:2px 6px;font-family:ui-monospace,Menlo,monospace;font-size:10px}.cmdk-list{flex:1;margin:0;padding:6px;list-style:none;overflow-y:auto}.cmdk-item a{color:var(--color-foreground);cursor:pointer;border-radius:8px;grid-template-columns:40px minmax(0,1fr) auto;align-items:center;gap:12px;padding:10px 12px;text-decoration:none;display:grid}.cmdk-item.active a{background:var(--color-accent)}.cmdk-item-icon{background:var(--color-background);border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:22px;display:flex}.cmdk-item-body{flex-direction:column;gap:2px;min-width:0;display:flex}.cmdk-item-title{font-size:14px;font-weight:600}.cmdk-item-desc,.cmdk-item-title{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.cmdk-item-desc{color:var(--color-muted);font-size:12px}.cmdk-item-meta{align-items:center;gap:6px;font-size:10px;display:flex}.cmdk-item-group{font-size:14px}.cmdk-item-cat{text-transform:uppercase;letter-spacing:.05em;background:var(--color-background);color:var(--color-muted);border-radius:4px;padding:3px 8px}.cmdk-empty{text-align:center;color:var(--color-muted);padding:32px;font-size:14px}.cmdk-footer{border-top:1px solid var(--color-border);color:var(--color-muted);gap:18px;padding:10px 16px;font-size:11px;display:flex}.cmdk-footer kbd{background:var(--color-background);border:1px solid var(--color-border);border-radius:3px;margin-right:4px;padding:1px 5px;font-family:ui-monospace,Menlo,monospace}.footer-sitemap{border-bottom:1px solid var(--color-border);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:24px 20px;max-width:1400px;margin:0 auto;padding:36px 24px 24px;display:grid}.footer-sitemap-col{min-width:0}.footer-sitemap-head{text-transform:uppercase;letter-spacing:.06em;color:var(--color-foreground);margin:0 0 10px;font-size:11px;font-weight:700}.footer-sitemap-col ul{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.footer-sitemap-col li a{color:var(--color-muted);font-size:12px;text-decoration:none;transition:color .1s}.footer-sitemap-col li a:hover{color:var(--color-foreground)}.footer-sitemap-all{font-weight:600;color:var(--color-primary)!important}.blog-list{flex-direction:column;gap:16px;display:flex}.blog-card{color:var(--color-foreground);background:var(--color-card);border:1px solid var(--color-border);border-radius:14px;padding:22px 24px;text-decoration:none;transition:transform .15s,border-color .15s,box-shadow .15s;display:block}.blog-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 6px 20px #0000001a}.blog-card h2{margin:10px 0 8px;font-size:20px;font-weight:600}.blog-card p{color:var(--color-muted);margin:0;font-size:14px;line-height:1.55}.blog-card-meta{color:var(--color-muted);align-items:center;gap:10px;font-size:12px;display:flex}.blog-card-cat{background:var(--color-accent);text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:2px 10px;font-size:11px;font-weight:600}.blog-post-layout{grid-template-columns:minmax(0,1fr) 220px;align-items:start;gap:36px;max-width:1060px;margin:0 auto;padding:24px 20px 80px;display:grid}@media (max-width:860px){.blog-post-layout{grid-template-columns:minmax(0,1fr)}}.blog-post-header{margin:16px 0 32px}.blog-post-header h1{margin:12px 0 10px;font-size:32px;font-weight:700;line-height:1.25}.blog-post-desc{color:var(--color-muted);margin:0;font-size:16px;line-height:1.55}.blog-post-meta{color:var(--color-muted);align-items:center;gap:10px;font-size:12px;display:flex}.prose{color:var(--color-foreground);font-size:16px;line-height:1.75}.prose h2{border-bottom:1px solid var(--color-border);margin:40px 0 16px;padding-bottom:8px;font-size:24px;font-weight:700}.prose h3{margin:28px 0 12px;font-size:19px;font-weight:600}.prose p{margin:14px 0}.prose a{color:var(--color-primary);text-underline-offset:2px;text-decoration:underline}.prose ol,.prose ul{margin:14px 0;padding-left:24px}.prose li{margin:6px 0}.prose strong{font-weight:600}.prose code{background:var(--color-accent);border-radius:4px;padding:2px 6px;font-family:ui-monospace,Menlo,monospace;font-size:14px}.prose pre{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;padding:16px;font-size:14px;overflow-x:auto}.prose pre code{background:0 0;padding:0}.prose table{border-collapse:collapse;width:100%;margin:18px 0;font-size:14px}.prose th{text-align:left;background:var(--color-accent);border-bottom:2px solid var(--color-border);padding:10px 14px;font-weight:600}.prose td{border-bottom:1px solid var(--color-border);padding:10px 14px}.prose blockquote{border-left:4px solid var(--color-primary);background:var(--color-accent);border-radius:0 8px 8px 0;margin:18px 0;padding:12px 20px}.prose hr{border:0;border-top:1px solid var(--color-border);margin:32px 0}.blog-sidebar{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:18px;position:sticky;top:84px}.blog-sidebar h3{text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);margin:0 0 12px;font-size:13px;font-weight:700}.blog-sidebar ul{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.blog-sidebar li a{color:var(--color-foreground);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:14px;text-decoration:none;transition:background .1s;display:flex}.blog-sidebar li a:hover{background:var(--color-accent)}.compare-table-wrap{margin:16px 0 28px;overflow-x:auto}.compare-table{border-collapse:collapse;width:100%;font-size:14px}.compare-table th{text-align:left;border-bottom:2px solid var(--color-border);text-transform:uppercase;letter-spacing:.03em;color:var(--color-muted);padding:10px 14px;font-size:13px;font-weight:600}.compare-col-eazi{color:var(--color-foreground)!important}.compare-table td{border-bottom:1px solid var(--color-border);padding:10px 14px;line-height:1.45}.compare-table tbody tr:hover{background:#ffffff08}.compare-feature-name{white-space:nowrap;font-weight:500}.compare-cta{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;margin-top:32px;padding:20px 24px}.compare-cta p{margin:0 0 12px;font-size:15px;font-weight:600}.compare-cta-links{flex-wrap:wrap;gap:8px;display:flex}.compare-cta-link{background:var(--color-accent);color:var(--color-foreground);border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:opacity .15s;display:inline-flex}.compare-cta-link:hover{opacity:.85}@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-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-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}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}