/*! 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-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-space-x-reverse:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-500:oklch(63.7% .237 25.331);--color-amber-50:oklch(98.7% .022 95.277);--color-amber-100:oklch(96.2% .059 95.617);--color-amber-700:oklch(55.5% .163 48.998);--color-blue-50:oklch(97% .014 254.604);--color-blue-300:oklch(80.9% .105 251.813);--color-blue-400:oklch(70.7% .165 254.624);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-slate-100:oklch(96.8% .007 247.896);--color-slate-200:oklch(92.9% .013 255.508);--color-slate-300:oklch(86.9% .022 252.894);--color-slate-400:oklch(70.4% .04 256.788);--color-slate-600:oklch(44.6% .043 257.281);--color-slate-700:oklch(37.2% .044 257.287);--color-slate-800:oklch(27.9% .041 260.031);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-lg:32rem;--container-6xl:72rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--leading-tight:1.25;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--animate-spin:spin 1s linear infinite;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-background:#fafaf8;--color-foreground:#1a1917;--color-popover:#fff;--color-popover-foreground:#1a1917;--color-primary:#2e5bff;--color-primary-foreground:#fff;--color-secondary:#f5f4f0;--color-secondary-foreground:#1a1917;--color-muted:#f5f4f0;--color-muted-foreground:#6b6862;--color-accent:#2e5bff;--color-accent-foreground:#fff;--color-destructive:#dc2626;--color-destructive-foreground:#fff;--color-input:#e5e2da;--color-ring:#2e5bff}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-4{top:calc(var(--spacing) * 4)}.top-\[50\%\]{top:50%}.right-3{right:calc(var(--spacing) * 3)}.right-4{right:calc(var(--spacing) * 4)}.bottom-3{bottom:calc(var(--spacing) * 3)}.left-2{left:calc(var(--spacing) * 2)}.left-\[50\%\]{left:50%}.z-50{z-index:50}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mr-1\.5{margin-right:calc(var(--spacing) * 1.5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.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)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-20{height:calc(var(--spacing) * 20)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-px{height:1px}.max-h-96{max-height:calc(var(--spacing) * 96)}.min-h-40{min-height:calc(var(--spacing) * 40)}.min-h-80{min-height:calc(var(--spacing) * 80)}.min-h-screen{min-height:100vh}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-4{width:calc(var(--spacing) * 4)}.w-6{width:calc(var(--spacing) * 6)}.w-7{width:calc(var(--spacing) * 7)}.w-9{width:calc(var(--spacing) * 9)}.w-10{width:calc(var(--spacing) * 10)}.w-20{width:calc(var(--spacing) * 20)}.w-full{width:100%}.max-w-6xl{max-width:var(--container-6xl)}.max-w-lg{max-width:var(--container-lg)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.flex-1{flex:1}.flex-shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.translate-x-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-amber-100{border-color:var(--color-amber-100)}.border-blue-400{border-color:var(--color-blue-400)}.border-input{border-color:var(--color-input)}.border-slate-100{border-color:var(--color-slate-100)}.border-slate-200{border-color:var(--color-slate-200)}.border-transparent{border-color:#0000}.bg-amber-50{background-color:var(--color-amber-50)}.bg-amber-700{background-color:var(--color-amber-700)}.bg-background{background-color:var(--color-background)}.bg-black\/20{background-color:#0003}@supports (color:color-mix(in lab, red, red)){.bg-black\/20{background-color:color-mix(in oklab, var(--color-black) 20%, transparent)}}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab, red, red)){.bg-black\/80{background-color:color-mix(in oklab, var(--color-black) 80%, transparent)}}.bg-blue-50{background-color:var(--color-blue-50)}.bg-blue-50\/20{background-color:#eff6ff33}@supports (color:color-mix(in lab, red, red)){.bg-blue-50\/20{background-color:color-mix(in oklab, var(--color-blue-50) 20%, transparent)}}.bg-blue-600{background-color:var(--color-blue-600)}.bg-destructive{background-color:var(--color-destructive)}.bg-muted{background-color:var(--color-muted)}.bg-popover{background-color:var(--color-popover)}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-secondary)}.bg-slate-100{background-color:var(--color-slate-100)}.bg-white{background-color:var(--color-white)}.p-1{padding:calc(var(--spacing) * 1)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-8{padding-inline:calc(var(--spacing) * 8)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-4{padding-block:calc(var(--spacing) * 4)}.pt-3{padding-top:calc(var(--spacing) * 3)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pl-8{padding-left:calc(var(--spacing) * 8)}.text-center{text-align:center}.font-mono{font-family:var(--font-mono)}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[11px\]{font-size:11px}.leading-none{--tw-leading:1;line-height:1}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.whitespace-nowrap{white-space:nowrap}.text-blue-600{color:var(--color-blue-600)}.text-destructive-foreground{color:var(--color-destructive-foreground)}.text-foreground{color:var(--color-foreground)}.text-muted-foreground{color:var(--color-muted-foreground)}.text-popover-foreground{color:var(--color-popover-foreground)}.text-primary{color:var(--color-primary)}.text-primary-foreground{color:var(--color-primary-foreground)}.text-secondary-foreground{color:var(--color-secondary-foreground)}.text-slate-400{color:var(--color-slate-400)}.text-slate-600{color:var(--color-slate-600)}.text-slate-700{color:var(--color-slate-700)}.text-slate-800{color:var(--color-slate-800)}.text-white{color:var(--color-white)}.text-white\/50{color:#ffffff80}@supports (color:color-mix(in lab, red, red)){.text-white\/50{color:color-mix(in oklab, var(--color-white) 50%, transparent)}}.text-white\/60{color:#fff9}@supports (color:color-mix(in lab, red, red)){.text-white\/60{color:color-mix(in oklab, var(--color-white) 60%, transparent)}}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-offset-background{--tw-ring-offset-color:var(--color-background)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:opacity-70:is(:where(.peer):disabled~*){opacity:.7}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.placeholder\:text-muted-foreground::placeholder{color:var(--color-muted-foreground)}@media (hover:hover){.hover\:border-blue-300:hover{border-color:var(--color-blue-300)}.hover\:border-slate-300:hover{border-color:var(--color-slate-300)}.hover\:bg-accent:hover{background-color:var(--color-accent)}.hover\:bg-blue-50\/40:hover{background-color:#eff6ff66}@supports (color:color-mix(in lab, red, red)){.hover\:bg-blue-50\/40:hover{background-color:color-mix(in oklab, var(--color-blue-50) 40%, transparent)}}.hover\:bg-destructive\/90:hover{background-color:#dc2626e6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab, var(--color-destructive) 90%, transparent)}}.hover\:bg-primary\/90:hover{background-color:#2e5bffe6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab, var(--color-primary) 90%, transparent)}}.hover\:bg-red-50:hover{background-color:var(--color-red-50)}.hover\:bg-secondary\/80:hover{background-color:#f5f4f0cc}@supports (color:color-mix(in lab, red, red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab, var(--color-secondary) 80%, transparent)}}.hover\:bg-slate-100:hover{background-color:var(--color-slate-100)}.hover\:text-accent-foreground:hover{color:var(--color-accent-foreground)}.hover\:text-blue-500:hover{color:var(--color-blue-500)}.hover\:text-red-500:hover{color:var(--color-red-500)}.hover\:text-slate-600:hover{color:var(--color-slate-600)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}}.focus\:bg-accent:focus{background-color:var(--color-accent)}.focus\:text-accent-foreground:focus{color:var(--color-accent-foreground)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--color-ring)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:var(--color-ring)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:var(--color-accent)}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:var(--color-muted-foreground)}@media (width>=40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}:where(.sm\:space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)))}.sm\:text-left{text-align:left}}@media (width>=64rem){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width>=80rem){.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.\[\&\>span\]\:line-clamp-1>span{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}}:root{--bg:#fafaf8;--surface:#fff;--surface-2:#f5f4f0;--surface-3:#edebe5;--hover:#f0eee8;--selected:#ebf1fe;--border:#e5e2da;--border-strong:#d4d0c5;--border-soft:#efede6;--text:#1a1917;--text-muted:#6b6862;--text-soft:#9a968d;--text-faint:#bfbbb1;--accent:#2e5bff;--accent-soft:#e8eeff;--accent-hover:#1f47d9;--wood-1:#c9a876;--wood-2:#a8895c;--wood-3:#6f5538;--warn:#d97706;--warn-soft:#fef3e2;--ok:#059669;--danger:#dc2626;--topbar-h:44px;--bottombar-h:28px;--sidebar-l-w:240px;--sidebar-r-w:320px;--font-ui:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--r-sm:4px;--r-md:6px;--r-lg:10px;--shadow-sm:0 1px 2px #14120e0a;--shadow-md:0 2px 8px #14120e0f, 0 1px 2px #14120e0a;--shadow-lg:0 8px 24px #14120e14, 0 2px 6px #14120e0a}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);font-family:var(--font-ui);font-feature-settings:"cv11", "ss01", "ss03";-webkit-font-smoothing:antialiased;font-size:13px;line-height:1.4}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}.font-mono{font-family:var(--font-mono)!important}kbd{font-family:var(--font-mono)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border:1px solid var(--surface);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.new-project-dialog{border-radius:var(--r-lg);background:var(--surface);border:1px solid #e5e2daeb;gap:0;width:min(92vw,560px);max-width:560px;padding:0;overflow:hidden;box-shadow:0 24px 70px #14120e38,0 4px 18px #14120e1a}.new-project-form{flex-direction:column;min-width:0;display:flex}.new-project-header{text-align:left;border-bottom:1px solid var(--border-soft);background:linear-gradient(#fff 0%,#fafaf8 100%);grid-template-columns:38px minmax(0,1fr);gap:12px;padding:22px 24px 18px;display:grid}.new-project-title{letter-spacing:0;font-size:18px;line-height:1.2}.new-project-description{max-width:390px;color:var(--text-muted);margin-top:5px;font-size:12px;line-height:1.45}.new-project-icon{border-radius:var(--r-md);background:var(--accent-soft);width:38px;height:38px;color:var(--accent);border:1px solid #d9e2ff;place-items:center;display:grid}.new-project-body{gap:14px;padding:18px 24px 20px;display:grid}.new-project-section{gap:12px;display:grid}.new-project-section+.new-project-section{padding-top:2px}.new-project-section-title{color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:7px;font-size:11px;font-weight:650;display:flex}.new-project-field{gap:7px;min-width:0;display:grid}.new-project-field label{color:var(--text);font-size:12px;font-weight:600}.new-project-field input{border-color:var(--border);border-radius:var(--r-md);background:var(--surface);height:40px;padding:0 14px;box-shadow:inset 0 1px #ffffffe6}.new-project-field input:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px #2e5bff24}.new-project-field input::placeholder{color:var(--text-soft)}.dimension-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.new-project-field.compact label{color:var(--text-muted)}.unit-input{min-width:0;position:relative}.unit-input input{font-family:var(--font-mono);font-variant-numeric:tabular-nums;padding:0 42px 0 14px}.unit-input span{color:var(--text-soft);pointer-events:none;font-size:11px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.room-summary{border:1px solid var(--border-soft);border-radius:var(--r-md);background:var(--surface-2);min-height:34px;color:var(--text-muted);justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;font-size:12px;display:flex}.room-summary strong{color:var(--text);font-family:var(--font-mono);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:12px;font-weight:600}.new-project-error{border-radius:var(--r-md);color:var(--danger);background:#fef2f2;border:1px solid #dc26262e;padding:8px 10px;font-size:12px;line-height:1.35}.new-project-actions{border-top:1px solid var(--border-soft);background:var(--surface-2);flex-direction:row;justify-content:flex-end;gap:8px;padding:14px 24px;display:flex}.new-project-actions button{min-width:122px}@media (width<=520px){.new-project-dialog{width:calc(100vw - 24px)}.new-project-header,.new-project-body,.new-project-actions{padding-left:16px;padding-right:16px}.dimension-grid{grid-template-columns:1fr}.room-summary{flex-direction:column;align-items:flex-start;gap:2px}.new-project-actions{flex-direction:column-reverse}.new-project-actions button{width:100%}}.app-nav{align-items:center;gap:2px;height:100%;padding:0 4px;display:flex}.app-nav button{border-radius:var(--r-sm);height:30px;color:var(--text-muted);align-items:center;gap:6px;padding:0 12px;font-size:12px;font-weight:500;display:flex}.app-nav button:hover{color:var(--text);background:var(--hover)}.app-nav button.active{color:var(--text);background:var(--surface-2)}.app-nav .badge{font-family:var(--font-mono);background:var(--surface-3);color:var(--text-muted);border-radius:8px;padding:1px 5px;font-size:10px;font-weight:500}.app-nav button.active .badge{background:var(--text);color:var(--bg)}.bom-page{background:var(--bg);grid-template-rows:auto auto auto 1fr auto;min-height:0;display:grid;overflow:hidden}.bom-header{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:16px;padding:16px 20px 12px;display:flex}.bom-header h1{letter-spacing:-.01em;margin:0;font-size:20px;font-weight:600}.bom-header .meta{color:var(--text-muted);margin-top:2px;font-size:12px}.bom-header .actions{gap:6px;margin-left:auto;display:flex}.bom-summary{background:var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1px;display:grid}.summary-card{background:var(--surface);flex-direction:column;gap:4px;padding:14px 18px;display:flex}.summary-card .label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-soft);font-size:11px;font-weight:500}.summary-card .value{font-family:var(--font-mono);color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-size:18px;font-weight:600}.summary-card .sub{color:var(--text-muted);font-size:11px}.summary-card.accent .value{color:var(--accent)}.summary-card.total{background:linear-gradient(180deg, var(--text) 0%, #2a2722 100%)}.summary-card.total .label{color:#fafaf880}.summary-card.total .value{color:#fff;font-size:22px}.summary-card.total .sub{color:#fafaf899}.bom-toolbar{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding:10px 20px;display:flex}.bom-toolbar .search-wrap{width:280px;position:relative}.bom-toolbar .search-wrap input{border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-2);outline:none;width:100%;height:30px;padding:0 10px 0 30px;font-size:12px}.bom-toolbar .search-wrap input:focus{border-color:var(--accent);background:var(--surface)}.bom-toolbar .search-wrap svg{color:var(--text-soft);position:absolute;top:50%;left:9px;transform:translateY(-50%)}.group-switch{background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border);gap:1px;padding:2px;display:flex}.group-switch button{height:26px;color:var(--text-muted);border-radius:4px;align-items:center;gap:4px;padding:0 10px;font-size:11px;font-weight:500;display:flex}.group-switch button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.filter-chip{background:var(--surface-2);height:26px;color:var(--text-muted);border:1px solid var(--border);cursor:pointer;border-radius:999px;align-items:center;gap:4px;padding:0 10px;font-size:11px;font-weight:500;display:inline-flex}.filter-chip .x{color:var(--text-soft);margin-left:2px}.bom-tablewrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);margin:0 24px;overflow:auto}.bom-full{border-collapse:collapse;width:100%;font-size:12px}.bom-full thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap;padding:10px 12px;font-size:10px;font-weight:600;position:sticky;top:0}.bom-full thead th.num{text-align:right}.bom-full thead th.center{text-align:center}.bom-full tbody td{border-bottom:1px solid var(--border-soft);vertical-align:middle;padding:10px 12px}.bom-full tbody tr:hover td{background:var(--surface-2)}.bom-full tbody td.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.bom-full tbody td.num{text-align:right;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.bom-group-row td{border-top:1px solid var(--border);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);z-index:2;font-size:11px;font-weight:600;position:sticky;top:32px;background:var(--surface-2)!important;padding:8px 12px!important}.bom-group-row td .group-meta{font-family:var(--font-mono);color:var(--text-soft);text-transform:none;letter-spacing:0;margin-left:8px;font-size:10px;font-weight:500}.piece-cell{align-items:center;gap:8px;display:flex}.piece-cell .ico{background:var(--surface-2);border:1px solid var(--border-soft);width:28px;height:28px;color:var(--text-muted);border-radius:5px;flex-shrink:0;place-items:center;display:grid}.piece-cell .ico.tablero{color:#fff;background:linear-gradient(135deg,#d4b890,#a8895c);border-color:#6f5538}.piece-cell .ico.herraje{background:var(--surface-3)}.piece-cell .ico.canto{color:#6b6862;background:linear-gradient(135deg,#e8e5dd,#bfbbb1)}.piece-cell .ico.accesorio{background:var(--accent-soft);color:var(--accent)}.piece-cell .name{color:var(--text);font-weight:500}.piece-cell .sub{color:var(--text-soft);font-size:10px;font-family:var(--font-mono)}.module-pill{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border);white-space:nowrap;border-radius:999px;padding:2px 7px;font-size:10px;font-weight:500}.material-pill{color:var(--text);align-items:center;gap:6px;font-size:11px;display:inline-flex}.material-pill .dot{border:1px solid var(--border);border-radius:3px;width:12px;height:12px}.qty-input{border:1px solid var(--border);background:var(--surface);text-align:right;width:56px;height:26px;font-family:var(--font-mono);border-radius:4px;outline:none;padding:0 6px;font-size:11px}.qty-input:focus{border-color:var(--accent)}.row-status{color:var(--text-muted);align-items:center;gap:5px;font-size:11px;display:inline-flex}.row-status .dot{background:var(--text-soft);border-radius:50%;width:7px;height:7px}.row-status.ok .dot{background:var(--ok)}.row-status.cut .dot{background:var(--accent)}.bom-footer{background:var(--surface);border-top:1px solid var(--border);color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:16px;padding:14px 20px;font-size:12px;display:flex}.bom-footer .total-block{flex-wrap:wrap;align-items:baseline;gap:20px;margin-left:auto;display:flex}.bom-footer .total-block .item{flex-direction:column;align-items:flex-end;display:flex}.bom-footer .total-block .item .l{text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);font-size:10px;font-weight:500}.bom-footer .total-block .item .v{font-family:var(--font-mono);color:var(--text);font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.bom-footer .total-block .item.grand .v{color:var(--text);font-size:22px}.kind-tab-bar{border-bottom:1px solid var(--border);background:var(--surface);gap:2px;padding:0 24px;display:flex}.kind-tab-bar button{color:var(--text-muted);border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 14px 9px;font-size:12px;font-weight:500;display:flex}.kind-tab-bar button:hover{color:var(--text)}.kind-tab-bar button.active{color:var(--text);border-bottom-color:var(--text)}.kind-tab-bar .badge{font-family:var(--font-mono);background:var(--surface-3);color:var(--text-muted);border-radius:8px;padding:1px 5px;font-size:10px;font-weight:500}.opt-page{background:var(--bg);grid-template-columns:280px 1fr 300px;min-height:0;display:grid;overflow:hidden}@media (width<=1200px){.opt-page{grid-template-columns:240px 1fr 280px}}.opt-sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;display:flex;overflow-y:auto}.opt-sidebar.right{border-right:none;border-left:1px solid var(--border)}.opt-sidebar-header{border-bottom:1px solid var(--border);padding:14px 16px 10px}.opt-sidebar-header h3{margin:0;font-size:13px;font-weight:600}.opt-sidebar-header .sub{color:var(--text-soft);margin-top:2px;font-size:11px}.opt-section{border-bottom:1px solid var(--border-soft);padding:12px 16px}.opt-section h4{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 8px;font-size:10px;font-weight:600}.opt-canvas{background:#f2eee6;flex-direction:column;min-width:0;display:flex;overflow:hidden}.opt-canvas-toolbar{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 16px;display:flex}.sheet-tabs{background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border);gap:2px;padding:3px;display:flex}.sheet-tabs button{height:24px;color:var(--text-muted);border-radius:4px;align-items:center;gap:5px;padding:0 10px;font-size:11px;font-weight:500;display:flex}.sheet-tabs button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.sheet-tabs button .pct{font-family:var(--font-mono);color:var(--text-soft);font-size:9px}.sheet-tabs button.active .pct{color:var(--accent)}.opt-viewport{background:radial-gradient(circle at 1px 1px,#0000000d 1px,#0000 0) 0 0/20px 20px,#f2eee6;flex:1;justify-content:center;align-items:center;min-height:0;padding:24px;display:flex;overflow:auto}.sheet-wrap{justify-content:center;align-items:center;width:100%;max-width:1100px;display:flex}.sheet-svg{background:#fff;border-radius:4px;width:100%;height:auto;display:block;box-shadow:0 4px 24px #0000001a,0 1px 4px #0000000d}.kpi-card{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--r-md);flex-direction:column;gap:2px;margin-bottom:6px;padding:10px 12px;display:flex}.kpi-card .l{text-transform:uppercase;letter-spacing:.05em;color:var(--text-soft);font-size:10px;font-weight:500}.kpi-card .v{font-family:var(--font-mono);color:var(--text);font-variant-numeric:tabular-nums;font-size:16px;font-weight:600}.kpi-card .v.ok{color:var(--ok)}.kpi-card .sub{color:var(--text-muted);font-size:11px}.kpi-card.hero{background:linear-gradient(180deg, var(--text) 0%, #2a2722 100%);border-color:var(--text)}.kpi-card.hero .l{color:#fafaf880}.kpi-card.hero .v{color:#fff;font-size:22px}.kpi-card.hero .sub{color:#fafaf899}.efficiency-bar{background:var(--surface-3);border-radius:999px;height:6px;margin-top:6px;overflow:hidden}.efficiency-bar .fill{background:linear-gradient(90deg, var(--ok), #34d399);border-radius:999px;height:100%;transition:width .3s}.scrap-row{border:1px solid var(--border-soft);border-radius:var(--r-md);background:var(--surface);grid-template-columns:36px 1fr auto;align-items:center;gap:8px;margin-bottom:4px;padding:6px 8px;display:grid}.scrap-row .preview{background:linear-gradient(135deg,#e5cfa8,#c9a876);border:1px solid #6f5538;border-radius:2px;height:28px}.scrap-row .info .dim{font-family:var(--font-mono);color:var(--text);font-size:11px;font-weight:500}.scrap-row .info .meta{color:var(--text-soft);font-size:10px}.scrap-row .area{font-family:var(--font-mono);color:var(--text-muted);font-size:10px}.unplaced-alert{border-radius:var(--r-md);background:#fef2f2;border:1px solid #fca5a5;align-items:flex-start;gap:8px;margin-bottom:10px;padding:10px 12px;display:flex}.unplaced-alert svg{color:var(--danger);flex-shrink:0;margin-top:1px}.unplaced-alert .t{color:#991b1b;font-size:12px;font-weight:600}.unplaced-alert .s{color:#b91c1c;margin-top:2px;font-size:11px}.opt-mat-card{border:1px solid var(--border-soft);border-radius:var(--r-md);background:var(--surface);cursor:pointer;grid-template-columns:32px 1fr;align-items:center;gap:8px;margin-bottom:4px;padding:8px 10px;display:grid}.opt-mat-card:hover{border-color:var(--border-strong)}.opt-mat-card.active{background:var(--selected);border-color:var(--accent)}.opt-mat-card .swatch{border:1px solid var(--border);border-radius:5px;width:32px;height:32px}.opt-mat-card .info .name{font-size:12px;font-weight:500}.opt-mat-card .info .meta{font-family:var(--font-mono);color:var(--text-soft);font-size:10px}.opt-mat-card .info .count{font-family:var(--font-mono);color:var(--accent);font-size:10px;font-weight:500}.cat-page{background:var(--bg);grid-template-columns:220px 1fr;min-height:0;display:grid;overflow:hidden}.cat-nav{background:var(--surface);border-right:1px solid var(--border);padding:14px 10px;overflow-y:auto}.cat-nav-section{margin-bottom:18px}.cat-nav-section h5{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 8px 6px;font-size:10px;font-weight:600}.cat-nav-item{border-radius:var(--r-md);color:var(--text-soft);cursor:pointer;transition:var(--t);align-items:center;gap:10px;margin-bottom:1px;padding:7px 10px;font-size:12px;font-weight:500;display:flex}.cat-nav-item:hover{background:var(--surface-2);color:var(--text)}.cat-nav-item.active{background:var(--selected);color:var(--accent)}.cat-nav-item .count{font-family:var(--font-mono);color:var(--text-soft);background:var(--surface-3);border-radius:999px;margin-left:auto;padding:1px 6px;font-size:10px}.cat-nav-item.active .count{color:var(--accent);background:#6382bb26}.cat-main{flex-direction:column;min-width:0;display:flex;overflow:hidden}.cat-header{border-bottom:1px solid var(--border);background:var(--surface);padding:16px 24px 12px}.cat-header-top{flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:12px;display:flex}.cat-header h2{letter-spacing:-.01em;margin:0;font-size:22px;font-weight:600}.cat-header .desc{color:var(--text-soft);margin-top:2px;font-size:12px}.cat-readonly-note{border-radius:var(--r-md);color:#92510b;background:#fff7e6;border:1px solid #f0d9a4;align-items:center;gap:8px;max-width:720px;padding:8px 10px;font-size:12px;line-height:1.35;display:inline-flex}.cat-readonly-note svg{flex-shrink:0}.cat-error{border-radius:var(--r-md);max-width:720px;color:var(--danger);background:#fef2f2;border:1px solid #dc26262e;margin-top:8px;padding:8px 10px;font-size:12px;line-height:1.35}.cat-toolbar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.cat-search{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);flex:1;align-items:center;gap:6px;min-width:180px;max-width:320px;height:30px;padding:0 10px;display:flex}.cat-search input{background:0 0;border:none;outline:none;flex:1;font-size:12px}.cat-search kbd{font-family:var(--font-mono);background:var(--surface);border:1px solid var(--border);color:var(--text-soft);border-radius:3px;padding:1px 5px;font-size:10px}.cat-filters{border-bottom:1px solid var(--border);background:var(--surface);flex-wrap:wrap;align-items:center;gap:6px;padding:10px 24px;display:flex}.filter-chip{background:var(--surface-2);border:1px solid var(--border);height:24px;color:var(--text-soft);cursor:pointer;transition:var(--t);border-radius:999px;align-items:center;gap:5px;padding:0 10px;font-size:11px;font-weight:500;display:inline-flex}.filter-chip .x{opacity:.6;margin-left:2px}.cat-body{background:var(--bg);flex:1;padding:20px 24px;overflow:auto}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.product-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:var(--t);flex-direction:column;display:flex;overflow:hidden}.product-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.product-card.selected{border-color:var(--accent);box-shadow:0 0 0 2px #6382bb26}.product-preview{border-bottom:1px solid var(--border-soft);height:120px;position:relative;overflow:hidden}.product-preview .badge{border:1px solid var(--border);font-family:var(--font-mono);color:var(--text-soft);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffe6;border-radius:3px;padding:2px 6px;font-size:9px;font-weight:500;position:absolute;top:8px;right:8px}.product-preview .stock-pip{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffe6;border-radius:999px;align-items:center;gap:4px;padding:2px 7px;font-size:10px;font-weight:500;display:inline-flex;position:absolute;top:8px;left:8px}.stock-pip .dot{border-radius:50%;width:6px;height:6px}.stock-pip.in .dot{background:var(--ok)}.stock-pip.low .dot{background:var(--warn)}.stock-pip.out .dot{background:var(--danger)}.product-info{padding:10px 12px 12px}.product-name{letter-spacing:-.01em;margin-bottom:2px;font-size:13px;font-weight:600;line-height:1.25}.product-meta{font-family:var(--font-mono);color:var(--text-soft);gap:8px;font-size:10px;display:flex}.product-row{border-top:1px solid var(--border-soft);justify-content:space-between;align-items:center;margin-top:8px;padding-top:8px;display:flex}.product-price{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.product-supplier{color:var(--text-soft);font-size:10px}.cat-detail{background:var(--surface);border-left:1px solid var(--border);z-index:50;flex-direction:column;width:380px;animation:.18s ease-out slide-in;display:flex;position:absolute;top:0;bottom:0;right:0;box-shadow:-8px 0 24px #0000000f}@keyframes slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.cat-detail-header{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:14px 16px;display:flex}.cat-detail-header .swatch-lg{border-radius:var(--r-md);border:1px solid var(--border);flex-shrink:0;width:56px;height:56px}.cat-detail-header h3{letter-spacing:-.01em;margin:0 0 2px;font-size:15px;font-weight:600;line-height:1.2}.cat-detail-header .code{font-family:var(--font-mono);color:var(--text-soft);font-size:11px}.cat-detail-header .close{width:24px;height:24px;color:var(--text-soft);border-radius:5px;justify-content:center;align-items:center;display:flex;position:absolute;top:14px;right:14px}.cat-detail-header .close:hover{background:var(--surface-2);color:var(--text)}.cat-detail-body{flex:1;overflow-y:auto}.spec-group{border-bottom:1px solid var(--border-soft);padding:14px 16px}.spec-group h4{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 10px;font-size:10px;font-weight:600}.spec-row{justify-content:space-between;padding:4px 0;font-size:12px;display:flex}.spec-row .l{color:var(--text-soft)}.spec-row .v{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:500}.warehouse-row{border:1px solid var(--border-soft);border-radius:var(--r-md);grid-template-columns:1fr auto auto;align-items:center;gap:10px;margin-bottom:4px;padding:6px 8px;display:grid}.warehouse-row .name{font-size:12px;font-weight:500}.warehouse-row .loc{color:var(--text-soft);font-size:10px;font-family:var(--font-mono)}.warehouse-row .qty{font-family:var(--font-mono);font-size:12px;font-weight:600}.price-history{align-items:flex-end;gap:4px;height:60px;padding-top:6px;display:flex}.price-bar{background:linear-gradient(180deg, var(--accent-soft), #6382bb1a);border-top:2px solid var(--accent);border-radius:2px 2px 0 0;flex:1;position:relative}.price-history-label{font-family:var(--font-mono);color:var(--text-soft);text-align:center;margin-top:4px;font-size:9px}.cat-detail-footer{border-top:1px solid var(--border);gap:8px;padding:12px 16px;display:flex}.cat-detail-footer .btn{flex:1;justify-content:center;height:32px}.catalog-dialog-overlay{z-index:100;background:#14120e70;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.catalog-dialog{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);width:min(720px,100%);max-height:min(760px,100vh - 48px);box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.catalog-dialog-header{border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:16px 18px;display:flex}.catalog-dialog-header>div{flex:1}.catalog-dialog-header h3{letter-spacing:-.01em;margin:0;font-size:18px}.catalog-dialog-header p{color:var(--text-soft);margin:3px 0 0;font-size:12px}.catalog-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:16px 18px;display:grid;overflow-y:auto}.catalog-form-grid label{gap:5px;min-width:0;display:grid}.catalog-form-grid label span{color:var(--text-muted);font-size:11px;font-weight:600}.catalog-form-grid input,.catalog-form-grid select{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);width:100%;min-width:0;height:38px;color:var(--text);padding:0 10px;font-size:13px}.catalog-form-grid input:focus,.catalog-form-grid select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #2e5bff1f}.catalog-color-input{grid-template-columns:42px minmax(0,1fr);gap:8px;display:grid}.catalog-color-input input[type=color]{padding:4px}.catalog-check-field{align-content:start}.catalog-check-field input[type=checkbox]{width:18px;min-width:18px;height:18px;accent-color:var(--accent);padding:0}.catalog-dialog>.cat-error{margin:0 18px 14px}.catalog-dialog-footer{border-top:1px solid var(--border);background:var(--surface-2);justify-content:flex-end;gap:8px;padding:14px 18px;display:flex}@media (width<=720px){.catalog-form-grid{grid-template-columns:1fr}}.swatch-board{background-position:50%;background-size:cover}.swatch-edge{background:linear-gradient(90deg, transparent 0%, var(--swatch-color,#c9a876) 100%), repeating-linear-gradient(0deg, var(--surface-2) 0 4px, var(--surface) 4px 8px)}.hardware-icon{color:#6b6862;background:linear-gradient(135deg,#e8e5dd,#d6d2c7);justify-content:center;align-items:center;display:flex}.cat-table{border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;overflow:hidden}.cat-table thead{background:var(--surface-2)}.cat-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 12px;font-size:10px;font-weight:600}.cat-table td{border-bottom:1px solid var(--border-soft);vertical-align:middle;padding:10px 12px;font-size:12px}.cat-table tr:last-child td{border-bottom:none}.cat-table tr:hover td{background:var(--surface-2);cursor:pointer}.cat-table tr.selected td{background:var(--selected)}.cat-table .swatch-cell{border:1px solid var(--border);border-radius:4px;width:36px;height:28px}.cat-table .num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right}.view-toggle{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);gap:1px;padding:2px;display:inline-flex}.view-toggle button{width:26px;height:24px;color:var(--text-muted);border-radius:4px;justify-content:center;align-items:center;display:flex}.view-toggle button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.app{grid-template-rows:var(--topbar-h) 1fr var(--bottombar-h);background:var(--bg);height:100vh;display:grid}.workspace{grid-template-columns:var(--sidebar-l-w) 1fr var(--sidebar-r-w);min-height:0;display:grid;overflow:hidden}.workspace.no-left{grid-template-columns:0 1fr var(--sidebar-r-w)}.workspace.no-right{grid-template-columns:var(--sidebar-l-w) 1fr 0}.workspace.no-left.no-right{grid-template-columns:0 1fr 0}.app[data-screen-label=mueble]{grid-template-rows:var(--topbar-h) 1fr}.furniture-editor-workspace{background:#eef0f3;grid-template-columns:260px minmax(0,1fr) 340px;min-height:0;display:grid;overflow:hidden}.furniture-layers-panel,.furniture-properties-panel{background:var(--surface);flex-direction:column;min-width:0;min-height:0;display:flex}.furniture-layers-panel{border-right:1px solid var(--border)}.furniture-properties-panel{border-left:1px solid var(--border)}.furniture-editor-canvas{background:#e2e5e9;min-width:0;min-height:0;position:relative}.furniture-panel-heading,.furniture-properties-heading{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;height:58px;padding:10px 12px;display:flex}.furniture-panel-heading>div,.furniture-properties-heading{flex-direction:column;justify-content:center;align-items:flex-start}.furniture-panel-heading strong,.furniture-properties-heading strong{color:var(--text);font-size:13px}.furniture-properties-heading small{font:9px var(--font-mono);color:var(--text-soft)}.furniture-panel-kicker{color:var(--text-soft);text-transform:uppercase;letter-spacing:.08em;font-size:9px}.furniture-layer-search{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-2);height:32px;color:var(--text-soft);align-items:center;gap:7px;margin:10px 10px 6px;padding:0 9px;display:flex}.furniture-layer-search input{width:100%;color:var(--text);background:0 0;border:0;outline:0;font-size:11px}.furniture-layer-toolbar{color:var(--text-soft);justify-content:space-between;align-items:center;padding:4px 10px 8px;font-size:10px;display:flex}.furniture-layer-toolbar button{color:var(--text-muted);cursor:pointer;background:0 0;border:0;align-items:center;gap:5px;font-size:11px;display:flex}.furniture-layer-toolbar .furniture-group-selection{color:var(--accent);font-weight:600}.furniture-layer-tree{flex:1;padding:2px 6px 12px;overflow:auto}.furniture-group-row,.furniture-root-row,.furniture-layer-row{border-radius:var(--r-sm);min-height:30px;color:var(--text-muted);align-items:center;gap:6px;display:flex}.furniture-group-row.active,.furniture-layer-row.selected{color:#1769d2;background:#e7f2ff}.furniture-group-row input{min-width:0;color:inherit;background:0 0;border:0;outline:0;flex:1;font-size:11px;font-weight:600}.furniture-tree-toggle,.furniture-tree-action{width:20px;height:24px;color:inherit;cursor:pointer;background:0 0;border:0;place-items:center;display:grid}.furniture-layer-row{cursor:pointer;text-align:left;background:0 0;border:0;width:100%}.furniture-layer-row:hover,.furniture-group-row:hover{background:var(--hover)}.furniture-layer-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:11px;overflow:hidden}.furniture-layer-detail{font:9px var(--font-mono);color:var(--text-soft)}.furniture-root-row{text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);margin-top:6px;padding:0 8px;font-size:10px;font-weight:700}.furniture-layers-empty{color:var(--text-soft);text-align:center;padding:18px 12px;font-size:11px;line-height:1.5}.furniture-layer-move{border-top:1px solid var(--border-soft);color:var(--text-soft);gap:6px;padding:10px;font-size:10px;display:grid}.furniture-layer-move select{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);height:30px;color:var(--text);padding:0 7px;font-size:11px}.furniture-group-row{cursor:pointer}.furniture-group-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:11px;font-weight:600;overflow:hidden}.furniture-group-name-input{min-width:0;color:inherit;background:0 0;border:0;outline:0;flex:1;font-size:11px;font-weight:600}.furniture-inline-edit{border:1px solid var(--accent);border-radius:var(--r-sm);background:var(--surface);min-width:0;height:22px;color:var(--text);outline:0;flex:1;padding:0 4px;font-size:11px}.furniture-eye{width:22px;height:22px;color:var(--text-soft);cursor:pointer;opacity:0;background:0 0;border:0;flex-shrink:0;place-items:center;transition:opacity .12s;display:grid}.furniture-layer-row:hover .furniture-eye,.furniture-group-row:hover .furniture-eye,.furniture-eye.is-active{opacity:.85}.furniture-eye:hover{color:var(--text)}.furniture-layer-row.is-hidden .furniture-layer-name,.furniture-group-row.is-hidden .furniture-group-name{color:var(--text-muted);opacity:.55}.furniture-drop-line{background:var(--accent);pointer-events:none;border-radius:2px;height:2px;margin:1px 6px}.furniture-group-row.drop-inside{outline:2px solid var(--accent);outline-offset:-2px;background:var(--accent-soft,#eef3ff)}.furniture-properties-content{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.furniture-properties-empty{text-align:center;width:220px;color:var(--text-soft);justify-items:center;gap:8px;margin:auto;display:grid}.furniture-properties-empty strong{color:var(--text);font-size:12px}.furniture-properties-empty span{font-size:11px;line-height:1.45}.furniture-context-menu{z-index:1000;color:#f4f4f4;background:#202020;border:1px solid #ffffff14;border-radius:13px;width:252px;padding:7px;position:fixed;box-shadow:0 18px 45px #00000052}.furniture-context-menu button,.furniture-context-select{width:100%;height:36px;color:inherit;cursor:pointer;background:0 0;border:0;border-radius:7px;justify-content:space-between;align-items:center;gap:12px;padding:0 9px;font-size:12px;display:flex}.furniture-context-menu button:hover,.furniture-context-select:hover{background:#343434}.furniture-context-menu button span,.furniture-context-select>span{align-items:center;gap:9px;display:flex}.furniture-context-menu kbd{color:#aaa;font:11px var(--font-mono)}.furniture-context-divider{background:#3d3d3d;height:1px;margin:6px 5px}.furniture-context-menu .danger{color:#ff8f8f}.furniture-context-select select{color:#fff;background:#343434;border:0;outline:0;max-width:105px;font-size:10px}@media (width<=1050px){.furniture-editor-workspace{grid-template-columns:220px minmax(0,1fr) 300px}}.topbar{background:var(--surface);border-bottom:1px solid var(--border);height:var(--topbar-h);align-items:center;gap:8px;padding:0 12px;display:flex}.topbar .brand{letter-spacing:-.01em;border-right:1px solid var(--border);align-items:center;gap:8px;height:100%;padding-right:12px;font-weight:600;display:flex}.brand-mark{color:#fafaf8;letter-spacing:0;background:linear-gradient(135deg,#1a1917 0%,#3a3530 100%);border-radius:5px;place-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:grid}.crumbs{color:var(--text-muted);white-space:nowrap;align-items:center;gap:6px;min-width:0;font-size:12px;display:flex;overflow:hidden}.crumbs .current{text-overflow:ellipsis;overflow:hidden}@media (width<=1100px){.crumbs{display:none}}@media (width<=980px){.topbar .brand span{display:none}}.crumbs .sep{color:var(--text-faint)}.crumbs .current{color:var(--text);font-weight:500}.crumbs .status-pill{border-radius:999px;align-items:center;gap:5px;margin-left:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.crumbs .status-pill .dot{border-radius:50%;width:5px;height:5px}.crumbs .status-pill.s-design{color:#374151;background:#f3f4f6}.crumbs .status-pill.s-design .dot{background:#6b7280}.crumbs .status-pill.s-fab{color:var(--accent);background:#2e5bff1a}.crumbs .status-pill.s-fab .dot{background:var(--accent)}.crumbs .status-pill.s-install{color:#92510b;background:#fef6e7}.crumbs .status-pill.s-install .dot{background:var(--warn)}.crumbs .status-pill.s-done{color:#065f46;background:#ecfdf5}.crumbs .status-pill.s-done .dot{background:var(--ok)}.topbar .back-btn{color:var(--text-muted);border-radius:var(--r-md);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:4px 8px 4px 6px;font-size:12px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.topbar .back-btn:hover{background:var(--hover);color:var(--text)}.topbar .spacer{flex:1}.view-switch{background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border);gap:1px;padding:2px;display:flex}.view-switch button{color:var(--text-muted);border-radius:4px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:flex}.view-switch button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.view-switch button:hover:not(.active){color:var(--text)}.topbar-actions{align-items:center;gap:4px;display:flex}.icon-btn{border-radius:var(--r-sm);width:28px;height:28px;color:var(--text-muted);place-items:center;display:grid}.icon-btn:hover{background:var(--hover);color:var(--text)}.icon-btn.active{background:var(--selected);color:var(--accent)}.btn{border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);height:28px;color:var(--text);align-items:center;gap:6px;padding:0 12px;font-size:12px;font-weight:500;display:inline-flex}.btn:hover{background:var(--hover)}.btn:disabled{cursor:not-allowed;opacity:.55}.btn:disabled:hover{background:var(--surface)}.btn.primary{background:var(--text);color:var(--bg);border-color:var(--text)}.btn.primary:hover{background:#000}.btn.accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.accent:hover{background:var(--accent-hover)}.btn.accent:disabled:hover{background:var(--accent)}.divider-v{background:var(--border);width:1px;height:20px;margin:0 6px}.user-chip{color:#fff;background:linear-gradient(135deg,#c9a876,#a8895c);border-radius:50%;place-items:center;width:26px;height:26px;font-size:11px;font-weight:600;display:grid}.bottombar{background:var(--surface);border-top:1px solid var(--border);color:var(--text-muted);font-size:11px;font-family:var(--font-mono);height:var(--bottombar-h);align-items:center;gap:12px;padding:0 12px;display:flex}.bottombar .item{align-items:center;gap:5px;display:flex}.bottombar .sep{background:var(--border);width:1px;height:14px}.bottombar .spacer{flex:1}.bottombar .item.active{color:var(--accent)}.bottombar .item:hover{color:var(--text);cursor:default}.status-dot{background:var(--ok);border-radius:50%;width:6px;height:6px}.config-mode{grid-template-columns:1fr 1fr 1fr;gap:4px;margin-bottom:12px;display:grid}.mode-card{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface-2);cursor:pointer;flex-direction:column;align-items:center;gap:4px;padding:8px 4px 6px;transition:all .1s;display:flex}.mode-card:hover{background:var(--surface);border-color:var(--border-strong)}.mode-card.active{background:var(--selected);border-color:var(--accent);color:var(--accent)}.mode-card svg{color:var(--text-muted)}.mode-card.active svg{color:var(--accent)}.mode-card .label{font-size:11px;font-weight:500}.front-preview{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:var(--r-md);grid-template-columns:1fr auto;align-items:center;gap:12px;width:100%;margin-bottom:12px;padding:12px;display:grid}.front-preview-meta{font-family:var(--font-mono);color:var(--text-muted);flex-direction:column;gap:4px;font-size:10px;display:flex}.front-preview-meta .k{color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em;font-size:9px}.front-preview-meta .v{color:var(--text);font-weight:500}.comp-zone-head{color:var(--text-soft);justify-content:space-between;align-items:center;padding:6px 2px 4px;font-size:11px;display:flex}.comp-zone-head .budget{font-family:var(--font-mono);font-size:10px}.comp-door-node{border-top:1px solid var(--border-soft)}.comp-door-row{background:var(--surface);grid-template-columns:14px 18px 18px minmax(0,1fr) minmax(0,1fr) 26px 18px 18px 18px;align-items:center;gap:2px;min-height:38px;padding:6px 3px;display:grid}.comp-door-row:hover{background:var(--surface-2)}.comp-door-toggle,.comp-door-remove{width:18px;height:22px;color:var(--text-soft);border-radius:var(--r-sm);place-items:center;display:grid}.comp-door-toggle:hover,.comp-door-remove:hover{color:var(--text);background:var(--surface-3)}.comp-door-icon{color:var(--accent);place-items:center;display:grid}.comp-door-label{color:var(--text);font-size:11px;font-weight:600}.comp-door-select{font-family:var(--font-ui);color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;width:100%;min-width:0;padding:2px;font-size:11px;font-weight:500}.comp-door-row .num-input{min-width:0}.comp-door-row .num-input input{min-width:0;padding:0 4px;font-size:11px}.comp-door-row .num-input .unit{padding:0 4px;font-size:10px}.comp-door-row .pct,.drawer-row .pct{width:26px;color:var(--text-soft);font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right;font-size:10px}.comp-door-remove:hover{color:var(--danger)}.comp-lock{width:18px;height:22px;color:var(--text-faint);border-radius:var(--r-sm);place-items:center;display:grid}.comp-lock:hover{color:var(--text);background:var(--surface-3)}.comp-lock.active{color:var(--accent);background:var(--accent-soft)}.comp-visibility{width:18px;height:22px;color:var(--text-faint);border-radius:var(--r-sm);place-items:center;display:grid}.comp-visibility:hover{color:var(--text);background:var(--surface-3)}.comp-visibility.active{color:var(--accent);background:var(--accent-soft)}.comp-door-row.is-hidden,.drawer-row.is-hidden{color:var(--text-soft);background:var(--surface-2)}.comp-door-count{font-family:var(--font-mono);color:var(--text-soft);white-space:nowrap;font-size:9px}.comp-door-children{border:1px solid var(--border);border-left:2px solid var(--accent);border-radius:var(--r-sm);background:var(--surface-2);margin:0 8px 8px 28px;overflow:hidden}.comp-door-children-head{border-bottom:1px solid var(--border-soft);color:var(--text-soft);letter-spacing:.04em;text-transform:uppercase;justify-content:space-between;gap:8px;padding:6px 8px;font-size:9px;font-weight:600;display:flex}.comp-door-children .drawer-row{padding-left:6px}.comp-empty{color:var(--text-soft);text-align:center;padding:14px 10px;font-size:11px}.comp-empty.nested{padding:10px}.loc-badge{letter-spacing:.02em;border-radius:999px;flex-shrink:0;padding:1px 6px;font-size:9px;font-weight:500}.loc-badge[data-loc=front]{color:#0f6e56;background:#e6f4ec}.loc-badge[data-loc=interior]{background:var(--accent-soft);color:var(--accent)}.drawer-list{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);flex-direction:column;display:flex;overflow:hidden}.drawer-row{border-bottom:1px solid var(--border-soft);background:var(--surface);grid-template-columns:14px 14px auto minmax(0,1fr) 26px 18px 18px 18px;align-items:center;gap:2px;min-width:0;padding:6px 3px;transition:background .1s;display:grid}.drawer-row>*{min-width:0}.drawer-row:last-child{border-bottom:none}.drawer-row:hover{background:var(--surface-2)}.drawer-row.dragging{opacity:.5}.drawer-grip{color:var(--text-faint);cursor:grab;place-items:center;display:grid}.drawer-grip:hover{color:var(--text-muted)}.drawer-num{font-family:var(--font-mono);color:var(--text-soft);text-align:center;font-size:10px}.drawer-item-identity{white-space:nowrap;align-items:center;gap:5px;min-width:42px;font-size:11px;font-weight:500;display:flex}.drawer-item-icon{border-radius:var(--r-sm);background:var(--surface);border:1px solid;flex:0 0 20px;place-items:center;width:20px;height:20px;display:grid}.comp-door-children .drawer-item-icon{background:var(--surface-2)}.drawer-row .num-input{min-width:0;height:24px}.drawer-row .num-input input{min-width:0;padding:0 4px;font-size:11px}.drawer-row .num-input .unit{padding:0 4px;font-size:10px}.drawer-row .remove{color:var(--text-faint);border-radius:4px;place-items:center;width:18px;height:22px;display:grid}.drawer-row .remove:hover{color:var(--danger);background:var(--surface-3)}.comp-add-cluster{border-top:1px solid var(--border-soft);background:var(--surface-2);align-items:center;gap:5px;min-height:35px;padding:5px 8px;display:flex}.comp-add-cluster.inner{padding-left:8px}.comp-add-hint{color:var(--text-soft);white-space:nowrap;margin-right:2px;font-size:10px}.comp-add-button{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);width:27px;height:25px;color:var(--text-muted);cursor:pointer;flex:none;place-items:center;transition:border-color .12s,color .12s,background .12s;display:grid}.comp-add-button:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.comp-add-button.distribute{margin-left:auto}.drawer-detail{background:var(--surface-2);border-top:1px dashed var(--border-soft);border-bottom:1px solid var(--border-soft);flex-direction:column;gap:4px;padding:8px 10px 10px 32px;display:flex}.drawer-detail .dd-row{align-items:center;gap:8px;min-height:26px;display:flex}.drawer-detail .dd-label{color:var(--text-muted);min-width:76px;font-size:11px;font-weight:500}.drawer-detail .dd-help{color:var(--text-soft);margin-left:84px;font-size:10px;line-height:1.35}.drawer-detail .dd-error{color:var(--danger);align-items:center;gap:4px;margin-left:84px;font-size:10px;display:flex}.drawer-detail .dd-warn{color:#92400e;margin-left:84px;font-size:10px;line-height:1.35}.drawer-detail .dd-pill-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);gap:1px;padding:2px;display:inline-flex}.drawer-detail .dd-pill{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:3px 10px;font-size:11px;font-weight:500;transition:background .12s,color .12s}.drawer-detail .dd-pill:hover:not(.active):not(:disabled){background:var(--surface-2);color:var(--text)}.drawer-detail .dd-pill.active{background:var(--accent);color:#fff;cursor:default}.drawer-detail .dd-pill:disabled{opacity:.45;cursor:not-allowed}.drawer-detail .dd-link-btn{height:22px;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:4px;align-items:center;gap:4px;padding:0 6px;font-size:10px;display:inline-flex}.drawer-detail .dd-link-btn:hover{color:var(--accent);border-color:var(--accent)}.drawer-detail .num-input{height:24px}.drawer-detail .num-input input{padding:0 6px;font-size:11px}.drawer-detail .num-input .unit{padding:0 6px;font-size:10px}.drawer-detail .dd-select{background:var(--surface);border:1px solid var(--border);height:24px;color:var(--text);font-size:11px;font-family:var(--font-sans);cursor:pointer;border-radius:4px;flex:1;min-width:0;padding:0 6px}.drawer-detail .dd-select:hover{border-color:var(--accent)}.drawer-detail .dd-select:focus{border-color:var(--accent);outline:none}.height-bar{border:1px solid var(--border);background:var(--surface);border-radius:3px;flex-direction:column;width:18px;height:60px;display:flex;overflow:hidden}.height-bar .seg{border-bottom:1px solid var(--border-soft);background:var(--wood-1);transition:flex-basis .2s;position:relative}.height-bar .seg:last-child{border-bottom:none}.config-subhead{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:6px;margin:14px 0 6px;font-size:11px;font-weight:600;display:flex}.config-subhead .pill{font-family:var(--font-mono);background:var(--surface-3);color:var(--text-muted);text-transform:none;letter-spacing:0;border-radius:8px;padding:1px 5px;font-size:9px;font-weight:500}.order-toggle{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);gap:1px;padding:3px;display:flex}.order-toggle button{color:var(--text-muted);border-radius:4px;flex:1;justify-content:center;align-items:center;gap:5px;padding:6px 4px;font-size:11px;font-weight:500;display:flex}.order-toggle button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.alert-warn{background:var(--warn-soft);border-radius:var(--r-md);color:#92400e;border:1px solid #f4d8a6;gap:8px;margin-top:8px;padding:6px 8px;font-size:11px;display:flex}.alert-warn svg{color:var(--warn);flex-shrink:0;margin-top:1px}.snap-toast{background:var(--text);color:var(--bg);border-radius:var(--r-md);font-size:11px;font-family:var(--font-mono);box-shadow:var(--shadow-md);z-index:10;align-items:center;gap:6px;padding:6px 12px;animation:.2s ease-out fadeUp;display:flex;position:absolute;top:16px;left:50%;transform:translate(-50%)}@keyframes fadeUp{0%{opacity:0;transform:translate(-50%)translateY(4px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.sidebar-r{background:var(--surface);border-left:1px solid var(--border);flex-direction:column;min-height:0;display:flex;overflow:hidden}.tab-bar{border-bottom:1px solid var(--border);gap:2px;padding:0 8px;display:flex}.tab-bar button{color:var(--text-muted);border-bottom:2px solid #0000;align-items:center;gap:5px;margin-bottom:-1px;padding:10px 10px 9px;font-size:12px;font-weight:500;display:flex}.tab-bar button:hover{color:var(--text)}.tab-bar button.active{color:var(--text);border-bottom-color:var(--text)}.tab-bar .badge{font-family:var(--font-mono);background:var(--surface-3);color:var(--text-muted);border-radius:8px;padding:1px 5px;font-size:10px;font-weight:500}.inspector{flex:1;overflow-y:auto}.module-inspector-v1{height:100%;min-height:0;color:var(--text);background:var(--surface);flex-direction:column;font-size:13px;display:flex}.module-inspector-header{border-bottom:1px solid var(--border-soft);flex:none;padding:11px 13px}.module-stage-tabs{border-bottom:1px solid var(--border);background:var(--surface-2);flex:none;gap:3px;padding:8px 9px;display:flex}.module-stage-tab{border-radius:var(--r-md);min-width:0;min-height:47px;color:var(--text-muted);font-family:var(--font-ui);cursor:pointer;background:0 0;border:1px solid #0000;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:5px 3px;font-size:10.5px;display:flex}.module-stage-tab:hover{color:var(--text);background:var(--surface)}.module-stage-tab.active{border-color:var(--border);background:var(--surface);color:var(--accent);font-weight:500;box-shadow:0 1px 2px #0000000d}.module-inspector-scroll{overscroll-behavior:contain;flex:auto;min-height:0;overflow-y:auto}.module-inspector-scroll>.section:first-child{border-top:0}.module-position-footer{border-top:1px solid var(--border);background:var(--surface-2);flex:none;padding:10px 13px 8px;box-shadow:0 -4px 12px #1a19170a}.module-position-title{color:var(--text-soft);letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:6px;margin-bottom:9px;font-size:10px;font-weight:500;display:flex}.module-position-footer .field-row:last-child{margin-bottom:0}.section{border-bottom:1px solid var(--border-soft)}.section-header{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 14px 8px;font-size:11px;font-weight:600;display:flex}.section-header:hover{color:var(--text)}.section-header .chevron{transition:transform .15s}.section.collapsed .chevron{transform:rotate(-90deg)}.section.collapsed .section-body{display:none}.section-body{padding:0 14px 14px}.field{margin-bottom:10px}.field-row{grid-template-columns:80px 1fr;align-items:center;gap:8px;margin-bottom:6px;display:grid}.field-label{color:var(--text-muted);font-size:12px}.field-help{color:var(--text-soft);margin-top:4px;font-size:11px}.num-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);align-items:center;height:28px;transition:border-color .1s;display:flex;overflow:hidden}.num-input:focus-within{border-color:var(--accent);background:var(--surface)}.num-input input{width:100%;min-width:0;height:100%;font-family:var(--font-mono);font-variant-numeric:tabular-nums;background:0 0;border:none;outline:none;flex:1;padding:0 8px;font-size:12px}.num-input input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.num-input input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.num-input input[type=number]{appearance:textfield}.num-input .unit{color:var(--text-soft);font-size:11px;font-family:var(--font-mono);border-left:1px solid var(--border-soft);flex-shrink:0;place-items:center;height:100%;padding:0 8px;display:grid}.num-input .step{width:22px;height:100%;color:var(--text-soft);border-left:1px solid var(--border-soft);place-items:center;display:grid}.num-input .step:hover{background:var(--hover);color:var(--text)}.num-trio{grid-template-columns:1fr 1fr 1fr;gap:4px;display:grid}.num-cell{flex-direction:column;gap:3px;display:flex}.num-cell .axis{font-family:var(--font-mono);color:var(--text-soft);text-transform:uppercase;letter-spacing:.08em;padding-left:2px;font-size:9px}.num-cell .axis.x{color:#dc2626}.num-cell .axis.y{color:#059669}.num-cell .axis.z{color:#2e5bff}.swatch-grid{grid-template-columns:repeat(6,1fr);gap:5px;display:grid}.swatch{aspect-ratio:1;border-radius:var(--r-sm);cursor:pointer;border:2px solid #0000;transition:all .1s;position:relative}.swatch:hover{transform:scale(1.06)}.swatch.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--surface), 0 0 0 3px var(--accent)}.swatch:after{content:attr(data-name);background:var(--text);color:var(--bg);white-space:nowrap;opacity:0;pointer-events:none;border-radius:3px;padding:3px 6px;font-size:10px;transition:opacity .1s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)translateY(-4px)}.swatch:hover:after{opacity:1}.material-row{border:1px solid var(--border-soft);border-radius:var(--r-md);background:var(--surface-2);grid-template-columns:28px 1fr auto;align-items:center;gap:8px;margin-bottom:4px;padding:6px 8px;display:grid}.material-row:hover{background:var(--surface);border-color:var(--border)}.material-chip{border-radius:var(--r-sm);border:1px solid var(--border);width:28px;height:28px}.material-info{min-width:0}.material-info .name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.material-info .meta{font-family:var(--font-mono);color:var(--text-soft);font-size:10px}.chip-row{flex-wrap:wrap;gap:4px;display:flex}.chip{background:var(--surface-2);color:var(--text-muted);cursor:pointer;border:1px solid #0000;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:500}.chip:hover{background:var(--hover);color:var(--text)}.chip.active{background:var(--text);color:var(--bg)}.seg{background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border);padding:2px;display:flex}.seg button{color:var(--text-muted);border-radius:4px;flex:1;padding:4px 0;font-size:11px;font-weight:500}.seg button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.toggle-row{justify-content:space-between;align-items:center;padding:6px 0;display:flex}.toggle{background:var(--border-strong);border-radius:999px;flex-shrink:0;width:28px;height:16px;transition:background .1s;position:relative}.toggle:after{content:"";width:12px;height:12px;box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;transition:left .15s;position:absolute;top:2px;left:2px}.toggle.on{background:var(--accent)}.toggle.on:after{left:14px}.bom-table{border-collapse:collapse;width:100%;font-size:11px}.bom-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);border-bottom:1px solid var(--border);background:var(--surface);padding:6px 8px;font-size:10px;font-weight:600;position:sticky;top:0}.bom-table th.num{text-align:right}.bom-table td{border-bottom:1px solid var(--border-soft);vertical-align:middle;padding:8px}.bom-table td.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.bom-table td.num{text-align:right;font-family:var(--font-mono)}.bom-table tr:hover td{background:var(--surface-2)}.bom-table .item-name{color:var(--text);font-weight:500}.bom-table .item-sub{color:var(--text-soft);font-size:10px}.total-row{border-top:1px solid var(--border);background:var(--surface-2);justify-content:space-between;align-items:baseline;padding:12px 14px;display:flex}.total-row .total-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:11px;font-weight:600}.total-row .total-amt{font-family:var(--font-mono);color:var(--text);font-variant-numeric:tabular-nums;font-size:18px;font-weight:600}.empty{text-align:center;color:var(--text-soft);padding:40px 20px;font-size:12px}.empty svg{color:var(--text-faint);margin-bottom:8px}.sel-badge{background:var(--selected);color:var(--accent);font-size:11px;font-weight:500;font-family:var(--font-mono);border-radius:4px;align-items:center;gap:6px;padding:3px 8px;display:inline-flex}@media print{@page{size:A4 landscape;margin:10mm}html,body,#root{background:#fff!important;height:auto!important;overflow:visible!important}body{margin:0}.topbar,.bottombar,.bom-toolbar,.bom-header .actions{display:none!important}.app,.bom-page{height:auto!important;min-height:0!important;display:block!important;overflow:visible!important}.bom-header{margin-bottom:12px;background:0 0!important;border-bottom:2px solid #000!important;padding:0 0 8px!important}.bom-header h1{font-size:18px!important}.bom-summary{break-after:avoid;margin-bottom:10px;padding-bottom:8px;background:0 0!important;border-bottom:1px solid #ddd!important;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))!important;gap:8px!important}.summary-card{border-radius:4px;box-shadow:none!important;background:#fafafa!important;border:1px solid #e5e5e5!important;padding:8px 10px!important}.summary-card .value{font-size:14px!important}.summary-card.total{background:#f5f5f5!important}.summary-card.total .label,.summary-card.total .value,.summary-card.total .sub{color:#000!important}.bom-tablewrap{box-shadow:none!important;border:none!important;margin:0!important;overflow:visible!important}.bom-full{table-layout:auto;width:100%;font-size:9px}.bom-full thead{display:table-header-group}.bom-full thead th{white-space:nowrap!important;background:#f5f5f5!important;border-bottom:1px solid #999!important;padding:4px 6px!important;font-size:8.5px!important;position:static!important}.bom-full tbody td{text-overflow:ellipsis;max-width:0;overflow:hidden;white-space:nowrap!important;border-bottom:1px solid #eee!important;padding:3px 6px!important}.bom-full .num,.bom-full .mono{max-width:none}.bom-full .piece-cell .ico,.bom-full .piece-cell .sub{display:none!important}.bom-full .piece-cell{display:block!important}.bom-full .piece-cell .name{text-overflow:ellipsis;overflow:hidden;white-space:nowrap!important}.bom-full .module-pill,.bom-full .material-pill{white-space:nowrap!important;background:0 0!important;border:none!important;padding:0!important}.bom-full .material-pill .dot{width:6px!important;height:6px!important}.bom-group-row{break-after:avoid}.bom-group-row td{font-weight:600;background:#f0efea!important;padding:6px 8px!important}.bom-full tbody tr{break-inside:avoid}.qty-input{color:#000!important;background:0 0!important;border:none!important;width:auto!important;padding:0!important}.bom-footer{background:0 0!important;border-top:1px solid #ddd!important;padding:10px 0!important}body[data-print-mode=taller] .summary-card.total,body[data-print-mode=taller] .bom-full thead th:nth-child(9),body[data-print-mode=taller] .bom-full thead th:nth-child(10),body[data-print-mode=taller] .bom-full tbody td:nth-child(9),body[data-print-mode=taller] .bom-full tbody td:nth-child(10),body[data-print-mode=taller] .bom-group-row td span:last-child,body[data-print-mode=taller] .bom-footer,body[data-print-mode=cliente] .bom-full thead th:nth-child(7),body[data-print-mode=cliente] .bom-full thead th:nth-child(8),body[data-print-mode=cliente] .bom-full tbody td:nth-child(7),body[data-print-mode=cliente] .bom-full tbody td:nth-child(8){display:none!important}}.home-page{background:var(--bg);min-height:0;overflow-y:auto}.home-hero{background:linear-gradient(180deg, var(--surface) 0%, var(--bg) 100%);border-bottom:1px solid var(--border);padding:28px 32px 24px}.home-hero-row{flex-wrap:wrap;align-items:flex-start;gap:24px;max-width:1400px;margin:0 auto;display:flex}.home-hero-text{flex:1;min-width:260px}.home-greet{color:var(--text-soft);letter-spacing:.02em;margin-bottom:4px;font-size:12px;font-weight:500}.home-hero h1{letter-spacing:-.02em;color:var(--text);margin:0;font-size:28px;font-weight:600;line-height:1.15}.home-hero h1 em{color:var(--accent);font-style:normal;font-weight:600}.home-hero .sub{color:var(--text-soft);text-transform:capitalize;margin-top:4px;font-size:13px}.home-hero-actions{flex-shrink:0;gap:8px;display:flex}.home-search{max-width:1400px;margin:18px auto 0}.home-search-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);height:44px;box-shadow:var(--shadow-sm);align-items:center;padding:0 16px;transition:border-color .12s,box-shadow .12s;display:flex}.home-search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #2e5bff1f}.home-search-box input{color:var(--text);background:0 0;border:none;outline:none;flex:1;margin-left:10px;font-size:14px}.home-search-box input::placeholder{color:var(--text-soft)}.home-search-box kbd{font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--border);color:var(--text-soft);border-radius:4px;padding:2px 6px;font-size:10px}.home-search-scopes{gap:4px;margin-top:8px;display:flex}.home-search-scope{height:22px;color:var(--text-soft);background:var(--surface-2);border:1px solid var(--border);cursor:pointer;border-radius:999px;align-items:center;padding:0 9px;font-size:11px;font-weight:500;display:inline-flex}.home-search-scope.active{background:var(--text);color:#fff;border-color:var(--text)}.filter-chip{height:26px;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:999px;align-items:center;gap:5px;padding:0 11px;font-size:11px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.filter-chip:hover{background:var(--hover);color:var(--text)}.filter-chip.active{background:var(--text);color:#fff;border-color:var(--text)}.home-section{max-width:1400px;margin:0 auto;padding:24px 32px}.home-section-title{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:14px;display:flex}.home-section-title h2{letter-spacing:-.005em;color:var(--text);margin:0;font-size:14px;font-weight:600}.home-section-title .meta{color:var(--text-soft);font-size:11px}.kpi-strip{background:var(--border);border:1px solid var(--border);border-radius:var(--r-lg);grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1px;margin-bottom:24px;display:grid;overflow:hidden}.kpi-cell{background:var(--surface);flex-direction:column;gap:4px;padding:14px 16px;display:flex}.kpi-cell .l{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);align-items:center;gap:5px;font-size:10px;font-weight:600;display:flex}.kpi-cell .v{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--text);letter-spacing:-.01em;font-size:22px;font-weight:600}.kpi-cell .sub{color:var(--text-soft);font-size:11px}.kpi-cell.alert{background:linear-gradient(135deg,#fef6e7,#fdf1d9)}.kpi-cell.alert .v{color:#92510b}.proj-cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.home-projects-empty{border:1px dashed var(--border-strong);border-radius:var(--r-lg);background:var(--surface-2);min-height:180px;color:var(--text-soft);text-align:left;grid-column:1/-1;justify-content:center;align-items:center;gap:14px;padding:28px;display:flex}.home-projects-empty h3{color:var(--text);margin:0 0 4px;font-size:14px;font-weight:600}.home-projects-empty p{margin:0;font-size:12px}.proj-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;flex-direction:column;transition:border-color .12s,box-shadow .12s,transform .12s;display:flex;overflow:hidden}.proj-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.proj-card-cover{background:var(--surface-2);height:140px;position:relative;overflow:hidden}.proj-card-cover svg{width:100%;height:100%;display:block}.proj-card-status{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fffffff2;border-radius:999px;align-items:center;gap:5px;padding:3px 9px;font-size:10px;font-weight:600;display:inline-flex;position:absolute;top:10px;left:10px}.proj-card-status .dot{border-radius:50%;width:6px;height:6px}.proj-card-status.status-design .dot{background:#6b7280}.proj-card-status.status-design{color:#374151}.proj-card-status.status-fab .dot{background:var(--accent)}.proj-card-status.status-fab{color:var(--accent)}.proj-card-status.status-install .dot{background:var(--warn)}.proj-card-status.status-install{color:#92510b}.proj-card-status.status-done .dot{background:var(--ok)}.proj-card-status.status-done{color:#065f46}.proj-card-budget{font-family:var(--font-mono);color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1f1b16d9;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600;position:absolute;top:10px;right:10px}.proj-card-body{flex-direction:column;gap:4px;padding:12px 14px 14px;display:flex}.proj-card-name{letter-spacing:-.01em;color:var(--text);font-size:14px;font-weight:600;line-height:1.25}.proj-card-client{color:var(--text-soft);font-size:12px}.proj-card-meta{border-top:1px solid var(--border-soft);font-family:var(--font-mono);color:var(--text-soft);gap:12px;margin-top:8px;padding-top:10px;font-size:10px;display:flex}.proj-card-meta span{align-items:center;gap:4px;display:inline-flex}.proj-card.new{border:1px dashed var(--border-strong);background:var(--surface-2);text-align:center;min-height:280px;color:var(--text-soft);justify-content:center;align-items:center;display:flex}.proj-card.new:hover{border-color:var(--accent);color:var(--accent);background:var(--selected);box-shadow:none;transform:none}.proj-card.new .icon-wrap{background:var(--surface);border:1px solid var(--border);border-radius:50%;place-items:center;width:48px;height:48px;margin:0 auto 12px;display:grid}.proj-card.new h4{color:var(--text);margin:0 0 4px;font-size:14px;font-weight:600}.proj-card.new p{margin:0;font-size:11px}.proj-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.proj-table-toolbar{border-bottom:1px solid var(--border);background:var(--surface-2);flex-wrap:wrap;align-items:center;gap:8px;padding:10px 14px;display:flex}.proj-table{border-collapse:separate;border-spacing:0;width:100%}.proj-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap;padding:10px 14px;font-size:10px;font-weight:600}.proj-table td{border-bottom:1px solid var(--border-soft);vertical-align:middle;color:var(--text);padding:12px 14px;font-size:12px}.proj-table tr:last-child td{border-bottom:none}.proj-table tr:hover td{background:var(--surface-2);cursor:pointer}.proj-table .name{align-items:center;gap:10px;font-weight:500;display:flex}.proj-table .name .swatch{border:1px solid var(--border);background-position:50%;background-size:cover;border-radius:3px;flex-shrink:0;width:28px;height:22px}.proj-table th.num,.proj-table td.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right}.proj-table .status-badge{border-radius:999px;align-items:center;gap:5px;padding:3px 8px;font-size:10px;font-weight:600;display:inline-flex}.status-badge.s-design{color:#374151;background:#f3f4f6}.status-badge.s-design .dot{background:#6b7280}.status-badge.s-fab{color:var(--accent);background:#2e5bff1a}.status-badge.s-fab .dot{background:var(--accent)}.status-badge.s-install{color:#92510b;background:#fef6e7}.status-badge.s-install .dot{background:var(--warn)}.status-badge.s-done{color:#065f46;background:#ecfdf5}.status-badge.s-done .dot{background:var(--ok)}.status-badge .dot{border-radius:50%;width:5px;height:5px}.client-cell{align-items:center;gap:8px;display:flex}.client-cell .avatar{color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:24px;height:24px;font-size:10px;font-weight:600;display:grid}.home-grid{grid-template-columns:1fr 320px;align-items:flex-start;gap:24px;display:grid}@media (width<=1100px){.home-grid{grid-template-columns:1fr}}.home-rail{flex-direction:column;gap:18px;display:flex}@media (width<=700px){.app[data-screen-label=home] .topbar{gap:4px;padding-inline:8px}.app[data-screen-label=home] .topbar .brand{padding-right:4px}.app[data-screen-label=home] .app-nav{padding:0}.app[data-screen-label=home] .app-nav button{padding-inline:8px}.app[data-screen-label=home] .topbar-actions button[title=Notificaciones],.app[data-screen-label=home] .topbar-actions button[title=Ayuda],.app[data-screen-label=home] .user-chip,.app[data-screen-label=home] .topbar>.divider-v{display:none}.app[data-screen-label=home] .topbar>.btn.accent{justify-content:center;width:32px;padding:0;font-size:0;overflow:hidden}.app[data-screen-label=home] .home-hero{padding:22px 16px 18px}.app[data-screen-label=home] .home-hero-row{flex-direction:column;gap:14px}.app[data-screen-label=home] .home-hero-text{min-width:0}.app[data-screen-label=home] .home-hero h1{font-size:24px}.app[data-screen-label=home] .home-hero-actions,.app[data-screen-label=home] .home-hero-actions label,.app[data-screen-label=home] .home-hero-actions .btn{width:100%}.app[data-screen-label=home] .home-hero-actions .btn{justify-content:center}.app[data-screen-label=home] .home-search-box kbd{display:none}.app[data-screen-label=home] .home-section{padding:18px 16px 28px}.app[data-screen-label=home] .kpi-strip,.app[data-screen-label=home] .proj-cards{grid-template-columns:1fr}}.rail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.rail-card h3{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;gap:6px;margin:0;padding:12px 14px 10px;font-size:11px;font-weight:600;display:flex}.rail-link{text-transform:none;letter-spacing:0;color:var(--accent);cursor:pointer;font-size:11px;font-weight:500}.activity-item{border-bottom:1px solid var(--border-soft);gap:10px;padding:10px 14px;font-size:12px;display:flex}.activity-item:last-child{border-bottom:none}.activity-item .icon{background:var(--surface-2);width:24px;height:24px;color:var(--text-soft);border-radius:5px;flex-shrink:0;place-items:center;display:grid}.activity-item .icon.bom{color:var(--accent);background:#2e5bff1a}.activity-item .icon.cut{color:var(--ok);background:#ecfdf5}.activity-item .icon.cli{color:#92510b;background:#fef6e7}.activity-item .icon.alert{color:var(--danger);background:#fef2f2}.activity-item .icon.project{color:var(--accent);background:#2e5bff1a}.activity-item .icon.modules{color:var(--ok);background:#ecfdf5}.activity-item .body{flex:1}.activity-item .body p{color:var(--text);margin:0;line-height:1.35}.activity-item .body .ts{color:var(--text-soft);margin-top:2px;font-size:10px}.activity-empty{color:var(--text-soft);padding:14px;font-size:12px;line-height:1.4}.shortcut-row{border-bottom:1px solid var(--border-soft);cursor:pointer;align-items:center;gap:10px;padding:10px 14px;transition:background .12s;display:flex}.shortcut-row:last-child{border-bottom:none}.shortcut-row:hover{background:var(--surface-2)}.shortcut-row .icon-wrap{background:var(--surface-2);width:32px;height:32px;color:var(--text-muted);border-radius:7px;flex-shrink:0;place-items:center;display:grid}.shortcut-row .body{flex:1}.shortcut-row .body .t{color:var(--text);font-size:12px;font-weight:500}.shortcut-row .body .s{color:var(--text-soft);margin-top:1px;font-size:10px}.shortcut-row kbd{font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--border);color:var(--text-soft);border-radius:3px;padding:1px 5px;font-size:10px}.rail-ai{background:linear-gradient(135deg,#1f1b16,#2a2722);border-color:#1f1b16}.rail-ai h3{color:#fff9;border-bottom:1px solid #ffffff14;justify-content:flex-start}.rail-ai-body{color:#ffffffd9;padding:12px 14px;font-size:12px;line-height:1.5}.rail-ai-btn{color:#fff!important;background:#ffffff1a!important;border-color:#ffffff26!important}.btn.lg{height:36px;padding:0 16px;font-size:13px;font-weight:500}.auth-shell{background:linear-gradient(135deg,#f6f4ef 0%,#fafaf8 54%,#eef2ff 100%);place-items:center;min-height:100vh;padding:28px;display:grid}.auth-layout{border-radius:var(--r-lg);background:var(--surface);border:1px solid #e5e2dae6;grid-template-columns:minmax(0,1.08fr) minmax(360px,420px);width:min(980px,100%);min-height:560px;display:grid;overflow:hidden;box-shadow:0 24px 80px #14120e24,0 4px 18px #14120e14}.auth-panel{border-right:1px solid var(--border-soft);background:linear-gradient(#ffffffd1,#f5f4f0eb),repeating-linear-gradient(90deg,#6f553814 0 1px,#0000 1px 54px);flex-direction:column;justify-content:space-between;min-width:0;padding:34px;display:flex}.auth-card{background:var(--surface);align-self:center;width:100%;padding:38px 34px}.auth-card.compact{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);width:260px;box-shadow:var(--shadow-lg);color:var(--text-soft);justify-items:center;gap:12px;font-size:13px;display:grid}.brand-mark.large{width:42px;height:42px;font-size:13px}.auth-brand{align-items:center;gap:12px;display:flex}.auth-brand h1,.auth-copy h2,.auth-hero-copy h2{color:var(--text);margin:0}.auth-brand h1{font-size:18px}.auth-brand p,.auth-copy p,.auth-alt,.auth-hero-copy p{color:var(--text-soft);margin:0;font-size:12px;line-height:1.45}.auth-copy{margin-bottom:16px}.auth-copy h2{letter-spacing:0;margin-bottom:5px;font-size:24px}.auth-hero-copy{max-width:440px}.auth-hero-copy>span{background:var(--accent-soft);height:24px;color:var(--accent);border:1px solid #d9e2ff;border-radius:999px;align-items:center;margin-bottom:14px;padding:0 9px;font-size:11px;font-weight:650;display:inline-flex}.auth-hero-copy h2{max-width:480px;font-size:34px;line-height:1.08}.auth-hero-copy p{max-width:390px;color:var(--text-muted);margin-top:12px;font-size:13px}.auth-feature-list{color:var(--text-muted);gap:10px;font-size:12px;display:grid}.auth-feature-list div{align-items:center;gap:9px;display:flex}.auth-feature-list svg{color:var(--accent)}.auth-test-account{border-radius:var(--r-md);background:var(--accent-soft);width:100%;min-height:42px;color:var(--accent);text-align:left;border:1px solid #d9e2ff;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:8px 10px;display:flex}.auth-test-account:hover{background:#dfe8ff}.auth-test-account span{color:var(--text-muted);font-size:12px;font-weight:600}.auth-test-account strong{font-family:var(--font-mono);font-size:12px;font-weight:650}.auth-form{gap:14px;display:grid}.auth-form label span{color:var(--text-muted);margin-bottom:5px;font-size:11px;font-weight:600;display:block}.auth-input{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);height:42px;color:var(--text-soft);align-items:center;gap:8px;padding:0 10px;transition:border-color .12s,box-shadow .12s,background .12s;display:flex}.auth-input:focus-within{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px #2e5bff1f}.auth-input input{min-width:0;color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:13px}.auth-input button{color:var(--text-soft);cursor:pointer;background:0 0;border:none;place-items:center;padding:0;display:grid}.auth-input button:hover{color:var(--text)}.auth-error{color:var(--danger);border-radius:var(--r-md);background:#fef2f2;border:1px solid #dc26262e;padding:8px 10px;font-size:12px}.auth-submit{justify-content:center;width:100%;height:42px;margin-top:2px}.auth-alt{text-align:center;margin-top:18px}.auth-alt a{color:var(--accent);font-weight:600;text-decoration:none}@media (width<=820px){.auth-shell{padding:16px}.auth-layout{grid-template-columns:1fr;min-height:0}.auth-panel{border-right:none;border-bottom:1px solid var(--border-soft);gap:28px;padding:24px}.auth-hero-copy h2{font-size:26px}.auth-card{padding:26px 24px}}.render-style-control{border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffeb;align-items:center;gap:2px;padding:3px;display:inline-flex}.render-style-control button{border-radius:var(--r-sm);height:28px;color:var(--text-soft);cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;gap:5px;padding:0 8px;font-size:10px;font-weight:650;display:inline-flex}.render-style-control button:hover{color:var(--text);background:var(--surface-2)}.render-style-control button.active{color:var(--accent);background:var(--accent-soft)}.render-style-control.compact button{width:28px;padding:0}@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}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@keyframes spin{to{transform:rotate(360deg)}}.public-model-page{background:var(--bg);min-height:100vh;color:var(--text);grid-template-rows:auto 1fr;display:grid}.public-model-header{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:14px;min-height:76px;padding:14px clamp(18px,4vw,52px);display:flex}.public-model-header h1{font-size:20px;font-weight:750}.public-model-header p{color:var(--text-soft);margin-top:3px;font-size:12px}.public-model-render-style{margin-left:auto}.public-model-brand{border-radius:var(--r-md);color:#fff;background:#191918;flex:none;place-items:center;width:34px;height:34px;font-size:11px;font-weight:800;text-decoration:none;display:grid}.public-model-workspace{grid-template-columns:minmax(0,1fr) minmax(280px,360px);min-height:0;display:grid}.public-model-viewer{background:#d7dce1;min-height:560px}.public-model-controls{border-left:1px solid var(--border);background:var(--surface);flex-direction:column;gap:20px;padding:28px;display:flex;overflow-y:auto}.public-model-controls h2{margin-top:5px;font-size:20px;font-weight:750}.public-model-controls p{color:var(--text-soft);margin-top:6px;font-size:12px;line-height:1.5}.public-model-eyebrow{color:var(--accent);text-transform:uppercase;font-size:10px;font-weight:750}.public-dimension-control{gap:9px;display:grid}.public-dimension-control>span{justify-content:space-between;font-size:12px;display:flex}.public-dimension-control output{font-family:var(--font-mono);font-weight:650}.public-dimension-control input{width:100%;accent-color:var(--accent)}.public-dimension-control small{color:var(--text-faint);font-family:var(--font-mono);justify-content:space-between;display:flex}.public-model-summary{border:1px solid var(--border-soft);border-radius:var(--r-md);background:var(--surface-2);color:var(--text-soft);justify-content:space-between;gap:12px;padding:12px;font-size:11px;display:flex}.public-model-summary strong{color:var(--text);font-family:var(--font-mono)}.public-model-downloads{gap:8px;display:grid}.public-model-downloads .btn{justify-content:center;width:100%}.public-model-cta{border-radius:var(--r-md);background:var(--accent-soft);color:var(--text-soft);text-align:center;border:1px solid #d9e2ff;padding:12px;font-size:12px;line-height:1.5}.public-model-cta a{color:var(--accent);font-weight:650;text-decoration:none}.public-model-state,.public-model-lock-page{background:var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.public-model-state{color:var(--text-soft);align-content:center;gap:10px}.public-model-lock{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);width:min(440px,100%);box-shadow:var(--shadow-lg);justify-items:start;gap:14px;padding:28px;display:grid}.public-model-lock h1{font-size:24px;font-weight:760}.public-model-lock p{color:var(--text-soft);line-height:1.55}.public-model-note{padding-top:4px;font-size:12px}.public-coupon-form{gap:7px;width:100%;display:grid}.public-coupon-form label{font-size:12px;font-weight:650}.public-coupon-form>div{grid-template-columns:1fr auto;gap:7px;display:grid}.public-coupon-form input{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);min-width:0;height:38px;padding:0 10px}.public-model-error{border-radius:var(--r-md);width:100%;color:var(--danger);background:var(--danger-soft);padding:10px 12px;font-size:12px}@media (width<=760px){.public-model-header{flex-wrap:wrap}.public-model-render-style{width:100%;margin-left:48px}.public-model-workspace{grid-template-rows:minmax(380px,52vh) auto;grid-template-columns:1fr}.public-model-viewer{min-height:380px}.public-model-controls{border-left:0;border-top:1px solid var(--border);padding:20px}.public-model-summary{flex-direction:column}}.public-library-page{background:var(--bg);min-height:100vh;color:var(--text);padding-bottom:48px}.public-library-header{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;min-height:64px;padding:10px clamp(18px,5vw,72px);display:flex}.public-library-wordmark{color:var(--text);align-items:center;gap:10px;text-decoration:none;display:flex}.public-library-wordmark span{border-radius:var(--r-md);color:#fff;background:#191918;place-items:center;width:32px;height:32px;font-size:10px;font-weight:800;display:grid}.public-library-intro,.public-library-toolbar,.public-library-grid,.public-library-state{width:min(1180px,100% - 36px);margin-inline:auto}.public-library-intro{justify-content:space-between;align-items:end;gap:28px;padding:56px 0 30px;display:flex}.public-library-intro h1{margin-top:7px;font-size:clamp(30px,4vw,48px);font-weight:760;line-height:1.05}.public-library-intro p{max-width:610px;color:var(--text-soft);margin-top:12px;line-height:1.55}.public-library-intro>strong{color:var(--text-soft);white-space:nowrap;padding-bottom:5px;font-size:12px}.public-library-toolbar{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);justify-content:space-between;align-items:center;gap:14px;padding:12px;display:flex}.public-library-search{min-width:260px;color:var(--text-faint);flex:1;align-items:center;gap:9px;display:flex}.public-library-search input{width:100%;min-width:0;color:var(--text);background:0 0;border:0;outline:0}.public-library-filters{color:var(--text-faint);align-items:center;gap:4px;display:flex}.public-library-filters button{border-radius:var(--r-sm);height:30px;color:var(--text-soft);cursor:pointer;background:0 0;border:1px solid #0000;padding:0 10px;font-size:11px}.public-library-filters button:hover{background:var(--surface-2);color:var(--text)}.public-library-filters button.active{border-color:var(--border);background:var(--surface-2);color:var(--text);font-weight:650}.public-library-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;padding-top:20px;display:grid}.public-library-card{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);overflow:hidden}.public-library-preview{background:#d8dde1;place-items:center;min-height:245px;display:grid;position:relative;overflow:hidden}.public-library-preview:after{content:"";background:#b9945f;position:absolute;inset:68% -15% -25%;transform:rotate(-4deg)}.public-library-cabinet{--cabinet-ratio:.84;--cabinet-depth:24px;z-index:1;width:calc(128px * var(--cabinet-ratio));height:148px;box-shadow:var(--cabinet-depth) 12px 0 #c5c4bd, 0 18px 28px #282d3229;background:#eeeee9;border:2px solid #a5a39d;grid-template-columns:1fr 1fr;display:grid;position:relative;transform:skewY(-1deg)}.public-library-cabinet:before{content:"";left:-2px;right:calc(-1 * var(--cabinet-depth));top:calc(-1 * var(--cabinet-depth) / 2);height:calc(var(--cabinet-depth) / 2);transform-origin:0 100%;background:#f8f8f5;border:1px solid #aaa9a3;position:absolute;transform:skew(-54deg)}.public-library-cabinet span{border-right:1px solid #c7c6c0}.public-library-cabinet span:last-child{border-right:0}.public-library-access{z-index:2;border-radius:var(--r-sm);color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffe0;border:1px solid #ffffffa6;align-items:center;gap:5px;padding:6px 8px;font-size:10px;font-weight:650;display:flex;position:absolute;top:12px;right:12px}.public-library-access.free{color:#087a55}.public-library-access.coupon{color:#9a5700}.public-library-card-body{flex-direction:column;justify-content:space-between;gap:18px;min-height:180px;padding:18px;display:flex}.public-library-card-body p{color:var(--text-faint);font-size:10px}.public-library-card-body h2{margin-top:5px;font-size:17px;font-weight:720}.public-library-card-body>div>span{color:var(--text-soft);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:7px;font-size:12px;line-height:1.45;display:-webkit-box;overflow:hidden}.public-library-card-footer{justify-content:space-between;align-items:center;gap:12px;display:flex}.public-library-card-footer code{color:var(--text-soft);font-size:10px}.public-library-state{min-height:280px;color:var(--text-soft);align-content:center;place-items:center;gap:8px;display:grid}.public-library-state.error{color:var(--danger)}@media (width<=900px){.public-library-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=640px){.public-library-header{padding-inline:18px}.public-library-intro{flex-direction:column;align-items:start;padding-top:38px}.public-library-toolbar{flex-direction:column;align-items:stretch}.public-library-search{min-width:0;padding:5px}.public-library-filters{width:100%;overflow-x:auto}.public-library-grid{grid-template-columns:1fr}.public-library-preview{min-height:220px}}
