@charset "UTF-8";@font-face{font-family:IBM Plex Sans;src:url(/fonts/IBMPlexSans-Light.woff2) format("woff2");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Sans;src:url(/fonts/IBMPlexSans-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Sans;src:url(/fonts/IBMPlexSans-Medium.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Sans;src:url(/fonts/IBMPlexSans-SemiBold.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Sans;src:url(/fonts/IBMPlexSans-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Mono;src:url(/fonts/IBMPlexMono-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Mono;src:url(/fonts/IBMPlexMono-Medium.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Mono;src:url(/fonts/IBMPlexMono-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Outfit;src:url(/fonts/Outfit-VariableFont_wght.ttf) format("truetype");font-weight:300 900;font-style:normal;font-display:swap}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{min-height:100vh;text-rendering:optimizeSpeed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}a{text-decoration:none;color:inherit}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}table{border-collapse:collapse}:root,[data-theme=dark]{--bg: #0B0D0F;--bg-alt: #101316;--surface: #161A1E;--surface-hover: #1C2026;--border: #252A30;--border-light: #313840;--text: #EDEEF0;--text-muted: #9CA3AF;--text-dim: #6B7280;--brand: #38BDF8;--brand-light: #7DD3FC;--brand-dark: #0284C7;--accent: #7DD3FC;--forge: #0284C7;--gradient: linear-gradient(135deg, #38BDF8, #0284C7);--shadow-glow: 0 0 30px rgba(56, 189, 248, .08);--code-bg: #161A1E;--glass-bg: rgba(0, 0, 0, .55);--glass-bg-hover: rgba(0, 0, 0, .75);--glass-border: rgba(255, 255, 255, .14)}[data-theme=light]{--bg: #F3F4F6;--bg-alt: #E5E7EB;--surface: #FFFFFF;--surface-hover: #F9FAFB;--border: #D1D5DB;--border-light: #D1D5DB;--text: #111827;--text-muted: #374151;--text-dim: #6B7280;--brand: #0284C7;--brand-light: #38BDF8;--brand-dark: #0369A1;--accent: #7DD3FC;--forge: #0369A1;--gradient: linear-gradient(135deg, #0284C7, #0369A1);--shadow-glow: 0 0 20px rgba($brand-primary, .08);--code-bg: #EFF6F1;--glass-bg: rgba(255, 255, 255, .75);--glass-bg-hover: rgba(255, 255, 255, .95);--glass-border: rgba(0, 0, 0, .15)}.circuit-bg{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}html{background:var(--bg)}body{font-family:IBM Plex Sans,Geist,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1.125rem;font-weight:400;line-height:1.65;color:var(--text);background:transparent;transition:color .4s ease;-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column}main{width:100%;max-width:1200px;margin-inline:auto;background:#101316f5;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border-left:1px solid var(--border);border-right:1px solid var(--border);box-shadow:-15px 0 50px #00000040,15px 0 50px #00000040;position:relative;z-index:1;flex:1;display:flex;flex-direction:column}[data-theme=light] main{background:#f3f4f6f5;box-shadow:-15px 0 50px #0000001a,15px 0 50px #0000001a}@media(max-width:1200px){main{border-left:none;border-right:none}}h1,h2,h3,h4,h5,h6{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-weight:700;line-height:1.1;color:var(--text);margin-bottom:.75em;letter-spacing:-.025em}h1{font-size:3.25rem;font-weight:700}h2{font-size:2.5rem;font-weight:700}h3{font-size:2rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1.125rem}@media(max-width:768px){h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}}p{margin-bottom:1.25rem;color:var(--text-muted);line-height:1.65}a{color:var(--brand);transition:color .15s ease}a:hover{color:var(--brand-light)}strong{font-weight:600;color:var(--text)}code,pre{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace}code{font-size:.875em;padding:.15em .4em;border-radius:2px;background:var(--code-bg);color:var(--brand)}pre{padding:1.75rem;border-radius:4px;background:var(--code-bg);border:1px solid var(--border);overflow-x:auto;line-height:1.7}pre code{padding:0;background:none;color:inherit}.giallo-l{display:inline-block;min-height:1lh;width:100%}.giallo-ln{display:inline-block;user-select:none;margin-right:.4em;padding:0 .4em;min-width:3ch;text-align:right;opacity:.4}::selection{background:#38bdf840;color:var(--text)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:9999px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}hr{border:none;height:1px;background:var(--border);margin:3rem 0}ul,ol{color:var(--text-muted);line-height:1.65;margin-bottom:1.25rem;padding-left:1.5rem}li{margin-bottom:.5rem}blockquote{border-left:2px solid var(--brand);padding-left:1.5rem;margin:2rem 0;font-style:italic;color:var(--text-muted);font-size:1.125rem}.container{width:100%;margin-inline:auto;padding-inline:1.5rem}@media(min-width:1200px){.container{padding-inline:2rem}}.container-narrow{max-width:780px}.section{padding:2.5rem 0}@media(max-width:768px){.section{padding:1.5rem 0}}.section-alt{background:var(--surface)}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:992px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.gap-4{gap:2rem}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}.text-brand{color:var(--brand)}.text-gradient{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;padding-right:.06em;margin-right:-.06em}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2.5rem}.mt-6{margin-top:4rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2.5rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hidden{display:none}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.6rem;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-weight:600;font-size:1.125rem;border-radius:2px;border:1px solid transparent;cursor:pointer;transition:all .25s ease;white-space:nowrap;text-decoration:none;letter-spacing:.02em;text-transform:none}.btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.btn-primary{background:transparent;color:var(--brand);border-color:var(--brand);font-weight:700}.btn-primary:hover{background:var(--brand);color:var(--bg);transform:translateY(-1px);box-shadow:0 4px 20px #38bdf84d}.btn-outline{background:transparent;color:var(--text);border-color:var(--border-light)}.btn-outline:hover{border-color:var(--brand);color:var(--brand)}.btn-ghost{background:transparent;color:var(--brand);border-color:transparent;padding:.5rem 1rem;text-transform:none}.btn-ghost:hover{background:#38bdf80f}.btn-lg{padding:.95rem 2rem;font-size:1.125rem}.btn-md{padding:.85rem 1.6rem;font-size:1.125rem}.btn-sm{padding:.65rem 1.25rem;font-size:.875rem}.card{background:#161a1e99;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:4px;padding:2rem;transition:border-color .25s ease,box-shadow .25s ease}[data-theme=light] .card{background:#ffffffb3}.card:hover{border-color:#38bdf826;box-shadow:inset 0 0 20px #38bdf80a}.card h3,.card h4{margin-bottom:.5rem}.card p:last-child{margin-bottom:0}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;padding:2.5rem;background:var(--surface);border:1px solid var(--border);border-radius:4px}.stat-item{text-align:center}.stat-value{font-size:2.5rem;font-weight:700;color:var(--brand);line-height:1;margin-bottom:.25rem;letter-spacing:-.02em}.stat-label{font-size:.8125rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.feature-list{display:flex;flex-direction:column;gap:1.75rem}.feature-item{display:flex;gap:1rem;align-items:flex-start}.feature-dot{width:6px;height:6px;border-radius:0;background:var(--brand);margin-top:.6rem;flex-shrink:0}.feature-title{font-weight:600;color:var(--text);margin-bottom:.25rem;font-size:.875rem;letter-spacing:.01em}.feature-desc{font-size:1.125rem;color:var(--text-muted);margin-bottom:0}.code-block{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:2.75rem 1.5rem 1.75rem;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.8125rem;line-height:1.85;color:var(--text-muted);overflow-x:auto;position:relative}[data-theme=light] .code-block{border-color:#0f172a1f;box-shadow:0 1px 1px #0f172a0f}.code-block .code-window{position:absolute;top:0;left:0;right:0;height:2.4rem;display:flex;align-items:center;gap:.5rem;padding:0 1rem;border-radius:4px 4px 0 0;background:#ffffff14;border-bottom:1px solid rgba(255,255,255,.14);pointer-events:none}[data-theme=light] .code-block .code-window{background:#0f172a0a;border-bottom:1px solid rgba(15,23,42,.08)}.code-block .code-window-dot{width:.65rem;height:.65rem;border-radius:50%;background:#f87171}.code-block .code-window-dot:nth-child(2){background:#fbbf24}.code-block .code-window-dot:nth-child(3){background:#34d399}.code-block .code-block-content{margin-top:0}.code-block .code-comment{color:var(--text-dim);font-style:italic}.code-block .code-keyword{color:#c792ea}.code-block .code-type{color:var(--accent)}.code-block .code-func{color:#82aaff}.code-block .code-string{color:#c3e88d}.code-block .code-number{color:#f78c6c}.code-block .code-op{color:#89ddff}.code-block .code-plain{color:var(--text)}[data-theme=light] .code-block .code-keyword{color:#7c4dff}[data-theme=light] .code-block .code-func{color:#1565c0}[data-theme=light] .code-block .code-string{color:#2e7d32}[data-theme=light] .code-block .code-number{color:#c62828}[data-theme=light] .code-block .code-op{color:#00838f}.section-header{text-align:center;max-width:640px;margin:0 auto 4rem}.section-header h1,.section-header h2{margin-bottom:1.25rem}.section-header p{font-size:1.125rem}.tech-stack{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.8125rem;padding:.375rem .75rem;border:1px solid var(--border);border-radius:2px;color:var(--text-muted);background:var(--surface);transition:border-color .15s ease,color .15s ease}.tech-tag:hover{border-color:var(--brand);color:var(--brand)}.back-link{display:inline-block;font-size:.875rem;color:var(--text-dim);text-decoration:none;margin-bottom:2rem;letter-spacing:.02em;text-transform:uppercase;transition:color .15s ease}.back-link:hover{color:var(--brand)}.trust-bar{padding:3rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center}.trust-label{font-size:.8125rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1.5rem}.trust-logos{display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap;margin-bottom:1.5rem}.trust-logo{font-size:1.125rem;font-weight:600;color:var(--text-dim);opacity:.5;letter-spacing:.04em;text-transform:uppercase;padding:.5rem 1rem;border:1px solid var(--border);border-radius:2px}.trust-badges{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}.trust-badge{font-size:.8125rem;color:var(--brand);font-weight:500;letter-spacing:.03em}.nav{position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:1200px;z-index:200;background:transparent;border-bottom:1px solid var(--border);border-left:1px solid var(--border);border-right:1px solid var(--border);transition:background .25s ease}@media(max-width:1200px){.nav{border-left:none;border-right:none}}.nav.scrolled{background:#0b0d0feb;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(20px)}[data-theme=light] .nav.scrolled{background:#f3f4f6eb}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;padding-bottom:.75rem}.nav-left{display:flex;align-items:center;gap:.5rem}.nav-logo{display:flex;align-items:center;text-decoration:none;--logo-height: calc(2.175rem + 2px) }.nav-logo img{height:var(--logo-height);width:auto}.nav-logo .logo-dark{display:none}@media(max-width:576px){.nav-logo img{height:28px}}[data-theme=dark] .nav-logo .logo-light{display:none}[data-theme=dark] .nav-logo .logo-dark{display:block}.nav-links{display:flex;align-items:center;gap:0}@media(max-width:992px){.nav-links{display:none;position:fixed;inset:0;background:var(--bg);flex-direction:column;justify-content:center;gap:2rem;z-index:300;font-size:1.25rem}.nav-links.open{display:flex}}.nav-link{color:var(--text-dim);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-weight:500;font-size:1.125rem;text-transform:none;letter-spacing:.02em;transition:color .15s ease;text-decoration:none;padding:.5rem .875rem}.nav-link:hover{color:var(--text)}.nav-link.active{color:var(--brand)}.nav-dropdown{position:relative}.nav-dropdown.active>.nav-dropdown-trigger{color:var(--brand)}.nav-dropdown-trigger{display:flex;align-items:center;gap:.3rem;background:none;border:none;cursor:pointer}.nav-dropdown-arrow{transition:transform .15s ease;flex-shrink:0}.nav-dropdown.open .nav-dropdown-arrow{transform:rotate(180deg)}.nav-dropdown-menu{position:absolute;top:calc(100% + .25rem);left:50%;transform:translate(-50%) translateY(4px);min-width:200px;padding:.5rem;background:var(--surface);border:1px solid var(--border);border-radius:3px;box-shadow:0 12px 24px #00000026;z-index:100;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s ease,transform .15s ease,visibility .15s ease;flex-direction:column;display:flex}.nav-dropdown.open .nav-dropdown-menu{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%) translateY(0)}@media(max-width:992px){.nav-dropdown-menu{position:static;transform:none;background:transparent;border:none;box-shadow:none;padding:0;min-width:unset;gap:1rem;align-items:center;opacity:0;max-height:0;overflow:hidden;transition:opacity .25s ease,max-height .25s ease}.nav-dropdown.open .nav-dropdown-menu{opacity:1;max-height:500px;transform:none}}.nav-dropdown-item{display:block;padding:.5rem .75rem;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;font-weight:500;color:var(--text-muted);text-decoration:none;border-radius:2px;transition:color .15s ease,background .15s ease;white-space:nowrap}.nav-dropdown-item:hover{color:var(--text);background:#38bdf80f}.nav-dropdown-item.active{color:var(--brand);background:#38bdf81a}@media(max-width:992px){.nav-dropdown-item{font-size:1.125rem}}.nav-link-ext:after{content:" ↗";font-size:.65em;opacity:.5}.nav-divider{width:1px;height:14px;background:var(--border);margin:0 .375rem}@media(max-width:992px){.nav-divider{display:none}}.nav-actions{display:flex;align-items:center;gap:.75rem}@media(max-width:768px){.nav-cta{display:none}}.lang-switch{display:flex;align-items:center;border:1px solid var(--border);border-radius:2px;overflow:hidden}.lang-option{padding:.25rem .5rem;font-size:.8125rem;font-weight:500;color:var(--text-dim);text-decoration:none;transition:color .15s ease,background .15s ease;letter-spacing:.03em}.lang-option.active{color:var(--brand);background:#38bdf814}.lang-option:hover:not(.active){color:var(--text)}.theme-toggle{background:none;border:1px solid var(--border);border-radius:2px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-dim);transition:color .15s ease,border-color .15s ease}.theme-toggle:hover{color:var(--brand);border-color:var(--brand)}.theme-toggle svg{width:15px;height:15px}.nav-toggle{display:none;background:none;border:1px solid var(--border);border-radius:2px;cursor:pointer;padding:.5rem;width:36px;height:36px;align-items:center;justify-content:center}.nav-toggle svg{width:16px;height:16px;stroke:var(--text);fill:none;stroke-width:2;stroke-linecap:round}@media(max-width:992px){.nav-toggle{display:flex}}.mobile-close{display:none;position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--text);font-size:2rem;cursor:pointer}@media(max-width:992px){.nav-links.open .mobile-close{display:block}}.nav-anchors{display:none;border-top:1px solid var(--border);background:transparent}.nav-anchors.visible{display:block}.nav-anchors-inner{display:flex;align-items:center;gap:.25rem;padding:.375rem 1rem;overflow-x:auto;scrollbar-width:none}.nav-anchors-inner::-webkit-scrollbar{display:none}.anchor-link{flex-shrink:0;font-size:.8125rem;font-weight:500;color:var(--text-dim);text-decoration:none;padding:.25rem .75rem;white-space:nowrap;border-radius:2px;transition:color .15s ease,background .15s ease}.anchor-link:hover{color:var(--text);background:#38bdf80d}.anchor-link.active{color:var(--brand);background:#38bdf824;border:1px solid rgba(56,189,248,.22)}.scroll-top{position:fixed;bottom:2rem;right:2rem;z-index:200;width:40px;height:40px;border-radius:2px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .25s ease,visibility .25s ease,transform .25s ease,color .15s ease,border-color .15s ease}.scroll-top:hover{color:var(--brand);border-color:var(--brand)}.scroll-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.hero{position:relative;display:flex;align-items:center;overflow:hidden;padding-top:6rem;padding-bottom:1.5rem}.hero+.section{padding-top:.25rem}.hero-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.hero-content{position:relative;z-index:1;width:100%;max-width:100%}.hero h1{font-size:3.25rem;font-weight:700;line-height:1.05;margin-bottom:.75rem;letter-spacing:-.035em}@media(max-width:768px){.hero h1{font-size:2rem}}.hero-sub{font-size:1.125rem;color:var(--text-muted);line-height:1.65;margin-bottom:1.25rem;max-width:480px}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}.pillar-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto;gap:1px;background:var(--border);border:1px solid var(--border)}.pillar-grid>:nth-child(1){grid-column:span 2}@media(max-width:992px){.pillar-grid{grid-template-columns:repeat(2,1fr)}.pillar-grid>:nth-child(1){grid-column:span 2}}@media(max-width:768px){.pillar-grid{grid-template-columns:1fr}.pillar-grid>:nth-child(1){grid-column:span 1}}.pillar-card{background:var(--bg);padding:2.5rem;display:flex;flex-direction:column;gap:.75rem;transition:background .25s ease;position:relative}.pillar-card:hover{background:var(--surface)}.pillar-card:hover .pillar-title{color:var(--brand)}.pillar-marker{display:none}.pillar-title{font-size:1.125rem;font-weight:700;transition:color .15s ease;letter-spacing:-.01em}.pillar-desc{color:var(--text-muted);font-size:1.125rem;line-height:1.65;flex-grow:1;margin-bottom:0}.pillar-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:500;font-size:.8125rem;color:var(--text-dim);text-decoration:none;text-transform:uppercase;letter-spacing:.04em;transition:color .15s ease,gap .15s ease}.pillar-link:hover{color:var(--brand);gap:.75rem}.bento-section-title{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;font-weight:700;letter-spacing:.05em;margin-bottom:1rem;color:var(--text-dim);text-transform:uppercase}.bento-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:4px;overflow:hidden}@media(max-width:992px){.bento-grid{grid-template-columns:1fr}}@media(max-width:768px){.bento-grid{grid-template-columns:1fr}}.bento-card{background:var(--bg);text-decoration:none;color:inherit;transition:background .25s ease}.bento-card:hover{background:var(--surface)}.bento-card:hover h3{color:var(--brand)}.bento-card:hover .pillar-link{color:var(--brand);gap:.75rem}.bento-card.bento-card-wide{grid-column:span 2}@media(max-width:768px){.bento-card.bento-card-wide{grid-column:span 1}}.bento-card-inner{padding:1.5rem;display:flex;flex-direction:column;gap:.5rem;height:100%}.bento-card-inner h3{font-size:1.125rem;font-weight:700;transition:color .15s ease;letter-spacing:-.01em;margin-bottom:.15rem}.bento-card-inner p{color:var(--text-muted);font-size:1.125rem;line-height:1.65;flex-grow:1;margin-bottom:.5rem}.bento-card-icon{color:var(--brand);margin-bottom:.5rem}.bento-card-meta{display:flex;gap:.5rem;flex-wrap:wrap}.bento-tag{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.6875rem;color:var(--text-dim);border:1px solid var(--border);border-radius:2px;padding:.15rem .45rem;letter-spacing:.02em}.footer{background:var(--bg-alt);border-top:1px solid var(--border);padding:3rem 0 1.5rem;margin-top:auto}.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto auto;gap:2rem;margin-bottom:2.5rem}.footer-grid .footer-brand{grid-column:1/-1;grid-row:1;padding-bottom:2rem;border-bottom:1px solid var(--border);margin-bottom:1rem}@media(max-width:768px){.footer-grid{grid-template-columns:1fr;grid-template-rows:auto}.footer-grid .footer-brand{grid-column:1;grid-row:auto;padding-bottom:1.5rem;margin-bottom:.5rem}}.footer-brand p{color:var(--text-muted);font-size:.875rem;line-height:1.65;margin-top:.75rem;margin-bottom:.75rem}.eu-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.8125rem;color:var(--text-dim)}.eu-badge svg{color:var(--brand);flex-shrink:0}.footer-col h4{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:1rem}.footer-links{display:flex;flex-direction:column;gap:.5rem}.footer-link{color:var(--text-muted);text-decoration:none;font-size:.875rem;transition:color .15s ease}.footer-link:hover{color:var(--brand)}.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:1.5rem;border-top:1px solid var(--border);font-size:.8125rem;color:var(--text-dim)}@media(max-width:768px){.footer-bottom{flex-direction:column;gap:1rem;text-align:center}}.footer-legal{display:flex;gap:1.5rem;flex-wrap:wrap}.footer-legal a{color:var(--text-dim);text-decoration:none;font-size:.8125rem;transition:color .15s ease}.footer-legal a:hover{color:var(--brand)}@keyframes tool-spinner-rotate{to{transform:rotate(360deg)}}@keyframes tool-spinner-pulse{0%,to{opacity:1}50%{opacity:.4}}.tool-page-section{padding-top:6rem;padding-bottom:3rem}.tool-page-header{margin-bottom:2rem;text-align:center}.tool-page-header h1{font-size:2rem;font-weight:700;line-height:1.1;margin-bottom:.75rem;letter-spacing:-.025em}@media(max-width:768px){.tool-page-header h1{font-size:1.5rem}}.tool-stage{position:relative;width:100%;aspect-ratio:16/9;min-height:300px;max-height:calc(100vh - 280px);margin-inline:auto;border-radius:4px;overflow:hidden;border:2px solid var(--border);background:var(--surface);box-shadow:inset 0 0 20px #38bdf80a;transition:border-color .25s ease,background-color .25s ease}@media(max-width:768px){.tool-stage{min-height:240px;max-height:calc(100vh - 200px)}}.tool-stage:after{content:"Drop to process image...";position:absolute;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#14161ad9;backdrop-filter:blur(8px);color:var(--brand);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:2rem;font-weight:700;pointer-events:none;opacity:0;transition:opacity .25s ease}.tool-stage.dragover{border-color:#38bdf8;border-style:dashed}.tool-stage.dragover:after{opacity:1}.tool-stage-layer{position:absolute;inset:0}.tool-stage-top-center{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:30}.tool-backend-badge{display:inline-flex;align-items:center;padding:.25rem .65rem;border:1px solid rgba(56,189,248,.3);border-radius:9999px;background:var(--glass-bg);backdrop-filter:blur(6px);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;color:var(--brand);cursor:default;letter-spacing:.03em}.tool-toggle{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem;border:1px solid var(--glass-border);border-radius:9999px;background:var(--glass-bg);backdrop-filter:blur(6px)}.tool-toggle-btn{appearance:none;border:1px solid transparent;background:transparent;color:var(--text-dim);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;padding:.35rem .75rem;border-radius:9999px;cursor:pointer;transition:background .25s ease,color .25s ease,border-color .25s ease}.tool-toggle-btn[aria-pressed=true]{color:var(--text);border-color:#38bdf859;background:#38bdf824}.tool-toggle-btn:hover{color:var(--text);border-color:#38bdf840}.tool-toggle-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.tools-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}@media(max-width:768px){.tools-grid{grid-template-columns:1fr}}.tool-card{display:flex;flex-direction:column;gap:1rem;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:2.5rem;text-decoration:none;transition:border-color .25s ease,box-shadow .25s ease}.tool-card:hover{border-color:#38bdf84d;box-shadow:inset 0 0 20px #38bdf80a}.tool-card:hover h2{color:var(--brand)}.tool-card-header{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap}.tool-card-header h2{font-size:1.5rem;margin-bottom:0}.tool-badge{font-size:.8125rem;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;color:var(--text-dim);border:1px solid var(--border);border-radius:2px;padding:.2rem .6rem}.tool-card-desc{color:var(--text-muted);font-size:1.125rem;line-height:1.65;margin-bottom:0;flex-grow:1}.privacy-bar{display:flex;align-items:center;justify-content:center;gap:3rem;padding:2.5rem 2rem;background:var(--surface);border:1px solid var(--border);border-radius:4px;flex-wrap:wrap}@media(max-width:768px){.privacy-bar{gap:2rem;padding:2rem 1.5rem}}.privacy-item{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted);white-space:nowrap}.privacy-item svg{color:var(--brand);flex-shrink:0}.tool-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;margin:0;border:none;cursor:pointer;text-align:center}.tool-dropzone-content{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;padding:2.5rem 2rem;pointer-events:none;position:relative}.tool-dropzone .tool-file-input{pointer-events:none}.tool-dropzone-heading{font-size:2rem;font-weight:700;line-height:1.1;letter-spacing:-.025em;text-align:center;margin:0;padding-top:1rem}@media(max-width:768px){.tool-dropzone-heading{font-size:1.5rem}}.tool-dropzone-action{display:flex;flex-direction:column;align-items:center}.tool-dropzone-icon{width:48px;height:48px;color:var(--text-dim);margin-bottom:1rem;flex:0 0 auto}.tool-dropzone-icon svg{width:100%;height:100%}.tool-dropzone-title{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:.35rem}.tool-dropzone-subtitle{font-size:1.125rem;color:var(--text-dim);max-width:400px;margin:0}.tool-file-input{display:none}.tool-privacy-badge{position:absolute;bottom:2.5rem;display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid var(--border);border-radius:2px;font-size:.8125rem;color:var(--text-dim);background:var(--surface)}.tool-privacy-badge svg{width:14px;height:14px;flex-shrink:0}.tool-processing-overlay{display:none;position:absolute;inset:0;z-index:25;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.tool-processing-box{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 3rem;background:#14161ad9;border:1px solid rgba(255,255,255,.1);border-radius:4px;backdrop-filter:blur(8px);box-shadow:0 8px 32px #00000080;min-width:min(400px,100%)}.tool-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--brand);border-radius:9999px;animation:tool-spinner-rotate .8s linear infinite,tool-spinner-pulse 1.5s ease-in-out infinite;margin-bottom:1.25rem}.tool-status{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--brand);letter-spacing:.02em}.tool-progress{width:100%;height:8px;border-radius:9999px;border:1px solid var(--border);background:#0006;overflow:hidden;margin-top:1rem}.tool-progress-bar{width:0%;height:100%;background:linear-gradient(90deg,#38bdf8,#0284c7);transition:width .2s ease}.tool-result{display:none;flex-direction:column;align-items:center;gap:1.5rem;padding:0}.tool-result-container{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;user-select:none;background-color:var(--surface);background-image:repeating-conic-gradient(var(--border) 0% 25%,transparent 0% 50%);background-size:20px 20px;background-position:center}.tool-result-frame{position:relative;line-height:0}.tool-result-original{display:block;width:100%;height:100%;position:relative;z-index:2;clip-path:inset(0 var(--orig-right, 50%) 0 0)}.tool-result-processed{position:absolute;top:0;left:0;width:100%;height:100%;z-index:3;clip-path:inset(0 0 0 var(--res-left, 50%))}.tool-pills{position:absolute;top:10px;left:10px;right:10px;z-index:5;display:flex;justify-content:space-between;pointer-events:none}.tool-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .75rem;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;color:var(--text);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:9999px;backdrop-filter:blur(6px)}.tool-result-frame>.tool-slider-line{position:absolute;top:0;bottom:0;width:2px;background:#fff;z-index:4;left:50%;transform:translate(-50%);pointer-events:none;box-shadow:0 0 4px #0000004d}.tool-icon-btn{position:absolute;z-index:26;display:none;align-items:center;justify-content:center;gap:.4rem;padding:.5rem .75rem;border-radius:9999px;border:2px solid rgba(56,189,248,.5);background:var(--glass-bg);color:var(--text);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;cursor:pointer;backdrop-filter:blur(6px);transition:background .25s ease,border-color .25s ease,color .25s ease,transform .25s ease}.tool-icon-btn svg{flex-shrink:0}.tool-icon-btn:hover{background:var(--glass-bg-hover);border-color:#38bdf8;color:var(--brand);transform:translateY(-1px)}.tool-icon-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.tool-new-btn{left:12px;bottom:12px}.tool-save-fab{right:12px;bottom:12px}.tool-undo-btn{left:12px;bottom:56px}.tool-reset-btn{left:12px;bottom:100px}.tool-save-img-btn{right:12px;bottom:12px}.tool-save-mask-btn{right:12px;bottom:56px}.tool-save-pts-btn{right:12px;bottom:100px}.tool-segment-canvas{display:block;width:100%;height:100%;object-fit:contain;cursor:crosshair;background-color:var(--surface);background-image:repeating-conic-gradient(var(--border) 0% 25%,transparent 0% 50%);background-size:20px 20px}.tool-segment-hints{position:absolute;bottom:10px;left:50%;transform:translate(-50%);z-index:5;display:flex;gap:.75rem;pointer-events:none}.tool-hint{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .65rem;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;color:var(--text);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:9999px;backdrop-filter:blur(6px);opacity:.85}.tool-hint:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%}.tool-hint-fg:before{background:#38bdf8d9}.tool-hint-bg:before{background:#f87171d9}.tool-state-idle .tool-dropzone{display:flex}.tool-state-idle .tool-result,.tool-state-idle .tool-processing-overlay,.tool-state-idle .tool-icon-btn,.tool-state-idle .tool-pills,.tool-state-processing .tool-dropzone{display:none}.tool-state-processing .tool-result,.tool-state-processing .tool-processing-overlay{display:flex}.tool-state-processing .tool-icon-btn,.tool-state-processing .tool-pills,.tool-state-result .tool-dropzone{display:none}.tool-state-result .tool-result{display:flex}.tool-state-result .tool-processing-overlay{display:none}.tool-state-result .tool-icon-btn{display:inline-flex}.tool-state-result .tool-pills{display:flex}.tool-layout,.tool-layout-column,.rx-layout,.hash-layout,.uuid-layout,.tool-layout-grid,.md-layout,.qr-layout,.rxrev-layout,.noise-layout,.led-layout,.rc-layout,.vd-layout{background:var(--border);border:1px solid var(--border);border-radius:4px;overflow:hidden;width:100%;margin-inline:auto}.tool-layout-grid,.md-layout,.qr-layout,.rxrev-layout,.noise-layout,.led-layout,.rc-layout,.vd-layout{display:grid;gap:1px}.tool-layout-column,.rx-layout,.hash-layout,.uuid-layout{display:flex;flex-direction:column;gap:1px}.vd-layout{grid-template-columns:240px 1fr 240px}@media(max-width:992px){.vd-layout{grid-template-columns:1fr 1fr}.vd-layout .vd-schematic-panel{grid-column:span 2}}@media(max-width:768px){.vd-layout{grid-template-columns:1fr}.vd-layout .vd-schematic-panel{grid-column:span 1}}.vd-panel{background:var(--bg);padding:1.75rem}.vd-inputs{display:flex;flex-direction:column;gap:1rem}.vd-field{display:flex;flex-direction:column;gap:.3rem;transition:opacity .25s ease}.vd-field label{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-bottom:0}.vd-field.vd-field-disabled{opacity:.3;pointer-events:none}.vd-e-chips{display:flex;gap:.35rem;flex-wrap:wrap;padding-top:.25rem}.vd-e-chip{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.7rem;padding:.15rem .45rem;border:1px solid var(--border);border-radius:2px;color:var(--text-dim);background:var(--surface);cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease;white-space:nowrap}.vd-e-chip:hover{border-color:var(--brand);color:var(--brand)}.vd-input-wrap{display:flex;align-items:center;border:1px solid var(--border);border-radius:2px;background:var(--surface);transition:border-color .15s ease;overflow:hidden}.vd-input-wrap:focus-within{border-color:var(--brand)}.vd-input-wrap input{flex:1;background:transparent;border:none;color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:1.125rem;padding:.5rem .6rem;outline:none;min-width:0}.vd-unit{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.875rem;color:var(--text-dim);padding:0 .6rem;flex-shrink:0;border-left:1px solid var(--border);background:var(--bg-alt);align-self:stretch;display:flex;align-items:center}.vd-load-toggle{padding-top:.25rem}.vd-checkbox-label{display:inline-flex;align-items:center;gap:.5rem;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:1.125rem;color:var(--text-muted);cursor:pointer;margin-bottom:0}.vd-checkbox-label input[type=checkbox]{accent-color:var(--brand);width:16px;height:16px;cursor:pointer}.vd-error{font-size:.8125rem;color:#f87171;padding:.5rem 0}.vd-schematic-panel{display:flex;align-items:center;justify-content:center;min-height:280px;padding:1rem}.vd-schematic-panel svg{width:100%;max-width:340px;height:auto}.vd-results{display:flex;align-items:flex-start;padding-top:1.5rem}.vd-result-table{width:100%;border-collapse:collapse}.vd-result-table tr+tr td{padding-top:.6rem}.vd-result-label{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;padding-right:1rem;vertical-align:baseline}.vd-result-value{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:1.125rem;color:var(--brand);font-weight:500;text-align:right;vertical-align:baseline}.vd-row-disabled{opacity:.3}.vd-row-disabled td{color:var(--text-dim)!important}.vd-footer-note{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-top:1.5rem;font-size:.8125rem;color:var(--text-dim)}.vd-footer-note svg{color:var(--text-dim);flex-shrink:0}.rc-layout{grid-template-columns:280px 1fr}@media(max-width:768px){.rc-layout{grid-template-columns:1fr}}.rc-panel{background:var(--bg);padding:1.75rem}.rc-sidebar{display:flex;flex-direction:column;gap:1rem}.rc-divider{border-top:1px solid var(--border);margin:.25rem 0}.rc-chart-panel{display:flex;align-items:stretch;min-height:380px}.rc-chart-panel canvas{width:100%;height:100%;display:block}.pixelize-result-canvas{display:block;width:100%;height:100%;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}.pixelize-block-control{display:none;position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:26;align-items:center;gap:.65rem;padding:.5rem 1rem;border-radius:9999px;border:1px solid rgba(56,189,248,.5);background:#0b0d0fe0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}[data-theme=light] .pixelize-block-control{background:#ffffffeb}.pixelize-block-label{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;color:var(--text-muted);white-space:nowrap}.pixelize-block-value{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.8125rem;color:var(--brand);min-width:2.5rem;text-align:center;white-space:nowrap}.pixelize-block-slider{-webkit-appearance:none;appearance:none;width:120px;height:4px;border-radius:9999px;background:var(--border);outline:none;cursor:pointer}.pixelize-block-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--brand);border:2px solid var(--surface);cursor:pointer;box-shadow:0 0 4px #38bdf866}.pixelize-block-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--brand);border:2px solid var(--surface);cursor:pointer;box-shadow:0 0 4px #38bdf866}.tool-state-result .pixelize-block-control{display:flex}.pixelize-preview{display:none;position:absolute;top:12px;right:12px;z-index:26;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;border:1px solid rgba(56,189,248,.3);border-radius:2px;background-color:#1a1a1a;background-image:linear-gradient(45deg,#333 25%,transparent 25%,transparent 75%,#333 75%),linear-gradient(45deg,#333 25%,transparent 25%,transparent 75%,#333 75%);background-size:8px 8px;background-position:0 0,4px 4px;box-shadow:0 4px 16px #0006}[data-theme=light] .pixelize-preview{background-color:#e8e8e8;background-image:linear-gradient(45deg,#ccc 25%,transparent 25%,transparent 75%,#ccc 75%),linear-gradient(45deg,#ccc 25%,transparent 25%,transparent 75%,#ccc 75%)}.tool-state-result .pixelize-preview{display:block}.palletize-result-canvas{display:block;width:100%;height:100%}.palletize-controls{display:none;position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:25;flex-direction:column;align-items:center;gap:.4rem;padding:.5rem .85rem .55rem;border-radius:4px;border:1px solid rgba(56,189,248,.5);background:#0b0d0fe0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);max-width:calc(100% - 24px)}[data-theme=light] .palletize-controls{background:#ffffffeb}.tool-state-result .palletize-controls{display:flex}.palletize-controls-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}.palletize-chips-row{display:flex;align-items:center;justify-content:center;min-height:28px}.palletize-chips{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap;justify-content:center}.palletize-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border:1px solid var(--border);border-radius:9999px;background:transparent;color:var(--text-dim);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease;white-space:nowrap;line-height:1.4}.palletize-chip:hover{border-color:#38bdf866;color:var(--text-muted)}.palletize-chip.active{border-color:#38bdf899;background:#38bdf81f;color:var(--text)}.palletize-chip-dots{display:inline-flex;gap:2px}.palletize-chip-dots i{width:7px;height:7px;border-radius:50%;display:block;border:1px solid rgba(255,255,255,.08)}[data-theme=light] .palletize-chip-dots i{border-color:#00000014}.palletize-dither{display:flex;align-items:center;gap:.4rem}.palletize-dither-toggle{display:inline-flex;align-items:center;gap:.3rem;cursor:pointer;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;color:var(--text-muted);user-select:none}.palletize-dither-toggle input[type=checkbox]{accent-color:#38BDF8;width:14px;height:14px;cursor:pointer;margin:0}.palletize-control-value{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.8125rem;color:var(--brand);min-width:2rem;text-align:center;white-space:nowrap}.palletize-slider{-webkit-appearance:none;appearance:none;width:80px;height:4px;border-radius:9999px;background:var(--border);outline:none;cursor:pointer;transition:opacity .15s ease}.palletize-slider:disabled{opacity:.3;cursor:not-allowed}.palletize-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--brand);border:2px solid var(--surface);cursor:pointer;box-shadow:0 0 4px #38bdf866}.palletize-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--brand);border:2px solid var(--surface);cursor:pointer;box-shadow:0 0 4px #38bdf866}.palletize-swatches{display:none;position:absolute;top:12px;right:12px;z-index:26;gap:3px;padding:5px;border-radius:2px;border:1px solid rgba(56,189,248,.3);background:#0b0d0fe0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 16px #0006}[data-theme=light] .palletize-swatches{background:#ffffffeb}.tool-state-result .palletize-swatches{display:flex}.palletize-swatch{width:16px;height:16px;border-radius:2px;border:1px solid rgba(255,255,255,.1)}[data-theme=light] .palletize-swatch{border-color:#0000001a}.face-detect-canvas{display:block;width:100%;height:100%;object-fit:contain}.face-detect-controls{display:none;position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:25;flex-direction:column;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:4px;border:1px solid rgba(56,189,248,.5);background:#0b0d0fe0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);max-width:calc(100% - 24px)}[data-theme=light] .face-detect-controls{background:#ffffffeb}.tool-state-result .face-detect-controls{display:flex}.face-detect-count{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.8125rem;color:var(--brand);white-space:nowrap}.face-detect-toggles{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:center}.face-detect-toggle{display:inline-flex;align-items:center;gap:.3rem;cursor:pointer;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;color:var(--text-muted);user-select:none;white-space:nowrap}.face-detect-toggle input[type=checkbox]{accent-color:#38BDF8;width:14px;height:14px;cursor:pointer;margin:0}.face-detect-threshold{display:flex;align-items:center;gap:.4rem;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8125rem;color:var(--text-muted)}.face-detect-threshold label{white-space:nowrap}.face-detect-threshold input[type=range]{-webkit-appearance:none;appearance:none;width:80px;height:4px;border-radius:9999px;background:var(--border);outline:none;cursor:pointer}.face-detect-threshold input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--brand);border:2px solid var(--surface);cursor:pointer;box-shadow:0 0 4px #38bdf866}.face-detect-threshold input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--brand);border:2px solid var(--surface);cursor:pointer;box-shadow:0 0 4px #38bdf866}.face-detect-threshold span{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;color:var(--brand);min-width:2.2rem;text-align:center}.tool-save-faces-btn{right:12px;bottom:56px;z-index:30;display:none}.tool-state-result .tool-save-faces-btn{display:inline-flex}.uuid-controls{display:flex;flex-direction:column;gap:1rem;background:var(--bg);padding:1.75rem}.uuid-version-row{display:flex;gap:.5rem}.uuid-version-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem 1rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-muted);cursor:pointer;transition:all .15s ease;font-size:.9rem}.uuid-version-btn input{display:none}.uuid-version-btn.active{border-color:#38bdf8;color:#38bdf8;background:#38bdf814}.uuid-version-btn small{opacity:.6;font-size:.78rem}.uuid-count-row{display:flex;align-items:center;gap:.75rem}.uuid-count-row label{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.uuid-count-row input[type=number]{width:80px;padding:.45rem .6rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.85rem}.uuid-gen-btn{margin-left:auto;padding:.5rem 1.25rem;border:none;border-radius:6px;background:#38bdf8;color:#fff;font-weight:600;cursor:pointer;transition:background .15s ease}.uuid-gen-btn:hover{background:#0284c7}.uuid-format-row{display:flex;gap:1rem;flex-wrap:wrap}.uuid-check{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text-muted);cursor:pointer}.uuid-check input{accent-color:#38BDF8}.uuid-output-wrap{background:var(--bg);padding:1.75rem}.uuid-output-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.uuid-output-count{font-size:.8rem;color:var(--text-dim)}.uuid-copy-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .7rem;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:border-color .15s ease}.uuid-copy-btn:hover{border-color:#38bdf8;color:#38bdf8}.uuid-output{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;resize:vertical;line-height:1.6}.uuid-decode-section{background:var(--bg);padding:1.75rem}.uuid-decode-section h3{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:1rem;margin-bottom:.75rem;color:var(--text)}.uuid-decode-input-row input{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.85rem;margin-bottom:.75rem}.uuid-decode-table{width:100%;border-collapse:collapse}.uuid-decode-label{padding:.35rem 0;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;width:120px}.uuid-decode-value{padding:.35rem 0;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.85rem;color:var(--text)}.led-layout{grid-template-columns:240px 1fr 240px}@media(max-width:992px){.led-layout{grid-template-columns:1fr 1fr}.led-layout .led-schematic-panel{grid-column:span 2;max-width:none}}@media(max-width:768px){.led-layout{grid-template-columns:1fr}.led-layout .led-schematic-panel{grid-column:span 1}}.led-panel{background:var(--bg);padding:1.75rem}.led-inputs{display:flex;flex-direction:column;gap:1rem}.led-field{display:flex;flex-direction:column;gap:.3rem}.led-field label{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-bottom:0}.led-input-wrap{display:flex;align-items:center;border:1px solid var(--border);border-radius:6px;overflow:hidden}.led-input-wrap input{flex:1;padding:.5rem .75rem;border:none;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.85rem;outline:none}.led-input-wrap .led-unit{padding:.5rem .6rem;background:var(--surface);color:var(--text-dim);font-size:.8rem;border-left:1px solid var(--border)}.led-presets{display:flex;gap:.35rem;margin-top:.4rem;flex-wrap:wrap}.led-preset{padding:.25rem .6rem;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all .15s ease}.led-preset:hover,.led-preset.active{border-color:#38bdf8;color:#38bdf8}.led-schematic-panel{display:flex;align-items:center;justify-content:center;min-width:160px}.led-schematic-panel svg{width:100%;max-width:200px;height:auto}.led-result-table{width:100%;border-collapse:collapse}.led-result-label{padding:.4rem 0;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.led-result-value{padding:.4rem 0;text-align:right;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.85rem;color:var(--text)}.led-error{padding:.5rem .75rem;border-radius:6px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:.82rem}.led-warning{padding:.5rem .75rem;border-radius:6px;background:#fbbf241a;border:1px solid rgba(251,191,36,.3);color:#fbbf24;font-size:.82rem;line-height:1.5}.led-suggest-btn{display:inline;padding:.15rem .5rem;border:1px solid rgba(251,191,36,.4);border-radius:3px;background:#fbbf2426;color:#fbbf24;font-size:.78rem;cursor:pointer;transition:background .15s ease}.led-suggest-btn:hover{background:#fbbf2440}.noise-layout{grid-template-columns:300px 1fr}@media(max-width:768px){.noise-layout{grid-template-columns:1fr}}.noise-controls{display:flex;flex-direction:column;gap:1rem;background:var(--bg);padding:1.75rem}.noise-field label{display:block;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.3rem}.noise-field select,.noise-field input[type=number]{width:100%;padding:.45rem .6rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:.85rem}.noise-field input[type=range]{width:100%;accent-color:#38BDF8}.noise-val{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.8rem;color:#38bdf8}.noise-type-row{display:flex;gap:.5rem}.noise-type-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:.45rem .5rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-muted);cursor:pointer;transition:all .15s ease;font-size:.8rem;white-space:nowrap}.noise-type-btn input{display:none}.noise-type-btn.active{border-color:#38bdf8;color:#38bdf8;background:#38bdf814}.noise-seed-row{display:flex;gap:.5rem}.noise-seed-row input{flex:1}.noise-small-btn{padding:.4rem .6rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;font-size:.9rem;transition:border-color .15s ease}.noise-small-btn:hover{border-color:#38bdf8}.noise-color-row{display:flex;gap:1rem}.noise-check{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text-muted);cursor:pointer}.noise-check input{accent-color:#38BDF8}.noise-actions{display:flex;gap:.75rem}.noise-dl-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;flex:1;padding:.55rem 1rem;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;font-size:.85rem;transition:border-color .15s ease,color .15s ease}.noise-dl-btn svg{flex-shrink:0}.noise-dl-btn:hover{border-color:#38bdf8;color:#38bdf8}.noise-dl-btn:disabled{opacity:.4;cursor:default;pointer-events:none}.noise-preview{display:flex;align-items:center;justify-content:center;background:var(--bg);padding:1.75rem}.noise-preview canvas{max-width:100%;height:auto;border:1px solid var(--border);border-radius:4px;image-rendering:pixelated}.hash-input-section{background:var(--bg);padding:1.75rem}.hash-tabs{display:flex;gap:0;margin-bottom:1rem;border:1px solid var(--border);border-radius:6px;overflow:hidden;width:fit-content}.hash-tab{padding:.4rem 1rem;border:none;background:var(--surface);color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .15s ease}.hash-tab.active{background:#38bdf8;color:#fff}.hash-tab-content{display:none}.hash-tab-content.active{display:block}.hash-tab-content textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;resize:vertical;line-height:1.6}.hash-file-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;border:2px dashed var(--border);border-radius:6px;padding:2rem;text-align:center;color:var(--text-muted);cursor:pointer;transition:border-color .15s ease,background .15s ease}.hash-file-drop:hover{border-color:#38bdf8;background:#38bdf80a}.hash-file-drop.drag-active{border-color:#38bdf8;background:#38bdf80f}.hash-file-drop span{font-size:.85rem}.hash-file-drop svg{opacity:.5}.hash-file-name{display:block;margin-top:.5rem;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.8rem;color:var(--text-dim)}.hash-results-section{background:var(--bg);padding:1.75rem}.hash-format-row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.hash-fmt-btn{padding:.35rem .85rem;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .15s ease}.hash-fmt-btn.active{border-color:#38bdf8;color:#38bdf8;background:#38bdf814}.hash-fmt-btn:hover:not(.active){border-color:var(--text-dim)}.hash-upper-btn{margin-left:auto;padding:.35rem .65rem;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-muted);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s ease}.hash-upper-btn.active{border-color:#38bdf8;color:#38bdf8;background:#38bdf814}.hash-upper-btn:hover:not(.active){border-color:var(--text-dim)}.hash-output-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.hash-output-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.hash-output-row:last-child{border-bottom:none}.hash-output-algo{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;min-width:70px;flex-shrink:0}.hash-output-value{flex:1;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.78rem;color:var(--text);word-break:break-all;background:none}.hash-copy-btn{flex-shrink:0;padding:.25rem .4rem;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-muted);cursor:pointer;transition:border-color .15s ease}.hash-copy-btn:hover{border-color:#38bdf8;color:#38bdf8}.hash-output-empty{padding:1rem 0;text-align:center;color:var(--text-dim);font-size:.85rem}.rx-pattern-section{background:var(--bg);padding:1.75rem}.rx-pattern-row{display:flex;align-items:center;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;background:var(--surface)}.rx-delim{padding:.5rem .4rem;color:#38bdf8;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:1.1rem;font-weight:600;user-select:none}.rx-pattern-row input{border:none;background:transparent;color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.9rem;padding:.5rem .25rem;outline:none}.rx-pattern-row input#rx-pattern{flex:1;min-width:0}.rx-flags-input{width:50px;text-align:center;border-left:1px solid var(--border)!important}.rx-error{margin-top:.5rem;padding:.4rem .75rem;border-radius:6px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.78rem}.rx-input-section{background:var(--bg);padding:1.75rem}.rx-input-section>label{display:block;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}.rx-highlighted-wrap{position:relative;border:1px solid var(--border);border-radius:6px;overflow:hidden}.rx-highlights{position:absolute;inset:0;padding:.75rem;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;line-height:1.6;color:transparent;white-space:pre-wrap;word-wrap:break-word;overflow:auto;pointer-events:none}.rx-mark{background:#38bdf840;color:transparent;border-radius:2px}.rx-input-section textarea{width:100%;padding:.75rem;border:none;background:transparent;color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;resize:vertical;line-height:1.6;position:relative;z-index:1}.rx-replace-section{background:var(--bg);padding:1.75rem}.rx-replace-section>label{display:block;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}.rx-replace-section input{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.85rem}.rx-replace-output{margin-top:.5rem;padding:.5rem .75rem;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;color:var(--text-muted);white-space:pre-wrap;word-break:break-all;min-height:1.5em}.rx-matches-section{background:var(--bg);padding:1.75rem}.rx-matches-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.rx-matches-header span:first-child{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.rx-match-count{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.85rem;color:#38bdf8}.rx-matches-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.rx-no-matches{color:var(--text-dim);font-size:.85rem;text-align:center;padding:1rem 0}.rx-match-item{padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface)}.rx-match-header{font-size:.78rem;color:var(--text-dim);margin-bottom:.25rem}.rx-match-pos{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.72rem;color:var(--text-dim)}.rx-match-full{display:block;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;color:#38bdf8;background:none;margin-bottom:.25rem}.rx-groups{border-top:1px solid var(--border);padding-top:.35rem;margin-top:.25rem}.rx-group{font-size:.78rem;padding:.15rem 0}.rx-group code{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;color:var(--text);background:none}.rx-group-label{color:var(--text-dim);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.72rem}.rx-cheatsheet-section{background:var(--bg);padding:1.75rem}.rx-cheatsheet summary{cursor:pointer;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;user-select:none}.rx-cheatsheet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem;margin-top:1rem}.rx-cheatsheet-grid h4{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.82rem;color:var(--text-muted);margin:0 0 .5rem}.rx-cheatsheet-grid dl{margin:0}.rx-cheatsheet-grid dt{display:inline}.rx-cheatsheet-grid dt code{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.78rem;color:#38bdf8;background:none}.rx-cheatsheet-grid dd{display:inline;margin:0 0 0 .35rem;font-size:.78rem;color:var(--text-dim)}.rx-cheatsheet-grid dd:after{content:"";display:block;margin-bottom:.25rem}.diff-drop-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}@media(max-width:768px){.diff-drop-row{grid-template-columns:1fr}}.diff-drop{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:0;border:2px dashed var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;overflow:hidden;min-height:160px;transition:border-color .15s ease,background .15s ease}.diff-drop .diff-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2.5rem 1rem}.diff-drop .diff-preview-img{display:none;width:100%;height:100%;object-fit:contain;position:absolute;inset:0;background:var(--surface);opacity:.85}.diff-drop svg{opacity:.4}.diff-drop span{font-size:.85rem}.diff-drop:hover{border-color:#38bdf8;background:#38bdf80a}.diff-drop.drag-active{border-color:#38bdf8;background:#38bdf80f}.diff-drop.has-image{border-style:solid;border-color:#38bdf866}.diff-drop.has-image .diff-placeholder{display:none}.diff-drop.has-image .diff-preview-img{display:block}.diff-drop.has-image:hover .diff-preview-img{opacity:1}.diff-toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.diff-mode-row{display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden}.diff-mode-btn{padding:.4rem 1rem;border:none;background:var(--surface);color:var(--text-muted);font-size:.82rem;cursor:pointer;transition:all .15s ease}.diff-mode-btn.active{background:#38bdf8;color:#fff}.diff-info{font-size:.78rem;color:var(--text-dim);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace}.diff-viewport{position:relative;border:1px solid var(--border);border-radius:4px;overflow:hidden;margin:0 auto}.diff-viewport canvas{display:block;width:100%;height:auto}.diff-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.diff-canvas:first-child{position:relative}.diff-placeholder-stage{aspect-ratio:16/9;margin:0 auto;border:2px dashed var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s ease,background .15s ease}.diff-placeholder-stage:hover{border-color:#38bdf8;background:#38bdf80a}.diff-placeholder-content{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--text-muted)}.diff-placeholder-content svg{opacity:.3}.diff-placeholder-content span{font-size:.95rem;font-weight:500}.diff-slider-line{position:absolute;top:0;bottom:0;width:2px;background:#fff;pointer-events:none;z-index:2;box-shadow:0 0 4px #0000004d}.diff-source-ring{position:absolute;border-radius:50%;border:1.5px solid rgba(56,189,248,.55);pointer-events:none;z-index:2;display:none;box-shadow:0 0 0 1px #0003}.diff-lens{position:absolute;width:120px;height:120px;border-radius:50%;pointer-events:none;z-index:3;display:none;overflow:hidden;box-shadow:0 0 0 2px #38bdf8,0 2px 12px #0000004d}.diff-lens-group{position:absolute;display:none;gap:6px;pointer-events:none;z-index:4;background:#000000bf;backdrop-filter:blur(8px);border:1px solid rgba(56,189,248,.3);border-radius:4px;padding:10px 10px 2em;box-shadow:0 4px 20px #00000080}.diff-lens-zoom{position:absolute;top:-10px;right:-10px;padding:.15rem .45rem;background:#38bdf8;color:#fff;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.7rem;font-weight:700;border-radius:9999px;z-index:1}.diff-lens-item{position:relative;display:flex;flex-direction:column;align-items:center}.diff-lens-item canvas{width:120px;height:120px;border-radius:50%;border:1px solid rgba(255,255,255,.2);image-rendering:pixelated}.diff-lens-label{position:absolute;bottom:-18px;left:50%;transform:translate(-50%);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.65rem;color:#ffffffb3;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.diff-side-view{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:768px){.diff-side-view{grid-template-columns:1fr}}.diff-side-panel{position:relative;border-radius:4px;overflow:hidden;box-shadow:inset 0 0 0 1px var(--border);cursor:crosshair}.diff-side-panel canvas{display:block;width:100%;height:auto}.diff-side-label{position:absolute;top:8px;left:8px;padding:.2rem .6rem;background:#0009;color:#fff;border-radius:3px;font-size:.72rem;font-weight:600;z-index:1;pointer-events:none}.exif-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2.5rem 1rem;border:2px dashed var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:border-color .15s ease,background .15s ease;margin-bottom:1.5rem}.exif-drop svg{opacity:.4}.exif-drop span{font-size:.85rem}.exif-drop:hover{border-color:#38bdf8;background:#38bdf80a}.exif-drop.drag-active{border-color:#38bdf8;background:#38bdf80f}.exif-content{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:start}@media(max-width:768px){.exif-content{grid-template-columns:1fr}}.exif-preview-col{text-align:center}.exif-preview-col img{max-width:100%;border-radius:4px;border:1px solid var(--border)}.exif-filename{margin-top:.5rem;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.78rem;color:var(--text-dim);word-break:break-all}.exif-data-col{display:flex;flex-direction:column;gap:1.25rem}.exif-section h3{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin:0 0 .5rem}.exif-table{width:100%;border-collapse:collapse;font-size:.82rem}.exif-table tr{border-bottom:1px solid var(--border)}.exif-table td{padding:.35rem .5rem;vertical-align:top}.exif-key{color:var(--text-muted);white-space:nowrap;width:140px}.exif-val{color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.78rem;word-break:break-all}.exif-raw-section summary{cursor:pointer;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;user-select:none}.exif-raw-section .exif-table{margin-top:.75rem}.rxrev-layout{grid-template-columns:1fr 1fr}@media(max-width:768px){.rxrev-layout{grid-template-columns:1fr}}.rxrev-input-panel,.rxrev-output-panel{background:var(--bg);padding:1.75rem}.rxrev-input-panel label,.rxrev-output-panel label{display:block;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}.rxrev-input-panel textarea,.rxrev-output-panel textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;resize:vertical;line-height:1.6}.rxrev-input-actions{display:flex;gap:.5rem;margin-top:.75rem}.rxrev-test-btn{padding:.4rem .85rem;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-muted);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8rem;cursor:pointer;transition:border-color .15s ease,color .15s ease}.rxrev-test-btn:hover{border-color:#38bdf8;color:#38bdf8}.rxrev-results{display:flex;flex-direction:column;gap:.5rem}.rxrev-result{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface)}.rxrev-result.rxrev-result-na{opacity:.5}.rxrev-name{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;min-width:120px;flex-shrink:0}.rxrev-pattern{flex:1;font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.78rem;color:var(--text);word-break:break-all;background:none}.rxrev-na-pattern{color:var(--text-dim);font-style:italic}.rxrev-copy{flex-shrink:0;padding:.25rem .6rem;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem;transition:border-color .15s ease,color .15s ease}.rxrev-copy:hover{border-color:#38bdf8;color:#38bdf8}.rxrev-empty{color:var(--text-dim);font-size:.85rem;text-align:center;padding:2rem 0}.rxrev-modal{display:none;position:fixed;inset:0;z-index:400;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(4px)}.rxrev-modal-content{background:var(--bg);border:1px solid var(--border);border-radius:4px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto}.rxrev-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.9rem;color:var(--text)}.rxrev-modal-close{background:none;border:none;color:var(--text-dim);font-size:1.25rem;cursor:pointer}.rxrev-modal-body{padding:1.25rem}.rxrev-test-result{padding:.5rem .75rem;border-radius:6px;margin-bottom:1rem;font-size:.85rem}.rxrev-test-result code{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.8rem;background:none}.rxrev-test-result.rxrev-test-pass{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#4ade80}.rxrev-test-result.rxrev-test-fail{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.rxrev-test-lines{display:flex;flex-direction:column;gap:.25rem}.rxrev-test-line{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.78rem;padding:.25rem .5rem;border-radius:3px}.rxrev-test-line.pass{color:#4ade80}.rxrev-test-line.fail{color:#f87171}.qr-layout{grid-template-columns:1fr 1fr}@media(max-width:768px){.qr-layout{grid-template-columns:1fr}}.qr-settings-panel{background:var(--bg);padding:1.75rem;display:flex;flex-direction:column;gap:1rem}.qr-preview-panel{background:var(--bg);padding:1.5rem;display:flex;align-items:center;justify-content:center;min-height:380px}.qr-preview-wrap{position:relative;display:flex;align-items:center;justify-content:center}.qr-preview{display:flex;align-items:center;justify-content:center;width:100%}.qr-copy-fab{position:absolute;bottom:-8px;right:-8px;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;transition:border-color .15s ease,color .15s ease}.qr-copy-fab:hover{border-color:#38bdf8;color:#38bdf8}.qr-toast{position:absolute;bottom:36px;right:-8px;padding:.3rem .7rem;border-radius:9999px;background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.75rem;white-space:nowrap;opacity:0;transform:translateY(4px);transition:opacity .2s ease,transform .2s ease;pointer-events:none}.qr-toast.visible{opacity:1;transform:translateY(0)}.qr-type-group{border:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.35rem}.qr-type-group legend{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;padding:0;margin-bottom:.25rem;width:100%;float:none}.qr-radio{display:inline-flex;cursor:pointer}.qr-radio input{display:none}.qr-radio span{padding:.3rem .7rem;border:1px solid transparent;border-radius:9999px;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.8rem;color:var(--text-muted);transition:all .15s ease}.qr-radio input:checked+span{border-color:#38bdf880;background:#38bdf81f;color:#38bdf8}.qr-radio:hover span{color:var(--text)}.qr-field{display:flex;flex-direction:column;gap:.3rem}.qr-field label{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-bottom:0}.qr-field input[type=text],.qr-field input[type=url],.qr-field input[type=email],.qr-field input[type=tel],.qr-field input[type=number],.qr-field select{padding:.45rem .6rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:.85rem}.qr-field input[type=range]{width:100%;accent-color:#38BDF8}.qr-field textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;resize:vertical;line-height:1.5}.qr-fields{display:flex;flex-direction:column;gap:.75rem}.qr-divider{border-top:1px solid var(--border);margin:.25rem 0}.qr-style-row{display:flex;align-items:center;gap:.75rem}.qr-style-label{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.qr-toggle{position:relative;width:40px;height:22px;border-radius:9999px;border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:background .15s ease,border-color .15s ease;padding:0}.qr-toggle.active{background:#38bdf840;border-color:#38bdf880}.qr-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-dim);transition:transform .15s ease,background .15s ease}.qr-toggle.active .qr-toggle-thumb{transform:translate(18px);background:#38bdf8}.qr-colors{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.qr-color-row{display:flex;align-items:center;gap:.5rem}.qr-color-row input[type=color]{width:36px;height:36px;border:1px solid var(--border);border-radius:3px;padding:2px;cursor:pointer;background:var(--surface);-webkit-appearance:none;appearance:none;color-scheme:dark}.qr-color-row input[type=color]::-webkit-color-swatch-wrapper{padding:1px}.qr-color-row input[type=color]::-webkit-color-swatch{border:none;border-radius:2px}.qr-color-row input[type=color]::-moz-color-swatch{border:none;border-radius:2px}.qr-color-hex{flex:1;padding:.35rem .5rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.78rem;width:80px}.qr-export-row{display:flex;gap:.5rem}.qr-invert-warning{padding:.4rem .75rem;border:1px solid rgba(251,191,36,.3);border-radius:6px;background:#fbbf2414;color:#fbbf24;font-size:.78rem;line-height:1.4}.qr-export-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem 1rem;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-muted);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.82rem;cursor:pointer;transition:border-color .15s ease,color .15s ease}.qr-export-btn svg{flex-shrink:0}.qr-export-btn:hover{border-color:#38bdf8;color:#38bdf8}.qr-preview{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.qr-empty{color:var(--text-dim);font-size:.85rem;text-align:center}.md-layout{grid-template-columns:1fr 1fr}@media(max-width:768px){.md-layout{grid-template-columns:1fr}}.md-panel{background:var(--bg);padding:1.75rem;display:flex;flex-direction:column;gap:.5rem}.md-panel-header{display:flex;justify-content:space-between;align-items:center}.md-panel-header label{font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-bottom:0}.md-header-actions{display:flex;gap:.5rem}.md-copy-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .6rem;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:border-color .15s ease,color .15s ease;white-space:nowrap}.md-copy-btn:hover{border-color:#38bdf8;color:#38bdf8}.md-input-panel textarea,.md-md-panel textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;resize:vertical;line-height:1.6;flex:1}.md-rich-input{flex:1;padding:.75rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:.9rem;line-height:1.65;overflow-y:auto;min-height:420px;outline:none}.md-rich-input:focus{border-color:#38bdf8}.md-rich-input:empty:before{content:attr(data-placeholder);color:var(--text-dim);pointer-events:none;font-style:italic}.md-rich-input h1,.md-rich-input h2,.md-rich-input h3,.md-rich-input h4,.md-rich-input h5,.md-rich-input h6{margin:.75em 0 .35em;font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;line-height:1.2}.md-rich-input h1{font-size:1.5rem}.md-rich-input h2{font-size:1.25rem}.md-rich-input h3{font-size:1.1rem}.md-rich-input p{margin:.5em 0}.md-rich-input code{font-family:IBM Plex Mono,Geist Mono,Fira Code,Consolas,monospace;font-size:.82rem;background:var(--bg-alt);padding:.15em .35em;border-radius:2px}.md-rich-input pre{background:var(--bg-alt);padding:.75rem;border-radius:3px;overflow-x:auto;margin:.75em 0}.md-rich-input pre code{background:none;padding:0}.md-rich-input blockquote{border-left:3px solid var(--border);margin:.75em 0;padding:.25em .75em;color:var(--text-muted)}.md-rich-input table{border-collapse:collapse;width:100%;margin:.75em 0}.md-rich-input th,.md-rich-input td{border:1px solid var(--border);padding:.35rem .6rem;text-align:left}.md-rich-input th{background:var(--bg-alt);font-family:Outfit,IBM Plex Sans,-apple-system,sans-serif;font-size:.82rem}.md-rich-input ul,.md-rich-input ol{margin:.5em 0;padding-left:1.5em}.md-rich-input li{margin:.2em 0}.md-rich-input a{color:#38bdf8;text-decoration:underline}.md-rich-input img{max-width:100%;border-radius:3px}.md-rich-input hr{border:none;border-top:1px solid var(--border);margin:1em 0}.md-empty{color:var(--text-dim);font-size:.85rem;text-align:center;padding:2rem 0}.cookie-banner{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:500;background:#161a1ef2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:4px;padding:1rem 1.5rem;display:flex;align-items:center;gap:1.5rem;max-width:560px;width:calc(100% - 2rem);box-shadow:0 24px 48px #0003;font-size:1.125rem}[data-theme=light] .cookie-banner{background:#fffffff2}.cookie-banner.hidden{display:none}@media(max-width:768px){.cookie-banner{flex-direction:column;text-align:center}}.cookie-text{color:var(--text-muted);flex:1}.cookie-text a{color:var(--brand);text-decoration:underline}.cookie-icon{position:fixed;bottom:1.25rem;left:1.25rem;z-index:500;width:36px;height:36px;border-radius:2px;background:var(--surface);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;display:none;align-items:center;justify-content:center;transition:color .15s ease,border-color .15s ease}.cookie-icon:hover{color:var(--brand);border-color:var(--brand)}.cookie-icon.visible{display:flex}.page-404{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:6rem 2rem 2rem}.page-404-content{max-width:600px}.page-404 h1{font-size:8rem;font-weight:700;color:var(--brand);line-height:1;margin-bottom:1rem;letter-spacing:-.05em;opacity:.3}@media(max-width:768px){.page-404 h1{font-size:5rem}}.page-404 p{font-size:1.125rem;margin-bottom:2rem}.puzzle-container{margin:2.5rem 0}.puzzle-label{font-size:.8125rem;color:var(--text-dim);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.04em}#puzzle-canvas{border:1px solid var(--border);border-radius:4px;background:var(--surface);cursor:pointer;display:block;margin:0 auto;max-width:100%}.puzzle-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem}.puzzle-status{font-size:.8125rem;font-weight:600;color:var(--brand);text-transform:uppercase;letter-spacing:.04em}.legal-page h1{margin-bottom:2rem}.legal-page h2{font-size:1.5rem;margin-top:3rem;margin-bottom:1rem}.legal-page h3{font-size:1.25rem;margin-top:2rem;margin-bottom:.75rem}.legal-page ul{list-style:disc;padding-left:1.5rem;margin-bottom:1.5rem}
