/*! tailwindcss v4.2.4 | 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)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-font-weight:initial;--tw-outline-style:solid;--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-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0}}}@layer theme{:root,:host{--font-sans:"Geist Variable", sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--font-weight-medium:500;--radius-md:calc(var(--radius) * .8);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:"Geist Variable", sans-serif;--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*{border-color:var(--border);outline-color:var(--ring)}@supports (color:color-mix(in lab, red, red)){*{outline-color:color-mix(in oklab, var(--ring) 50%, transparent)}}body{background-color:var(--background);color:var(--foreground)}html{font-family:Geist Variable,sans-serif}}@layer components;@layer utilities{.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.start{inset-inline-start:var(--spacing)}.inline-flex{display:inline-flex}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-7{width:calc(var(--spacing) * 7);height:calc(var(--spacing) * 7)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.shrink-0{flex-shrink:0}.items-center{align-items:center}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.rounded-\[min\(var\(--radius-md\)\,10px\)\]{border-radius:min(var(--radius-md), 10px)}.rounded-\[min\(var\(--radius-md\)\,12px\)\]{border-radius:min(var(--radius-md), 12px)}.rounded-lg{border-radius:var(--radius)}.border{border-style:var(--tw-border-style);border-width:1px}.border-border{border-color:var(--border)}.border-transparent{border-color:#0000}.bg-background{background-color:var(--background)}.bg-destructive\/10{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.bg-destructive\/10{background-color:color-mix(in oklab, var(--destructive) 10%, transparent)}}.bg-primary{background-color:var(--primary)}.bg-secondary{background-color:var(--secondary)}.bg-clip-padding{background-clip:padding-box}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.8rem\]{font-size:.8rem}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.whitespace-nowrap{white-space:nowrap}.text-destructive{color:var(--destructive)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-secondary-foreground{color:var(--secondary-foreground)}.underline-offset-4{text-underline-offset:4px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.hover\:bg-destructive\/20:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-destructive\/20:hover{background-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.hover\:bg-muted:hover{background-color:var(--muted)}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab, var(--secondary) 80%, transparent)}}.hover\:text-foreground:hover{color:var(--foreground)}.hover\:underline:hover{text-decoration-line:underline}}.focus-visible\:border-destructive\/40:focus-visible{border-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.focus-visible\:border-destructive\/40:focus-visible{border-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:ring-3:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + 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)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab, red, red)){.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:color-mix(in oklab, var(--ring) 50%, transparent)}}.active\:not-aria-\[haspopup\]\:translate-y-px:active:not([aria-haspopup]){--tw-translate-y:1px;translate:var(--tw-translate-x) var(--tw-translate-y)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}:where([data-slot=button-group]) .in-data-\[slot\=button-group\]\:rounded-lg{border-radius:var(--radius)}.has-data-\[icon\=inline-end\]\:pr-1\.5:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 1.5)}.has-data-\[icon\=inline-end\]\:pr-2:has([data-icon=inline-end]){padding-right:calc(var(--spacing) * 2)}.has-data-\[icon\=inline-start\]\:pl-1\.5:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 1.5)}.has-data-\[icon\=inline-start\]\:pl-2:has([data-icon=inline-start]){padding-left:calc(var(--spacing) * 2)}.aria-expanded\:bg-muted[aria-expanded=true]{background-color:var(--muted)}.aria-expanded\:bg-secondary[aria-expanded=true]{background-color:var(--secondary)}.aria-expanded\:text-foreground[aria-expanded=true]{color:var(--foreground)}.aria-expanded\:text-secondary-foreground[aria-expanded=true]{color:var(--secondary-foreground)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-3[aria-invalid=true]{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + 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)}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.dark\:border-input:is(.dark *){border-color:var(--input)}.dark\:bg-destructive\/20:is(.dark *){background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:bg-destructive\/20:is(.dark *){background-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.dark\:bg-input\/30:is(.dark *){background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:bg-input\/30:is(.dark *){background-color:color-mix(in oklab, var(--input) 30%, transparent)}}@media (hover:hover){.dark\:hover\:bg-destructive\/30:is(.dark *):hover{background-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-destructive\/30:is(.dark *):hover{background-color:color-mix(in oklab, var(--destructive) 30%, transparent)}}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:var(--input)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:color-mix(in oklab, var(--input) 50%, transparent)}}.dark\:hover\:bg-muted\/50:is(.dark *):hover{background-color:var(--muted)}@supports (color:color-mix(in lab, red, red)){.dark\:hover\:bg-muted\/50:is(.dark *):hover{background-color:color-mix(in oklab, var(--muted) 50%, transparent)}}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid=true]{border-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:aria-invalid\:border-destructive\/50:is(.dark *)[aria-invalid=true]{border-color:color-mix(in oklab, var(--destructive) 50%, transparent)}}.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab, red, red)){.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3\.5 svg:not([class*=size-]){width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}@media (hover:hover){.\[a\]\:hover\:bg-primary\/80:is(a):hover{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.\[a\]\:hover\:bg-primary\/80:is(a):hover{background-color:color-mix(in oklab, var(--primary) 80%, transparent)}}}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-cyrillic-wght-normal-CHSlOQsW.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-latin-ext-wght-normal-DMtmJ5ZE.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/geist-latin-wght-normal-Dm3htQBi.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{color:#202124;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--background:oklch(100% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--primary:oklch(20.5% 0 0);--primary-foreground:oklch(98.5% 0 0);--secondary:oklch(97% 0 0);--secondary-foreground:oklch(20.5% 0 0);--muted:oklch(97% 0 0);--muted-foreground:oklch(55.6% 0 0);--accent:oklch(97% 0 0);--accent-foreground:oklch(20.5% 0 0);--destructive:oklch(57.7% .245 27.325);--border:oklch(92.2% 0 0);--input:oklch(92.2% 0 0);--ring:oklch(70.8% 0 0);--chart-1:oklch(87% 0 0);--chart-2:oklch(55.6% 0 0);--chart-3:oklch(43.9% 0 0);--chart-4:oklch(37.1% 0 0);--chart-5:oklch(26.9% 0 0);--radius:.625rem;--sidebar:oklch(98.5% 0 0);--sidebar-foreground:oklch(14.5% 0 0);--sidebar-primary:oklch(20.5% 0 0);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(97% 0 0);--sidebar-accent-foreground:oklch(20.5% 0 0);--sidebar-border:oklch(92.2% 0 0);--sidebar-ring:oklch(70.8% 0 0);background:#f7f8fa;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,textarea,select{font:inherit}.sidebar-wrapper{background:#f7f8fa;min-height:100vh;display:flex}.sidebar{color:#202124;background:#fff;border-right:1px solid #dde1e6;flex-direction:column;width:256px;height:100vh;display:flex;position:sticky;top:0}.sidebar-header{padding:18px 16px 12px}.sidebar-brand{color:#111827;align-items:center;gap:10px;font-size:15px;font-weight:850;text-decoration:none;display:flex}.sidebar-brand-icon{color:#fff;background:#111827;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:inline-flex}.sidebar-brand-icon svg{width:16px;height:16px}.sidebar-content{flex:1;min-height:0;padding:4px 10px 16px;overflow:auto}.sidebar-group{gap:6px;display:grid}.sidebar-group-label{color:#69707d;padding:0 8px 4px;font-size:12px;font-weight:800}.sidebar-menu{gap:2px;margin:0;padding:0;list-style:none;display:grid}.sidebar-menu-button{color:#394150;cursor:pointer;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;width:100%;min-height:38px;padding:8px 10px;transition:background-color .15s,color .15s;display:flex}.sidebar-menu-button svg{flex:none;width:16px;height:16px}.sidebar-menu-button span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.sidebar-menu-button:hover{color:#111827;background:#f0f4f4}.sidebar-menu-button[data-active=true]{color:#1d6360;background:#e7f4f2;font-weight:800}.sidebar-inset{flex:1;min-width:0}.mobile-toolbar{display:none}.app{justify-content:center;min-height:100vh;padding:32px;display:flex}.app-shell{width:min(100%,1180px);display:grid}.home-page{align-content:start;gap:26px;width:min(100%,1180px);display:grid}.home-header{gap:12px;max-width:760px;display:grid}.home-title-row{align-items:center;gap:14px;display:flex}.home-title-icon{color:#fff;background:#111827;border-radius:8px;justify-content:center;align-items:center;width:54px;height:54px;display:inline-flex}.home-title-icon svg{width:26px;height:26px}.home-summary{color:#4b5563;margin:0;font-size:18px;font-weight:650;line-height:1.55}.home-tool-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.home-tool-card{color:#202124;background:#fff;border:1px solid #dde1e6;border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto;align-items:start;gap:14px;min-height:138px;padding:18px;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .15s;display:grid;box-shadow:0 14px 34px #181f2c0f}.home-tool-card:hover{border-color:#9fc9c4;transform:translateY(-1px);box-shadow:0 18px 44px #181f2c1a}.home-tool-icon{color:#1d6360;background:#e7f4f2;border-radius:8px;justify-content:center;align-items:center;width:42px;height:42px;display:inline-flex}.home-tool-icon svg,.home-tool-arrow{width:19px;height:19px}.home-tool-content{gap:8px;min-width:0;display:grid}.home-tool-content strong{color:#111827;font-size:18px;font-weight:850;line-height:1.2}.home-tool-content span{color:#5f6673;font-size:14px;font-weight:650;line-height:1.45}.home-tool-arrow{color:#8b95a1}.jwt-tool,.bcrypt-tool,.base-converter,.text-tool,.unit-converter,.subnet-calculator,.ip-address-converter,.exchange-rate-calculator{width:min(100%,1180px)}.tool-header{justify-content:space-between;align-items:end;gap:24px;margin-bottom:24px;display:flex}.eyebrow{color:#256f6c;margin:0 0 10px;font-size:14px;font-weight:700}h1,h2{color:#111827}h1{margin:0;font-size:clamp(32px,5vw,52px);line-height:1.06}h2{margin:0;font-size:22px;line-height:1.2}.secret-field{gap:8px;min-width:min(100%,340px);display:grid}.secret-field label,.field{color:#3a414d;font-size:13px;font-weight:700}.secret-field label{align-items:center;gap:8px;display:inline-flex}.secret-field svg{width:16px;height:16px}.secret-field input,.field textarea,.unit-input,.unit-result,.base-value-input,.unit-select{color:#111827;background:#fff;border:1px solid #dde1e6;border-radius:8px;outline:none;transition:border-color .15s,box-shadow .15s}.secret-field input:focus,.field textarea:focus,.unit-input:focus-within,.base-value-input:focus,.unit-select:focus{border-color:#256f6c;box-shadow:0 0 0 3px #256f6c24}.secret-field input{height:40px;padding:0 12px}.tool-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.tool-panel{background:#fff;border:1px solid #dde1e6;border-radius:8px;align-content:start;gap:16px;padding:22px;display:grid;box-shadow:0 18px 50px #181f2c14}.panel-heading{justify-content:space-between;align-items:center;gap:12px;display:flex}.field{gap:8px;display:grid}.field textarea{resize:vertical;min-height:138px;padding:12px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;font-weight:500;line-height:1.55}.field textarea[readonly]{background:#f7f8fa}.token-input{min-height:190px}.secondary-action{justify-self:start}.verification{color:#5f6673;background:#f7f8fa;border:1px solid #d9dee8;border-radius:999px;width:fit-content;max-width:100%;min-height:38px;padding:8px 12px;font-size:13px;font-weight:800}.verification.is-valid{color:#12643d;background:#ecf8f2;border-color:#9bd1bd}.verification.is-invalid{color:#a92323;background:#fff0f0;border-color:#f1b6b6}.verification.is-match{color:#12643d;background:#ecf8f2;border-color:#9bd1bd}.verification.is-mismatch{color:#a92323;background:#fff0f0;border-color:#f1b6b6}.verification.is-unsupported,.verification.is-missing-secret,.verification.is-unsigned{color:#7a5a00;background:#fff8df;border-color:#ead28c}.verification svg{vertical-align:-2px;width:15px;height:15px;margin-right:6px}.bcrypt-cost-badge{color:#1d6360;background:#edf8f6;border:1px solid #d7dfdf;border-radius:999px;align-items:center;gap:8px;min-height:40px;padding:8px 14px;font-size:13px;font-weight:800;display:inline-flex}.bcrypt-cost-badge svg{width:16px;height:16px}.bcrypt-cost-field{color:#3a414d;gap:10px;font-size:13px;font-weight:800;display:grid}.bcrypt-cost-control{grid-template-columns:minmax(0,1fr) 44px;align-items:center;gap:14px;display:grid}.bcrypt-cost-control input{accent-color:#256f6c}.bcrypt-cost-control strong{color:#111827;background:#f7f8fa;border:1px solid #dde1e6;border-radius:8px;justify-content:center;align-items:center;min-height:36px;font-size:16px;font-weight:850;display:inline-flex}.bcrypt-textarea{min-height:114px}.text-counter-panel,.text-generator-panel{gap:18px}.text-tool-textarea{min-height:220px}.text-count-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.text-count-card{background:#fbfcfd;border:1px solid #e3e7ec;border-radius:8px;align-content:center;gap:8px;min-width:0;min-height:116px;padding:16px;display:grid}.text-count-card span{color:#69707d;font-size:12px;font-weight:850}.text-count-card strong{color:#111827;overflow-wrap:anywhere;font-size:34px;font-weight:900;line-height:1.1}.text-length-input{color:#111827;background:#fff;border:1px solid #dde1e6;border-radius:8px;outline:none;width:100%;min-height:48px;padding:0 12px;font-size:18px;font-weight:800;transition:border-color .15s,box-shadow .15s}.text-length-input:focus{border-color:#256f6c;box-shadow:0 0 0 3px #256f6c24}.text-option-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.text-option-grid label{color:#3a414d;background:#fbfcfd;border:1px solid #dde1e6;border-radius:8px;align-items:center;gap:9px;min-width:0;min-height:44px;padding:10px 12px;font-size:13px;font-weight:850;display:inline-flex}.text-option-grid input{accent-color:#256f6c;width:16px;height:16px}.conversion-chip{color:#1d6360;background:#edf8f6;border:1px solid #d7dfdf;border-radius:999px;align-items:center;gap:8px;min-height:40px;padding:8px 14px;font-size:13px;font-weight:800;display:inline-flex}.conversion-chip svg{width:16px;height:16px}.converter-panel,.base-converter-panel{gap:22px}.base-input-row{grid-template-columns:minmax(0,1fr) minmax(260px,320px) auto;align-items:end;gap:18px;display:grid}.base-value-input{width:100%;min-height:68px;padding:0 16px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:28px;font-weight:750;line-height:1.2}.base-reset-button{min-height:48px;margin-bottom:0}.base-selector{background:#fff;border:1px solid #dde1e6;border-radius:8px;grid-template-columns:repeat(4,minmax(0,1fr));min-height:48px;display:grid;overflow:hidden}.base-selector button{color:#4b5563;cursor:pointer;background:0 0;border:0;border-right:1px solid #edf0f2;min-width:0;padding:0 10px;font-size:13px;font-weight:850;transition:background-color .15s,color .15s}.base-selector button:last-child{border-right:0}.base-selector button:hover{color:#1d6360;background:#f4fbfa}.base-selector button[data-active=true]{color:#1d6360;background:#e7f4f2}.base-result-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.base-result-card{background:#fbfcfd;border:1px solid #e3e7ec;border-radius:8px;align-content:start;gap:10px;min-width:0;min-height:132px;padding:16px;display:grid}.base-result-card span{color:#69707d;font-size:12px;font-weight:850}.base-result-card strong{color:#111827;overflow-wrap:anywhere;min-width:0;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:24px;font-weight:850;line-height:1.3}.base-result-card code{color:#1d6360;background:#edf8f6;border:1px solid #d7dfdf;border-radius:999px;width:fit-content;padding:4px 8px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px;font-weight:850}.category-tabs{flex-wrap:wrap;gap:8px;display:flex}.category-tab{color:#4b5563;cursor:pointer;background:#fff;border:1px solid #dde1e6;border-radius:999px;min-height:36px;padding:8px 13px;font-size:13px;font-weight:850;transition:background-color .15s,border-color .15s,color .15s}.category-tab:hover{color:#1d6360;background:#f4fbfa;border-color:#bad2cf}.category-tab[data-active=true]{color:#1d6360;background:#e7f4f2;border-color:#9fc9c4}.converter-grid{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:end;gap:18px;display:grid}.unit-field{color:#3a414d;gap:10px;font-size:14px;font-weight:800;display:grid}.unit-input,.unit-result{grid-template-columns:minmax(0,1fr) auto;align-items:center;min-height:68px;display:grid;overflow:hidden}.unit-input input,.unit-result strong{color:#111827;background:0 0;border:0;outline:none;min-width:0;padding:0 16px;font-size:28px;font-weight:750;line-height:1.2}.unit-result strong{overflow-wrap:anywhere}.unit-input span,.unit-result span{color:#5f6673;background:#f7f8fa;border-left:1px solid #edf0f2;align-self:stretch;align-items:center;padding:0 16px;font-size:14px;font-weight:900;display:inline-flex}.unit-select-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.unit-select{color:#111827;outline:none;width:100%;min-height:48px;padding:0 12px}.swap-mark{color:#256f6c;background:#fff;border:1px solid #dde1e6;border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:14px;display:inline-flex}.swap-mark svg{width:18px;height:18px}.conversion-summary{color:#202124;border-top:1px solid #edf0f2;margin:0;padding-top:18px;font-size:18px;font-weight:800;line-height:1.4}.conversion-summary.is-error{color:#a92323}.exchange-rate-status{gap:12px;display:grid}.exchange-rate-meta{color:#5f6673;flex-wrap:wrap;gap:8px;font-size:13px;font-weight:800;line-height:1.4;display:flex}.exchange-rate-meta span{background:#f7f8fa;border:1px solid #dde1e6;border-radius:999px;align-items:center;min-height:30px;padding:6px 10px;display:inline-flex}.exchange-rate-meta span[data-state=success]{color:#12643d;background:#ecf8f2;border-color:#9bd1bd}.exchange-rate-meta span[data-state=error]{color:#a92323;background:#fff0f0;border-color:#f1b6b6}.exchange-rate-meta span[data-state=loading]{color:#7a5a00;background:#fff8df;border-color:#ead28c}.exchange-rate-loading{color:#69707d;font-size:13px;font-weight:800}.subnet-layout{grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:18px;display:grid}.ip-converter-layout{grid-template-columns:minmax(320px,.78fr) minmax(0,1.22fr);gap:18px;display:grid}.ip-converter-input-panel,.ip-converter-result-panel{gap:20px}.ip-converter-input-panel .panel-heading svg,.ip-converter-result-panel .panel-heading svg{color:#256f6c;width:20px;height:20px}.ip-address-field{color:#3a414d;gap:8px;font-size:13px;font-weight:850;display:grid}.ip-address-input{color:#111827;background:#fff;border:1px solid #dde1e6;border-radius:8px;outline:none;width:100%;min-height:58px;padding:0 14px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:18px;font-weight:800;line-height:1.2;transition:border-color .15s,box-shadow .15s}.ip-address-input:focus{border-color:#256f6c;box-shadow:0 0 0 3px #256f6c24}.ip-example-actions{flex-wrap:wrap;gap:8px;display:flex}.ip-converter-status{color:#3f4652;min-height:22px;margin:0;font-size:14px;font-weight:750;line-height:1.45}.ip-converter-status.is-error{color:#a92323}.ip-result-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.ip-result-card{background:#fbfcfd;border:1px solid #e3e7ec;border-radius:8px;align-content:start;gap:9px;min-width:0;min-height:104px;padding:14px;display:grid}.ip-result-card span{color:#69707d;font-size:12px;font-weight:850}.ip-result-card strong{color:#111827;overflow-wrap:anywhere;min-width:0;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:16px;font-weight:800;line-height:1.35}.subnet-input-panel,.subnet-result-panel{gap:20px}.subnet-input-panel .panel-heading svg,.subnet-result-panel .panel-heading svg{color:#256f6c;width:20px;height:20px}.ip-entry{grid-template-columns:repeat(4,minmax(64px,1fr)) auto minmax(72px,.65fr);align-items:end;gap:10px;display:grid}.ip-segment-field{color:#3a414d;gap:8px;min-width:0;font-size:12px;font-weight:850;display:grid}.ip-segment-field input{color:#111827;text-align:center;background:#fff;border:1px solid #dde1e6;border-radius:8px;outline:none;width:100%;min-height:52px;padding:0 10px;font-size:22px;font-weight:850;transition:border-color .15s,box-shadow .15s}.ip-segment-field input:focus{border-color:#256f6c;box-shadow:0 0 0 3px #256f6c24}.cidr-separator{color:#66707f;align-items:center;min-height:52px;font-size:28px;font-weight:850;display:inline-flex}.prefix-field input{color:#1d6360;background:#eef7f5}.subnet-status{color:#3f4652;min-height:22px;margin:0;font-size:14px;font-weight:750;line-height:1.45}.bit-visualization{border-top:1px solid #edf0f2;gap:12px;padding-top:18px;display:grid}.bit-legend{color:#4b5563;flex-wrap:wrap;gap:12px;font-size:13px;font-weight:800;display:flex}.bit-legend span{align-items:center;gap:6px;display:inline-flex}.bit-legend i{border-radius:3px;width:12px;height:12px}.legend-network{background:#1d6360}.legend-host{background:#8f5d1e}.bit-grid{grid-template-columns:repeat(8,minmax(24px,1fr));gap:6px;display:grid}.bit-cell{border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;min-height:30px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;font-weight:850;display:inline-flex}.bit-cell[data-role=network]{color:#1d6360;background:#e7f4f2;border-color:#9fc9c4}.bit-cell[data-role=host]{color:#7a4b12;background:#fff4df;border-color:#e8c99f}.subnet-result-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.subnet-result-item{background:#fbfcfd;border:1px solid #e3e7ec;border-radius:8px;gap:8px;min-height:82px;padding:14px;display:grid}.subnet-result-item span,.binary-output span{color:#69707d;font-size:12px;font-weight:850}.subnet-result-item strong{color:#111827;overflow-wrap:anywhere;min-width:0;font-size:20px;font-weight:850;line-height:1.2}.binary-output{border-top:1px solid #edf0f2;gap:10px;padding-top:18px;display:grid}.binary-output div{gap:7px;display:grid}.binary-output code{color:#111827;white-space:nowrap;background:#f7f8fa;border:1px solid #dde1e6;border-radius:8px;width:100%;padding:10px 12px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;font-weight:750;line-height:1.4;display:block;overflow-x:auto}.empty-result{color:#69707d;text-align:center;background:#f7f8fa;border:1px dashed #cfd6df;border-radius:8px;place-items:center;min-height:220px;padding:20px;font-size:14px;font-weight:800;display:grid}.status-message{color:#3f4652;min-height:24px;margin:16px 0 0;font-size:14px;font-weight:700}@media (width<=900px){.sidebar-wrapper{display:block}.sidebar{z-index:30;width:min(82vw,280px);transition:transform .18s;position:fixed;inset:0 auto 0 0;transform:translate(-100%)}.sidebar-wrapper[data-state=expanded] .sidebar{transform:translate(0);box-shadow:18px 0 50px #181f2c2e}.mobile-toolbar{z-index:20;color:#3a414d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f7f8faeb;border-bottom:1px solid #dde1e6;align-items:center;gap:10px;min-height:52px;padding:8px 16px;font-size:14px;font-weight:800;display:flex;position:sticky;top:0}.app{min-height:calc(100vh - 52px);padding:20px}.tool-header,.panel-heading{flex-direction:column;align-items:stretch}h1{font-size:36px}.tool-grid{grid-template-columns:1fr}.home-title-row{flex-direction:column;align-items:flex-start}.home-tool-grid{grid-template-columns:1fr}.home-tool-card{min-height:124px}.subnet-layout,.ip-converter-layout,.converter-grid,.base-input-row,.base-result-grid,.text-count-grid,.text-option-grid{grid-template-columns:1fr}.ip-entry{grid-template-columns:repeat(2,minmax(0,1fr))}.cidr-separator{justify-content:center;align-items:center;min-height:24px}.prefix-field{grid-column:span 1}.subnet-result-grid,.ip-result-grid,.unit-select-grid{grid-template-columns:1fr}.tool-panel{padding:18px}.swap-mark{margin:0;transform:rotate(90deg)}.panel-heading button,.secondary-action{width:100%}}.dark{--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(20.5% 0 0);--card-foreground:oklch(98.5% 0 0);--popover:oklch(20.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--primary:oklch(92.2% 0 0);--primary-foreground:oklch(20.5% 0 0);--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--destructive:oklch(70.4% .191 22.216);--border:oklch(100% 0 0/.1);--input:oklch(100% 0 0/.15);--ring:oklch(55.6% 0 0);--chart-1:oklch(87% 0 0);--chart-2:oklch(55.6% 0 0);--chart-3:oklch(43.9% 0 0);--chart-4:oklch(37.1% 0 0);--chart-5:oklch(26.9% 0 0);--sidebar:oklch(20.5% 0 0);--sidebar-foreground:oklch(98.5% 0 0);--sidebar-primary:oklch(48.8% .243 264.376);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(26.9% 0 0);--sidebar-accent-foreground:oklch(98.5% 0 0);--sidebar-border:oklch(100% 0 0/.1);--sidebar-ring:oklch(55.6% 0 0)}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@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-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}
