*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Plus Jakarta Sans,Segoe UI,system-ui,-apple-system,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:DM Mono,Consolas,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--k-background:42 50% 96%;--k-foreground:24 13% 15%;--k-card:40 50% 99%;--k-card-foreground:24 13% 15%;--k-popover:40 50% 99%;--k-popover-foreground:24 13% 15%;--k-primary:119 25% 39%;--k-primary-foreground:40 50% 97%;--k-secondary:36 53% 54%;--k-secondary-foreground:28 38% 16%;--k-muted:40 38% 92%;--k-muted-foreground:28 13% 38%;--k-accent:40 38% 89%;--k-accent-foreground:24 13% 15%;--k-destructive:6 63% 46%;--k-destructive-foreground:40 50% 97%;--k-border:38 32% 84%;--k-input:38 32% 84%;--k-ring:119 25% 39%;--k-emas-mid:36 60% 60%;--k-border-strong:36 26% 76%;--k-success:130 40% 36%;--radius:0.625rem;--bg:hsl(var(--k-background));--surface:hsl(var(--k-card));--surface-2:hsl(var(--k-muted));--text:hsl(var(--k-foreground));--text-2:hsl(var(--k-muted-foreground));--muted:hsl(var(--k-muted-foreground)/0.82);--border:hsl(var(--k-border));--border2:hsl(var(--k-border-strong));--emas:hsl(var(--k-secondary));--emas-light:hsl(var(--k-secondary)/0.16);--emas-mid:hsl(var(--k-emas-mid));--teal:hsl(var(--k-primary));--teal-light:hsl(var(--k-primary)/0.15);--danger:hsl(var(--k-destructive));--danger-light:hsl(var(--k-destructive)/0.14);--success:hsl(var(--k-success));--on-emas:hsl(var(--k-secondary-foreground));--panel:hsl(var(--k-card));--topbar-bg:hsl(var(--k-card));--hitam:#2c231b;--font-body:"Plus Jakarta Sans","Segoe UI",system-ui,-apple-system,sans-serif;--font-mono:"DM Mono","Consolas","Courier New",monospace;--sidebar-width:280px;--transition:0.2s ease;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--shadow-sm:0 1px 2px rgba(66,50,36,.06);--shadow-md:0 4px 16px rgba(66,50,36,.08);--shadow-lg:0 20px 50px rgba(60,45,32,.18)}.dark{--k-background:26 16% 9%;--k-foreground:40 44% 91%;--k-card:30 16% 12%;--k-card-foreground:40 44% 91%;--k-popover:30 16% 12%;--k-popover-foreground:40 44% 91%;--k-primary:112 27% 56%;--k-primary-foreground:30 25% 10%;--k-secondary:37 66% 65%;--k-secondary-foreground:30 30% 12%;--k-muted:32 18% 16%;--k-muted-foreground:33 22% 70%;--k-accent:32 18% 19%;--k-accent-foreground:40 44% 91%;--k-destructive:6 60% 52%;--k-destructive-foreground:40 44% 95%;--k-border:28 16% 20%;--k-input:28 16% 23%;--k-ring:112 27% 56%;--k-emas-mid:37 70% 72%;--k-border-strong:28 14% 28%;--k-success:130 38% 56%;--hitam:#171412}*{border-color:var(--border)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}svg{vertical-align:middle;flex-shrink:0}::-moz-selection{background:hsl(var(--k-primary)/.22)}::selection{background:hsl(var(--k-primary)/.22)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:hsl(var(--k-muted-foreground)/.3);border-radius:8px;border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:hsl(var(--k-muted-foreground)/.5);background-clip:content-box}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.app-topbar{position:sticky;top:0;z-index:200;height:56px;background:hsl(var(--k-card)/.85);-webkit-backdrop-filter:saturate(140%) blur(10px);backdrop-filter:saturate(140%) blur(10px);display:flex;align-items:center;padding:0 18px 0 14px;gap:12px;border-bottom:1px solid var(--border);flex-shrink:0}.topbar-menu-btn{display:none;background:none;border:none;color:var(--text-2);cursor:pointer;padding:7px;border-radius:var(--radius-sm);line-height:1;flex-shrink:0;font-family:inherit;transition:background .15s,color .15s}.topbar-menu-btn:hover{background:var(--surface-2);color:var(--text)}.topbar-brand-link{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;transition:opacity .15s}.topbar-brand-link:hover{opacity:.8}.topbar-brand-mark{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:linear-gradient(140deg,var(--teal),hsl(var(--k-primary)/.7));color:var(--k-primary-foreground,#fff);flex-shrink:0;box-shadow:var(--shadow-sm)}.topbar-brand-text{display:flex;flex-direction:column;gap:1px}.topbar-logo{font-size:8px;letter-spacing:.18em;color:var(--emas);font-weight:800;text-transform:uppercase;line-height:1}.topbar-page{font-size:12px;color:var(--text-2);line-height:1.1;font-weight:500}.topbar-sep{width:1px;height:22px;background:var(--border);flex-shrink:0}.topbar-bc{flex:1;font-size:13.5px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;letter-spacing:-.01em}.topbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.topbar-btn{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);color:var(--text-2);font-size:12.5px;font-weight:500;padding:7px 13px;border-radius:var(--radius-md);cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}.topbar-btn:hover{border-color:var(--border2);color:var(--text);background:var(--surface-2)}.topbar-btn-primary{display:inline-flex;align-items:center;gap:6px;background:var(--teal);border:1px solid transparent;color:var(--k-primary-foreground,#fff);font-size:12.5px;font-weight:700;padding:7px 16px;border-radius:var(--radius-md);cursor:pointer;font-family:inherit;transition:filter .15s,transform .1s,box-shadow .15s;white-space:nowrap;box-shadow:var(--shadow-sm)}.topbar-btn-primary:hover{filter:brightness(1.06);box-shadow:var(--shadow-md)}.topbar-btn-primary:active{transform:scale(.98)}.topbar-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--surface);border:1px solid var(--border);color:var(--text-2);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;transition:all .15s;flex-shrink:0}.topbar-icon-btn:hover{border-color:var(--border2);color:var(--text);background:var(--surface-2)}.theme-icon-sun{display:none}.dark .theme-icon-sun{display:inline-flex}.dark .theme-icon-moon{display:none}.app{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh}.sidebar{background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:56px;height:calc(100vh - 56px);overflow:hidden;z-index:10}.sidebar-brand{padding:16px 16px 13px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-back{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);text-decoration:none;margin-bottom:11px;transition:color .15s}.sidebar-back:hover{color:var(--teal)}.sidebar-brand .logo-text{font-size:9px;letter-spacing:.16em;color:var(--emas);font-weight:800;margin-bottom:3px;text-transform:uppercase}.sidebar-brand h1{font-size:15px;color:var(--text);font-weight:800;line-height:1.25;letter-spacing:-.01em}.sidebar-brand p{font-size:11px;color:var(--muted);margin-top:3px}.sidebar-search{padding:10px 12px 8px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-search input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-md);padding:8px 10px 8px 32px;font-size:12.5px;font-family:inherit;transition:all .15s;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23998' stroke-width='2' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:10px}.sidebar-search input:focus{outline:none;border-color:hsl(var(--k-ring));box-shadow:0 0 0 3px hsl(var(--k-ring)/.18)}.sidebar-search input::-moz-placeholder{color:var(--muted)}.sidebar-search input::placeholder{color:var(--muted)}.cat-accordion{border-bottom:1px solid var(--border);flex-shrink:0}.cat-acc-header{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .15s}.cat-acc-header:hover{background:var(--surface-2)}.cat-acc-title{font-size:9px;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}.cat-acc-chevron{font-size:11px;color:var(--muted);transition:color .15s;line-height:1}.cat-acc-header:hover .cat-acc-chevron{color:var(--text-2)}.cat-acc-body{padding:3px 0 5px;max-height:220px;overflow-y:auto}.cat-list-item{display:flex;align-items:center;width:100%;padding:6px 14px;background:none;border:none;cursor:pointer;font-family:inherit;gap:8px;transition:background .12s;text-align:left}.cat-list-item:hover{background:var(--surface-2)}.cat-list-item.active{background:var(--emas-light)}.cat-list-dot{width:6px;height:6px;border-radius:50%;background:var(--border2);flex-shrink:0;transition:background .15s}.cat-list-item.active .cat-list-dot{background:var(--emas)}.cat-list-item:first-child .cat-list-dot{display:none}.cat-list-name{font-size:12px;color:var(--text-2);flex:1;font-weight:500;transition:color .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-list-item:hover .cat-list-name{color:var(--text)}.cat-list-item.active .cat-list-name{color:hsl(var(--k-secondary-foreground));font-weight:700}.dark .cat-list-item.active .cat-list-name{color:var(--emas-mid)}.cat-list-count{font-size:10px;color:var(--muted);background:var(--surface-2);padding:1px 7px;border-radius:10px;font-weight:700;min-width:20px;text-align:center;flex-shrink:0;transition:all .12s}.cat-list-item.active .cat-list-count{background:var(--emas);color:var(--on-emas)}.sop-sec-chips{display:flex;flex-wrap:wrap;gap:3px;margin-top:6px}.sop-sec-chip{width:7px;height:7px;border-radius:2px;flex-shrink:0}.produk-list{flex:1;padding:6px 10px 8px;overflow-y:auto;min-height:0}.cat-group-header{font-size:9px;letter-spacing:.13em;color:var(--muted);font-weight:800;padding:9px 4px 5px;text-transform:uppercase;display:flex;align-items:center;gap:6px}.cat-group-header span{color:var(--border2)}.produk-item{display:flex;align-items:center;gap:7px;padding:8px 9px;border-radius:var(--radius-md);cursor:pointer;margin-bottom:3px;transition:background .15s,border-color .15s;border:1px solid transparent;-webkit-user-select:none;-moz-user-select:none;user-select:none}.produk-item:hover{background:var(--surface-2)}.produk-item.active{background:var(--emas-light);border-color:hsl(var(--k-secondary)/.4)}.produk-item.dragging{opacity:.4;border:1px dashed var(--border2)}.produk-item.drag-over{border:1px dashed var(--emas);background:var(--emas-light)}.drag-handle{color:var(--border2);font-size:13px;cursor:grab;padding:0 2px;flex-shrink:0;line-height:1;transition:color .15s}.produk-item:hover .drag-handle{color:var(--muted)}.drag-handle:active{cursor:grabbing}.produk-item .kode{font-size:9.5px;color:var(--emas);font-weight:600;letter-spacing:.03em;min-width:24px;font-family:var(--font-mono)}.produk-item .nama-item{font-size:12.5px;color:var(--text-2);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.produk-item.active .nama-item{color:var(--text);font-weight:600}.produk-item .del-btn,.produk-item .dup-btn{min-width:32px;min-height:32px;width:32px;height:32px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);opacity:0;transition:opacity .15s,background .15s,color .15s;flex-shrink:0;color:var(--muted)}.produk-item:hover .del-btn,.produk-item:hover .dup-btn{opacity:1}.produk-item .del-btn:hover{background:var(--danger-light);color:var(--danger)}.produk-item .dup-btn:hover{background:var(--emas-light);color:var(--emas)}@media (hover:none){.produk-item .del-btn,.produk-item .dup-btn{opacity:.7}}.sidebar-footer{padding:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;flex-shrink:0;background:var(--panel)}.btn-generate{width:100%;background:var(--teal);color:var(--k-primary-foreground,#fff);border:none;padding:11px 16px;border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:700;letter-spacing:.01em;transition:filter .15s,transform .1s,box-shadow .15s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:7px;box-shadow:var(--shadow-sm)}.btn-generate:hover{filter:brightness(1.06);box-shadow:var(--shadow-md)}.btn-generate:active{transform:scale(.98)}.sidebar-footer-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.btn-export-json,.btn-tambah-footer{background:var(--surface);color:var(--text-2);border:1px solid var(--border);padding:8px;border-radius:var(--radius-md);cursor:pointer;font-size:11px;font-weight:500;transition:all .15s;font-family:inherit;text-align:center;display:flex;align-items:center;justify-content:center;gap:5px}.btn-export-json:hover{border-color:var(--border2);color:var(--text);background:var(--surface-2)}.btn-tambah-footer:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}.main{padding:32px 36px 96px;max-width:940px;min-height:100vh}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:64vh;color:var(--muted);text-align:center;padding:40px 20px}.empty-state .icon{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;background:var(--surface-2);color:var(--teal);margin-bottom:18px}.empty-state h2{font-size:17px;font-weight:700;color:var(--text);margin-bottom:6px}.empty-state p{font-size:13.5px;line-height:1.65;max-width:280px}.form-grid{display:grid;gap:16px}.form-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.form-section-header{padding:11px 16px 11px 14px;background:hsl(var(--k-muted)/.5);border-bottom:1px solid var(--border);border-left:3px solid var(--sec-color,var(--border2));font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);display:flex;align-items:center;gap:8px}.sec-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.form-section-body{padding:16px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:12px}.form-row:last-child{margin-bottom:0}.form-group{display:flex;flex-direction:column;gap:5px}label{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.07em;text-transform:uppercase}input[type=date],input[type=number],input[type=text],select,textarea{background:var(--bg);border:1px solid var(--input);border-radius:var(--radius-md);padding:9px 11px;font-size:13px;color:var(--text);font-family:inherit;transition:border-color .15s,box-shadow .15s,background .15s;width:100%}input[type=date]:focus,input[type=number]:focus,input[type=text]:focus,select:focus,textarea:focus{outline:none;border-color:hsl(var(--k-ring));box-shadow:0 0 0 3px hsl(var(--k-ring)/.18);background:var(--surface)}input::-moz-placeholder,textarea::-moz-placeholder{color:var(--muted)}input::placeholder,textarea::placeholder{color:var(--muted)}textarea{resize:vertical;min-height:62px;line-height:1.55}.field-error{border-color:var(--danger)!important;box-shadow:0 0 0 3px var(--danger-light)!important}.field-error-msg{font-size:10.5px;color:var(--danger);font-weight:600;text-transform:none;letter-spacing:0}.dynamic-list{display:flex;flex-direction:column;gap:8px}.bahan-row{display:grid;grid-template-columns:1fr 110px 32px;gap:8px;align-items:center}.langkah-row{display:grid;grid-template-columns:28px 1fr 32px;gap:8px;align-items:flex-start}.langkah-num{width:28px;height:28px;background:var(--teal-light);color:var(--teal);border-radius:50%;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-top:6px;flex-shrink:0}.catatan-row{display:grid;grid-template-columns:1fr 32px;gap:8px;align-items:center}.btn-row-del{min-width:32px;min-height:32px;width:32px;height:32px;background:none;border:1px solid var(--border);color:var(--muted);border-radius:var(--radius-sm);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;margin-top:4px;font-family:inherit}.btn-row-del:hover{background:var(--danger-light);border-color:var(--danger);color:var(--danger)}.btn-add-row{margin-top:6px;background:none;border:1px dashed var(--border2);color:var(--muted);padding:9px 12px;border-radius:var(--radius-md);cursor:pointer;font-size:12px;width:100%;transition:all .15s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px;font-weight:500}.btn-add-row:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light)}.revisi-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:var(--radius-md)}.revisi-table{width:100%;border-collapse:collapse;font-size:12px;min-width:380px}.revisi-table th{background:var(--surface-2);padding:8px 10px;text-align:left;font-size:10px;font-weight:800;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}.revisi-table td,.revisi-table th{border-bottom:1px solid var(--border)}.revisi-table td{padding:6px;vertical-align:middle}.revisi-table tr:last-child td{border-bottom:none}.revisi-table td input[type=text]{padding:6px 8px;font-size:12px}.revisi-table .td-del{width:32px;text-align:center}.revisi-table .rev-num{width:56px}.revisi-table .rev-tgl{width:110px}.gula-opsi-group{display:flex;flex-wrap:wrap;gap:7px;margin-top:2px}.gula-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border:1.5px solid var(--border);border-radius:20px;cursor:pointer;font-size:12px;font-weight:600;color:var(--text-2);background:var(--bg);transition:all .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.gula-pill.active,.gula-pill:hover{border-color:var(--teal);color:var(--teal)}.gula-pill.active{background:var(--teal-light);font-weight:700}.gula-pill input{display:none}.gula-default-badge{display:inline-block;background:var(--emas);color:var(--on-emas);font-size:9px;font-weight:800;padding:1px 6px;border-radius:8px;margin-left:3px;letter-spacing:.04em}.gula-hint{font-size:11px;color:var(--muted);margin-top:6px}.bahan-matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:var(--radius-md)}.bahan-matrix{width:100%;border-collapse:collapse;min-width:360px}.bahan-matrix th{background:var(--surface-2);padding:8px 10px;text-align:left;font-size:10px;font-weight:800;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap}.bahan-matrix th:not(:first-child){text-align:center}.bahan-matrix td{padding:5px 6px;border-bottom:1px solid var(--border);vertical-align:middle}.bahan-matrix tr:last-child td{border-bottom:none}.bahan-matrix td:first-child{min-width:130px}.bahan-matrix input{padding:7px 9px;font-size:12.5px}.bahan-matrix .td-del{width:36px;text-align:center}.bahan-matrix th:last-child{width:36px}.toast{position:fixed;bottom:24px;right:24px;background:var(--surface);color:var(--text);padding:13px 18px;border-radius:var(--radius-md);font-size:13px;font-weight:500;opacity:0;transform:translateY(8px);transition:all .25s;pointer-events:none;z-index:9999;border:1px solid var(--border);border-left:3px solid var(--teal);max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg)}.toast.show{opacity:1;transform:translateY(0)}.toast.success{border-left-color:var(--success)}.toast.error{border-left-color:var(--danger)}.form-actions{position:sticky;bottom:0;z-index:50;display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:20px -36px -96px;padding:14px 36px;background:hsl(var(--k-card)/.9);-webkit-backdrop-filter:saturate(140%) blur(10px);backdrop-filter:saturate(140%) blur(10px);border-top:1px solid var(--border)}.btn-save{background:var(--teal);color:var(--k-primary-foreground,#fff);border:none;padding:10px 22px;border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:700;transition:filter .15s,transform .1s,box-shadow .15s;font-family:inherit;box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:7px}.btn-save:hover{filter:brightness(1.06);box-shadow:var(--shadow-md)}.btn-save:active{transform:scale(.98)}.btn-reset{background:var(--surface);border:1px solid var(--border);color:var(--text-2);padding:10px 16px;border-radius:var(--radius-md);cursor:pointer;font-size:13px;transition:all .15s;font-family:inherit}.btn-reset:hover{border-color:var(--border2);color:var(--text);background:var(--surface-2)}.badge-saved{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--success);opacity:0;transition:opacity .3s;align-self:center}.badge-saved.visible{opacity:1}.badge-saved.\!visible{opacity:1!important}.save-dirty-dot{margin-left:auto;font-size:11.5px;color:var(--muted);display:inline-flex;align-items:center;gap:6px}.save-dirty-dot:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--emas)}.gen-modal,.import-area{position:fixed;inset:0;background:rgba(31,25,20,.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:1000;padding:16px}.gen-modal.open,.import-area.open{display:flex}.import-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.import-box h3{font-size:16px;margin-bottom:12px;font-weight:800;color:var(--text)}.import-box textarea{height:180px;margin-bottom:12px;font-family:var(--font-mono);font-size:12px}.import-box .actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.btn-sm{padding:8px 15px;border-radius:var(--radius-md);font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);font-family:inherit;transition:all .15s;white-space:nowrap}.btn-sm:hover{background:var(--surface-2);border-color:var(--border2)}.btn-sm.primary{background:var(--teal);color:var(--k-primary-foreground,#fff);border-color:transparent}.btn-sm.primary:hover{filter:brightness(1.06)}.gen-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px 20px;width:100%;max-width:320px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.gen-box-wide{max-width:440px}.gen-box h3{font-size:16px;font-weight:800;margin-bottom:6px;color:var(--text)}.gen-box>p{font-size:12.5px;color:var(--muted);margin-bottom:12px;line-height:1.55}.gen-section-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-2);margin:4px 0;padding:7px 10px;background:var(--surface-2);border-radius:var(--radius-sm);border-left:3px solid var(--teal);display:flex;align-items:center;gap:7px}.gen-section-desc{font-size:11px;color:var(--muted);margin:4px 0 10px;line-height:1.5}.gen-divider{border:none;border-top:1px dashed var(--border2);margin:16px 0}.gen-options{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.gen-opt{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 14px;border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;background:var(--bg);transition:all .15s;font-size:12px;font-weight:700;color:var(--text-2);font-family:inherit}.gen-opt:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light);transform:translateY(-2px)}.gen-opt-rev:hover{border-color:var(--emas);color:var(--emas);background:var(--emas-light)}.gen-opt .gen-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px}.gen-opt .gen-label{font-size:13px;color:inherit}.gen-opt .gen-sub{font-size:10px;font-weight:500}.gen-cancel{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text-2);padding:9px;border-radius:var(--radius-md);cursor:pointer;font-size:12px;font-weight:600;transition:all .15s;font-family:inherit;margin-top:4px}.gen-cancel:hover{border-color:var(--border2);color:var(--text);background:var(--surface-2)}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(31,25,20,.5);z-index:140;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-overlay.open{display:block}.multi-toggle-row{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:14px;flex-wrap:wrap}.multi-toggle-row span{font-size:12.5px;color:var(--text);font-weight:600;flex:1}.toggle-switch{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--border2);border-radius:24px;cursor:pointer;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}.toggle-switch input:checked+.toggle-slider{background:var(--teal)}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(18px)}.varian-tab.active{color:var(--teal);border-bottom-color:var(--teal);background:var(--teal-light)}.varian-tab-panel.active{display:block}.varian-panel-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px}.mesin-gula-section{margin-top:18px;padding-top:16px;border-top:1px dashed var(--border2)}.mesin-gula-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:6px}.mesin-config-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.mesin-config-row .form-group label{margin-bottom:4px}.mesin-baris-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.mesin-baris-row{display:flex;align-items:center;gap:6px}.mesin-baris-row input{flex:1}.mesin-grid-preview{margin-top:14px;overflow-x:auto;-webkit-overflow-scrolling:touch}.mesin-grid-preview table{border-collapse:collapse;font-size:11px;min-width:200px}.mesin-grid-preview th{background:var(--surface-2);color:var(--text-2);font-size:10px;letter-spacing:.04em}.mesin-grid-preview td,.mesin-grid-preview th{padding:6px 10px;text-align:center;border:1px solid var(--border);font-weight:700}.mesin-grid-preview td{min-width:48px;font-size:11px}.mesin-grid-preview td.row-label{font-weight:800;font-size:10px;letter-spacing:.04em;text-align:right;padding-right:8px}.mesin-cell-empty,.mesin-grid-preview td.row-label{background:var(--surface-2);color:var(--muted)}.mesin-cell-toggle{cursor:pointer;transition:outline .1s}.mesin-cell-toggle:hover{outline:2px solid var(--teal);outline-offset:-2px}.mesin-grid-preview td.mesin-cell-empty.mesin-cell-toggle:hover{background:var(--teal-light);color:var(--teal)}.mesin-grid-legend{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--muted)}.legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}.legend-dot.large{background:var(--hitam)}.legend-dot.medium{background:var(--teal)}.legend-dot.small{background:var(--emas)}.peran-row{display:grid;grid-template-columns:1fr 2fr 32px;gap:8px;align-items:center}.foto-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.foto-item{gap:6px}.foto-item,.foto-slot{display:flex;flex-direction:column}.foto-slot{background:var(--bg);border:1.5px dashed var(--border2);border-radius:var(--radius-md);height:110px;align-items:center;justify-content:center;gap:5px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden}.foto-slot:hover{border-color:var(--teal);background:var(--teal-light)}.foto-slot img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:calc(var(--radius-md) - 1px)}.foto-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .12s;color:#fff;font-size:12px;font-weight:600}.foto-slot:hover .foto-overlay{opacity:1}.foto-hint,.foto-icon{color:var(--muted)}.foto-hint{font-size:10.5px}.foto-remove{position:absolute;top:6px;right:6px;width:24px;height:24px;background:rgba(0,0,0,.55);color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .12s}.foto-slot:hover .foto-remove{opacity:1}.foto-caption{font-size:11.5px}@media (hover:none){.foto-overlay{opacity:1;background:rgba(0,0,0,.18)}.foto-remove{opacity:.9}}.temuan-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.section-toggles{display:flex;flex-wrap:wrap;gap:8px}.toggle-sec{padding:6px 14px;border-radius:20px;font-size:11.5px;font-weight:600;background:var(--bg);border:1.5px solid var(--border);color:var(--text-2);cursor:pointer;transition:all .15s;font-family:inherit}.toggle-sec.on,.toggle-sec:hover{border-color:var(--teal);color:var(--teal)}.toggle-sec.on{background:var(--teal-light);font-weight:700}.area-row{display:grid;grid-template-columns:1fr 46px 2fr 32px;gap:7px;align-items:center;margin-bottom:6px}.area-foto-slot{background:var(--bg);border:1.5px dashed var(--border2);border-radius:var(--radius-sm);height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);position:relative;overflow:hidden;transition:border-color .12s}.area-foto-slot:hover{border-color:var(--teal)}.area-foto-slot img{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sb-row{display:grid;grid-template-columns:1fr 1fr 32px;gap:7px;align-items:center;margin-bottom:6px}.inp-salah{border-color:var(--danger)!important;background:var(--danger-light)!important}.inp-salah:focus{box-shadow:0 0 0 3px var(--danger-light)!important}.inp-benar{border-color:var(--success)!important;background:hsl(var(--k-success)/.1)!important}.inp-benar:focus{box-shadow:0 0 0 3px hsl(var(--k-success)/.16)!important}.tabel-row{display:grid;grid-template-columns:1fr 2fr 32px;gap:7px;align-items:center;margin-bottom:6px}.loading-overlay{position:fixed;inset:0;background:hsl(var(--k-background)/.92);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2000;gap:14px;font-size:13px;color:var(--muted)}.loading-overlay.hidden{display:none}.loading-spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.app-shell{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.appnav{background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:20}.appnav-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 14px;border-bottom:1px solid var(--border)}.appnav-mark{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:#fff;flex-shrink:0;background:linear-gradient(140deg,var(--teal),hsl(var(--k-primary)/.7));box-shadow:var(--shadow-sm)}.appnav-sec{font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:16px 16px 7px}.appnav-item{display:flex;align-items:center;gap:11px;margin:1px 10px;padding:9px 11px;border-radius:var(--radius-md);color:var(--text-2);cursor:pointer;font-size:13.5px;font-weight:500;transition:all .15s;border:1px solid transparent;text-decoration:none}.appnav-item:hover{background:var(--surface-2);color:var(--text)}.appnav-item.active{background:var(--teal-light);color:var(--teal);font-weight:600}.appnav-item .ico{width:18px;display:grid;place-items:center;flex-shrink:0}.appnav-spacer{flex:1}.appnav-foot{padding:12px;border-top:1px solid var(--border);gap:10px}.apphd,.appnav-foot{display:flex;align-items:center}.apphd{position:sticky;top:0;z-index:30;height:60px;gap:14px;padding:0 28px;background:hsl(var(--k-background)/.82);-webkit-backdrop-filter:saturate(140%) blur(10px);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--border)}.apphd h1{font-size:18px;font-weight:800;letter-spacing:-.01em}.apphd-search{flex:1;max-width:460px;position:relative}.apphd-search input{padding-left:34px}.apphd-search .si{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.appwrap{padding:26px 28px 64px;max-width:1180px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-sm)}.stat .lbl{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:7px}.stat .num{font-size:30px;font-weight:800;margin-top:8px;letter-spacing:-.02em;color:var(--text)}.stat .sub{font-size:11.5px;color:var(--muted);margin-top:3px}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:3px;gap:2px}.seg button{border:none;background:none;padding:6px 15px;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--text-2);cursor:pointer;font-family:inherit;transition:all .12s}.seg button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.sop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px}.sopc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s;text-decoration:none;color:inherit;display:block}.sopc:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border2)}.sopc .top{display:flex;align-items:flex-start;gap:11px;margin-bottom:14px}.sopc .ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}.sopc .nm{font-size:14.5px;font-weight:700;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sopc .kd{font-size:10.5px;color:var(--muted);font-family:var(--font-mono);margin-top:2px}.sopc .meta{display:flex;align-items:center;justify-content:space-between;padding-top:12px;margin-top:13px;border-top:1px solid var(--border);font-size:11px;color:var(--muted)}.chip{font-size:10px;font-weight:700;padding:2px 9px;border-radius:20px;letter-spacing:.02em}.dot{width:7px;height:7px;border-radius:50%;display:inline-block;vertical-align:middle}@media (max-width:860px){.stat-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:760px){body.app-shell{grid-template-columns:1fr!important}.appnav{position:fixed;left:-260px;top:0;width:248px;height:100vh;transition:left var(--transition)}.appnav.open{left:0;box-shadow:8px 0 32px rgba(33,25,18,.25)}.apphd{padding:0 16px}.appwrap{padding:20px 16px 56px}.appnav-mobile-btn{display:inline-flex!important}}.appnav-mobile-btn{display:none}.doc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.doc-h{padding:22px 26px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap}.doc-title{font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.doc-subtitle{font-size:13px;color:var(--muted);margin-top:5px}.doc-kode{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--emas)}.doc-rev{font-size:11px;color:var(--muted);margin-top:4px}.doc-b{padding:24px 26px}.dsec{margin-bottom:26px}.dsec:last-child{margin-bottom:0}.dsec-t{font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--teal);margin-bottom:12px;display:flex;align-items:center;gap:8px}.dtable{width:100%;border-collapse:collapse;font-size:13px}.dtable td,.dtable th{padding:8px 12px;border:1px solid var(--border);text-align:left}.dtable th{background:var(--surface-2);font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:800}.dtable .q{font-weight:700;color:var(--teal);text-align:center;width:110px;white-space:nowrap}.dtable .\!q{font-weight:700!important;color:var(--teal)!important;text-align:center!important;width:110px!important;white-space:nowrap!important}.dstep{display:flex;gap:12px;margin-bottom:12px}.dstep:last-child{margin-bottom:0}.dstep .n{width:26px;height:26px;border-radius:50%;background:var(--teal-light);color:var(--teal);font-weight:800;font-size:12px;display:grid;place-items:center;flex-shrink:0}.dstep p{font-size:13.5px;line-height:1.55;padding-top:3px;color:var(--text)}.dlist{list-style:none;display:flex;flex-direction:column;gap:8px}.dlist li{display:flex;gap:10px;font-size:13.5px;line-height:1.55;color:var(--text)}.dlist li:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--emas);margin-top:8px;flex-shrink:0}.read-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.read-photos figure{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--surface-2)}.read-photos img{width:100%;height:90px;-o-object-fit:cover;object-fit:cover;display:block}.read-photos figcaption{font-size:11px;color:var(--muted);padding:6px 8px}.read-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width:640px){.read-2col{grid-template-columns:1fr}}.edit-split{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:22px;align-items:start}.preview-col{position:sticky;top:76px}.preview-col-h{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:9px;display:flex;align-items:center;gap:6px}.preview-pane-doc .doc{box-shadow:var(--shadow-md)}.preview-pane-doc .doc-title{font-size:19px}.preview-pane-doc .doc-b,.preview-pane-doc .doc-h{padding:16px 18px}.preview-pane-doc .dlist li,.preview-pane-doc .dstep p,.preview-pane-doc .dtable{font-size:12px}.preview-note{font-size:10.5px;color:var(--muted);margin-top:9px;line-height:1.5}.edit-split .form-actions{margin:18px 0 0;padding:14px 0 0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border-top:1px solid var(--border);position:static}@media (max-width:1100px){.edit-split{grid-template-columns:1fr}.preview-col{display:none}}.\!visible{visibility:visible!important}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.min-h-screen{min-height:100vh}.border-collapse{border-collapse:collapse}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.border{border-width:1px}.bg-background{--tw-bg-opacity:1;background-color:hsl(var(--k-background)/var(--tw-bg-opacity,1))}.uppercase{text-transform:uppercase}.italic{font-style:italic}.text-foreground{--tw-text-opacity:1;color:hsl(var(--k-foreground)/var(--tw-text-opacity,1))}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.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)}@keyframes sectionIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-section{animation:sectionIn .22s ease both}.form-grid .form-section:first-child{animation-delay:0ms}.form-grid .form-section:nth-child(2){animation-delay:35ms}.form-grid .form-section:nth-child(3){animation-delay:70ms}.form-grid .form-section:nth-child(4){animation-delay:105ms}.form-grid .form-section:nth-child(5){animation-delay:.14s}.form-grid .form-section:nth-child(6){animation-delay:175ms}.form-grid .form-section:nth-child(7){animation-delay:.21s}.form-grid .form-section:nth-child(8){animation-delay:245ms}.form-grid .form-section:nth-child(9){animation-delay:.28s}.form-grid .form-section:nth-child(n+10){animation-delay:315ms}@keyframes modalIn{0%{opacity:0;transform:scale(.97) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.gen-modal.open .gen-box,.import-area.open .import-box{animation:modalIn .2s cubic-bezier(.22,1,.36,1) both}.btn-generate:active,.btn-save:active,.topbar-btn-primary:active{transform:scale(.97)}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast.show{animation:toastIn .18s ease forwards}@media (max-width:1280px){:root{--sidebar-width:264px}.main{padding:28px 30px 96px}}@media (max-width:1024px){:root{--sidebar-width:244px}.main{padding:24px 24px 96px;max-width:100%}.form-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.gen-box-wide{max-width:400px}}@media (max-width:768px){.app{grid-template-columns:1fr}.sidebar{position:fixed;left:-300px;top:56px;width:288px;height:calc(100vh - 56px);z-index:150;transition:left var(--transition);border-right:1px solid var(--border)}.sidebar.open{left:0;box-shadow:8px 0 32px rgba(33,25,18,.25)}.topbar-menu-btn{display:inline-flex;align-items:center;justify-content:center}.main{padding:22px 16px 96px;max-width:100%}.form-actions{margin:20px -16px -96px;padding:14px 16px}.form-row{grid-template-columns:1fr;gap:10px}.form-section-body{padding:14px}.bahan-row{grid-template-columns:1fr 90px 32px}.toast{bottom:16px;right:16px;left:16px;text-align:center}.import-box{padding:18px 16px}.gen-box-wide{max-width:100%}.foto-grid,.gen-options,.mesin-config-row,.peran-row,.temuan-grid{grid-template-columns:1fr}.sb-row{grid-template-columns:1fr 1fr 32px}.topbar-page{display:none}}@media (max-width:480px){.main{padding:18px 12px 96px}.form-section-header{font-size:10px;padding:10px 12px}.form-section-body{padding:12px}.bahan-row{grid-template-columns:1fr 76px 30px}.langkah-row{grid-template-columns:24px 1fr 30px}.langkah-num{width:24px;height:24px;font-size:10px}.gula-pill{font-size:11px;padding:5px 11px}.area-row{grid-template-columns:1fr 1fr}.empty-state .icon{width:72px;height:72px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.loading-spinner{animation:none}}