@import"https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&display=swap";:root{--pps-font-main: "Inter", "Noto Sans Thai", "Sarabun", "Segoe UI", -apple-system, BlinkMacSystemFont, system-ui, Roboto, "Helvetica Neue", Arial, sans-serif;--pps-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--pps-text-2xs: .6875rem;--pps-text-xs: .75rem;--pps-text-sm: .8125rem;--pps-text-md: .875rem;--pps-text-base: .9375rem;--pps-text-lg: 1rem;--pps-text-xl: 1.125rem;--pps-text-2xl: 1.25rem;--pps-text-3xl: 1.375rem;--pps-text-4xl: 1.5rem;--pps-text-5xl: 1.625rem;--pps-text-6xl: 1.75rem;--pps-text-7xl: 1.875rem;--pps-text-8xl: 2rem;--pps-text-9xl: 2.25rem;--pps-text-display: 2.625rem;--fs-xxs: var(--pps-text-2xs);--fs-xs: var(--pps-text-xs);--fs-sm: var(--pps-text-sm);--fs-md: var(--pps-text-md);--fs-lg: var(--pps-text-lg);--fs-xl: var(--pps-text-xl);--fs-2xl: var(--pps-text-2xl);--fs-9: .5625rem;--fs-8: .5rem;--fs-10: .625rem;--fs-11: var(--pps-text-2xs);--fs-12: var(--pps-text-xs);--fs-13: var(--pps-text-sm);--fs-14: var(--pps-text-md);--fs-15: var(--pps-text-base);--fs-16: var(--pps-text-lg);--fs-17: 1.0625rem;--fs-18: var(--pps-text-xl);--fs-19: 1.1875rem;--fs-20: var(--pps-text-2xl);--fs-21: 1.3125rem;--fs-22: var(--pps-text-3xl);--fs-24: var(--pps-text-4xl);--fs-26: var(--pps-text-5xl);--fs-28: var(--pps-text-6xl);--fs-30: var(--pps-text-7xl);--fs-32: var(--pps-text-8xl);--fs-34: 2.125rem;--fs-36: var(--pps-text-9xl);--fs-38: 2.375rem;--fs-40: 2.5rem;--fs-42: var(--pps-text-display);--font-xs: var(--pps-text-xs);--font-sm: var(--pps-text-sm);--font-base: var(--pps-text-lg);--pps-page-pad: 24px;--pps-page-pad-sm: 14px;--pps-content-max: none;--pps-touch-target: 44px;--pps-tv-touch-target: 48px;--wpd-fs-2xs: var(--pps-text-2xs);--wpd-fs-xs: var(--pps-text-xs);--wpd-fs-sm: var(--pps-text-sm);--wpd-fs-md: var(--pps-text-md);--wpd-fs-lg: var(--pps-text-lg);--wpd-fs-xl: var(--pps-text-xl);--wpd-fs-2xl: var(--pps-text-2xl);--wpf-fs-2xs: var(--pps-text-2xs);--wpf-fs-xs: var(--pps-text-xs);--wpf-fs-sm: var(--pps-text-sm);--wpf-fs-md: var(--pps-text-md);--wpf-fs-lg: var(--pps-text-lg);--wpf-fs-xl: var(--pps-text-xl);--wpf-fs-2xl: var(--pps-text-2xl);--wpl-fs-2xs: var(--pps-text-2xs);--wpl-fs-xs: var(--pps-text-xs);--wpl-fs-sm: var(--pps-text-sm);--wpl-fs-md: var(--pps-text-md);--wpl-fs-lg: var(--pps-text-lg);--wpl-fs-xl: var(--pps-text-xl);--wpl-fs-2xl: var(--pps-text-2xl);--wpai-fs-2xs: var(--pps-text-2xs);--wpai-fs-xs: var(--pps-text-xs);--wpai-fs-sm: var(--pps-text-sm);--wpai-fs-md: var(--pps-text-md);--wpai-fs-lg: var(--pps-text-lg);--wpai-fs-xl: var(--pps-text-xl);--wpai-fs-2xl: var(--pps-text-2xl);font-family:var(--pps-font-main);font-size:var(--fs-16);line-height:1.5;font-weight:400;color-scheme:light;color:#0f172a;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{width:100%;min-width:320px;min-height:100%;background-color:#f8fafc;text-size-adjust:100%;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#747bff}body{margin:0;width:100%;min-width:320px;min-height:100vh;min-height:100dvh;font-family:var(--pps-font-main);font-size:var(--pps-text-lg);color:#0f172a;background-color:#f8fafc;overflow-x:hidden}#root{width:100%;min-width:0;min-height:100vh;min-height:100dvh;background-color:#f8fafc;text-align:initial}h1{font-size:var(--pps-text-9xl);line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:var(--fs-16);font-weight:500;font-family:inherit;background-color:#f9fafb;cursor:pointer;transition:border-color .25s}code,kbd,samp,pre{font-family:var(--pps-font-mono)}input,select,textarea,button{color:inherit;font-family:inherit;font-size:inherit;max-width:100%}img,svg,video,canvas{max-width:100%}img,video,canvas{height:auto}button,[role=button],input,select,textarea{min-height:var(--pps-touch-target)}button,a,input,select,textarea{touch-action:manipulation}table{max-width:100%}:where(.pps-table-wrap,.table-wrap,.table-responsive,.up-card,.mp-table-wrap,.gr-table-wrap,.stc-table-wrap){max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}:where(.modal,.up-modal,.mp-card[role=dialog],.swal2-popup){max-width:calc(100vw - 24px)}:where(.modal,.up-modal,.mp-card[role=dialog]){max-height:calc(100dvh - 24px)}:where(.page,.up-page,.mp-page,.ppshome-content){min-width:0}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.language-switcher{display:inline-flex;align-items:center;gap:6px;padding:4px;border:1px solid #dbe3ee;border-radius:999px;background:#fff;color:#0f172a;box-shadow:0 1px 2px #0f172a0f;flex-shrink:0}.language-switcher-icon{width:15px;height:15px;margin-left:6px;color:#0369a1}.language-switcher-options{display:inline-flex;gap:2px}.language-switcher button{min-width:34px;height:28px;padding:0 8px;border:none;border-radius:999px;background:transparent;color:#475569;font-size:var(--fs-12);font-weight:800;line-height:1}.language-switcher button:hover{border-color:transparent;background:#f1f5f9}.language-switcher button.active{background:#0369a1;color:#fff}.login-language{position:fixed;top:18px;right:18px;z-index:20}.global-language-switcher{position:fixed;top:18px;right:18px;z-index:10000}@media(max-width:768px){:root{--pps-page-pad: 16px;--pps-touch-target: 46px}body{font-size:var(--pps-text-base)}h1{font-size:var(--pps-text-5xl)}.global-language-switcher,.login-language{top:max(10px,env(safe-area-inset-top));right:max(10px,env(safe-area-inset-right))}}@media(max-width:480px){:root{--pps-page-pad: var(--pps-page-pad-sm)}h1{font-size:var(--pps-text-3xl)}button{padding-inline:.9em}}@media(min-width:1800px){:root{--pps-page-pad: 32px;--pps-touch-target: var(--pps-tv-touch-target)}}@media(min-width:2560px){:root{--pps-page-pad: 40px;--pps-text-lg: 1.0625rem;--pps-text-xl: 1.1875rem;--pps-text-2xl: 1.375rem;--pps-text-3xl: 1.5rem;--pps-text-4xl: 1.75rem}}@supports (height: 100svh){body,#root{min-height:100svh}}@media print{.global-language-switcher,.login-language{display:none!important}}@media(prefers-color-scheme:dark){:root{color:#0f172a;background-color:#f8fafc}body{color:#0f172a;background-color:#f8fafc}}.pps-welcome{width:100%;height:100%;background:#000;overflow:hidden;display:flex;align-items:center;justify-content:center}#hero-vid{width:100%;height:100%;object-fit:cover}.login-page{--bg: #ffffff;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #4b5563;--primary: #0f6cbd;--primary-hover: #0b5cab;--danger: #dc2626;--shadow-focus: 0 0 0 3px rgba(15, 108, 189, .15);min-height:100vh;background:var(--bg);color:var(--text);font-family:var(--pps-font-main)}.login-page *{box-sizing:border-box}.login-page,.login-page #root{width:100%;height:100%}.login-page .login-wrapper{width:100%;min-height:100vh;display:flex;justify-content:center;align-items:center;padding:24px 16px 90px;overflow-y:auto;position:relative}.login-page .login-box{width:460px;max-width:100%;text-align:center}.login-page .login-box h1{margin:0 0 12px;font-size:var(--fs-36);font-weight:700;color:#000}.login-page .subtitle{font-size:var(--fs-16);color:var(--muted);margin:0 0 36px}.login-page form{text-align:left}.login-page label{font-size:var(--fs-16);font-weight:700;color:#000;display:block;margin-bottom:8px}.login-page label span{color:var(--danger);margin-left:4px}.login-page .input-group{position:relative;margin-bottom:26px}.login-page .input-group input{width:100%;height:54px;padding:0 52px;border-radius:12px;border:1px solid var(--border);font-size:var(--fs-17);background:#e5e7eb;color:var(--text);transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease}.login-page .input-group input::placeholder{color:#6b7280;font-size:var(--fs-15)}.login-page .input-group input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:var(--shadow-focus)}.login-page .icon{position:absolute;top:50%;transform:translateY(-50%);font-size:var(--fs-20);color:#374151}.login-page .icon.left{left:16px}.login-page .icon.right{right:16px;cursor:pointer;opacity:.7}.login-page .icon.right:hover{opacity:1}.login-page .login-btn{width:100%;height:52px;border:none;border-radius:12px;background:#0f6cbdba;color:#fff;font-size:var(--fs-17);font-weight:700;letter-spacing:.2px;cursor:pointer;transition:background-color .2s ease,transform .05s ease,box-shadow .2s ease}.login-page .login-btn:hover{background:var(--primary-hover)}.login-page .login-btn:active{transform:translateY(1px)}.login-page .login-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #0f6cbd59}.login-page .login-btn:disabled{background:#9ca3af;cursor:not-allowed;box-shadow:none;transform:none}.login-page .login-error{margin-bottom:14px;color:var(--danger);font-size:var(--fs-15);font-weight:600}.login-page .login-loading{height:52px;background:#0f6cbdab;color:#fff;border-radius:12px;font-size:var(--fs-16);font-weight:700;display:flex;align-items:center;justify-content:center}.login-page .login-footer{position:absolute;left:0;bottom:24px;width:100%;text-align:center;font-size:var(--fs-13);color:#6b7280;line-height:1.6;-webkit-user-select:none;user-select:none}.login-page .login-footer-sub{font-size:var(--fs-12);color:#9ca3af;margin-top:2px}@media(max-width:768px){.login-page .login-wrapper{padding:20px 14px 80px;align-items:flex-start}.login-page .login-box h1{font-size:var(--fs-30)}.login-page .subtitle{font-size:var(--fs-15);margin-bottom:28px}.login-page .input-group input,.login-page .login-btn,.login-page .login-loading{height:50px;font-size:var(--fs-16)}}@media(max-width:520px){.login-page .login-wrapper{padding:16px 12px 72px}.login-page .login-box{width:100%}.login-page .login-box h1{font-size:var(--fs-26)}.login-page .subtitle{font-size:var(--fs-14);margin-bottom:22px}.login-page .input-group{margin-bottom:18px}.login-page .input-group input{height:48px;padding:0 44px;font-size:var(--fs-15)}.login-page label{font-size:var(--fs-14)}.login-page .login-btn,.login-page .login-loading{height:48px;font-size:var(--fs-15)}.login-page .login-footer{bottom:16px;font-size:var(--fs-12)}.login-page .login-footer-sub{font-size:var(--fs-11)}}@media(max-width:360px){.login-page .login-box h1{font-size:var(--fs-24)}.login-page .subtitle{font-size:var(--fs-13)}}@media(max-height:640px){.login-page .login-wrapper{align-items:flex-start}.login-page .login-footer{bottom:12px}}.login-page .login-divider{display:flex;align-items:center;gap:12px;margin:18px 0 14px;color:#64748b;font-size:.875rem}.login-page .login-divider:before,.login-page .login-divider:after{content:"";height:1px;flex:1;background:#e2e8f0}.login-page .face-login-panel{width:100%}.login-page .face-login-open,.login-page .face-login-confirm,.login-page .face-login-secondary,.login-page .face-login-close{width:100%;border:0;border-radius:12px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;cursor:pointer;transition:transform .15s ease,opacity .15s ease,box-shadow .15s ease}.login-page .face-login-open,.login-page .face-login-confirm{color:#fff;background:linear-gradient(135deg,#0f766e,#14b8a6);box-shadow:0 10px 22px #0f766e38}.login-page .face-login-secondary{color:#0f766e;background:#ccfbf1}.login-page .face-login-close{color:#475569;background:#e2e8f0}.login-page .face-login-open:hover,.login-page .face-login-confirm:hover,.login-page .face-login-secondary:hover,.login-page .face-login-close:hover{transform:translateY(-1px)}.login-page .face-login-open:disabled,.login-page .face-login-confirm:disabled,.login-page .face-login-secondary:disabled,.login-page .face-login-close:disabled{cursor:not-allowed;opacity:.65;transform:none}.login-page .face-login-camera{display:grid;gap:10px}.login-page .face-login-video-wrap{overflow:hidden;border-radius:16px;background:#0f172a;border:1px solid #cbd5e1;aspect-ratio:4 / 3}.login-page .face-login-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.login-page .face-login-message{border-radius:10px;background:#f8fafc;color:#334155;border:1px solid #e2e8f0;padding:8px 10px;font-size:.875rem;line-height:1.35}.login-page .face-login-actions{display:grid;gap:8px}:root{--primary: #0369a1;--primary-hover: #0284c7;--primary-light: #e0f2fe;--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #111827;--text-muted: #6b7280;--danger: #dc2626;--shadow: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 6px 18px rgba(15, 23, 42, .08);--radius: 12px;--radius-sm: 10px;--topbar-h: 56px}.ppshome-container{height:100vh;height:100dvh;width:100%;min-width:0;display:flex;flex-direction:column;background:var(--bg);font-family:var(--pps-font-main);overflow:hidden;color:var(--text)}.ppshome-topbar{height:var(--topbar-h);min-height:var(--topbar-h);background:var(--card);color:var(--text);display:flex;align-items:center;justify-content:space-between;padding:0 18px;padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right));flex-shrink:0;border-bottom:1px solid var(--border);box-shadow:none}.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}.hamburger{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-18);cursor:pointer;border-radius:2px;color:var(--text);transition:background .15s ease}.hamburger:hover{background:#0f172a0f}.hamburger:active{background:#0f172a1a}.pps-logo{height:48px;max-width:510px;object-fit:contain;display:block;filter:saturate(.95)}.app-title{font-size:var(--fs-15);font-weight:650;letter-spacing:.2px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-user{color:var(--text-muted);font-weight:500}.user-menu-container{position:relative}.user-icon{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-22);cursor:pointer;border-radius:999px;color:var(--text);background:transparent;transition:background .15s ease}.user-icon:hover{background:#0f172a0f}.user-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:var(--card);border-radius:12px;box-shadow:var(--shadow-md);min-width:220px;z-index:1000;overflow:hidden;border:1px solid var(--border)}.dropdown-item{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;transition:background .12s ease;color:var(--text);font-size:var(--fs-14);font-weight:600}.dropdown-item:hover{background:#f3f4f6}.dropdown-item.user-info{cursor:default;color:var(--primary);background:#f0f9ff;font-weight:600}.dropdown-item.user-info:hover{background:#f0f9ff}.dropdown-item.logout{color:var(--danger)}.dropdown-item.logout:hover{background:#fef2f2}.dropdown-icon{font-size:var(--fs-16);opacity:.9}.dropdown-divider{height:1px;background:var(--border);margin:4px 0}.ppshome-body{flex:1;display:flex;min-width:0;min-height:0;overflow:hidden}.sidebar{width:350px;background:var(--card);border-right:1px solid var(--border);padding:16px 10px;transition:width .25s ease,padding .25s ease;flex-shrink:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;box-shadow:none}.sidebar.collapsed{width:64px;padding:16px 8px}.sidebar.collapsed .nav-section{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:12px}.sidebar.collapsed .nav-item span{display:none}.sidebar.collapsed .nav-item svg{font-size:var(--fs-20)}.nav-section{font-size:var(--fs-11);font-weight:500;color:var(--text-muted);margin:18px 10px 10px;text-transform:uppercase;letter-spacing:.9px;opacity:.75}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;font-size:var(--fs-13);font-weight:500;color:var(--text);cursor:pointer;text-decoration:none;transition:background .12s ease,color .12s ease;margin-bottom:4px;position:relative;overflow:hidden}.nav-item:hover{background:#f3f4f6}.nav-item.active{background:#f0f9ff;color:var(--primary)}.nav-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:999px;background:var(--primary)}.nav-item svg{font-size:var(--fs-18);flex-shrink:0;opacity:.9}.nav-group{margin-bottom:6px}.nav-group-items{display:flex;flex-direction:column}.nav-section-toggle{width:calc(100% - 4px);min-height:34px;border:0;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;font-family:inherit;border-radius:9px;padding:8px 10px;transition:background .12s ease,color .12s ease}.nav-section-main{display:inline-flex;align-items:center;gap:8px;min-width:0}.nav-section-code{min-width:28px;height:20px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#e0f2fe;color:var(--primary);border:1px solid #bae6fd;font-size:var(--fs-11);font-weight:800;letter-spacing:0;flex-shrink:0}.nav-section-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-section-toggle:hover{background:#0f172a0a;color:var(--text);opacity:1}.nav-section-toggle:focus-visible{outline:2px solid rgba(3,105,161,.32);outline-offset:2px}.nav-section-chevron{display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-11);line-height:1;opacity:.72;flex-shrink:0}.nav-section-chevron svg{width:11px;height:11px}.sidebar.collapsed .nav-group{margin-bottom:0}.sidebar.collapsed .nav-group-items{display:flex}.nav-code{min-width:36px;height:22px;padding:0 7px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#f8fafc;border:1px solid #dbeafe;color:var(--primary);font-size:var(--fs-11);font-weight:800;line-height:1;letter-spacing:.1px;flex-shrink:0}.nav-item.active .nav-code{background:#dbeafe;border-color:#93c5fd}.sidebar.collapsed .nav-code{display:none}.ppshome-content{flex:1;min-width:0;padding:var(--pps-page-pad, 24px);overflow-y:auto;overflow-x:hidden;background:var(--bg);overscroll-behavior:contain}.ppshome-content h1{font-size:var(--fs-22);margin-bottom:8px;color:var(--text);font-weight:750;letter-spacing:-.2px}.ppshome-content h2{font-size:var(--fs-18);margin-bottom:14px;color:var(--text);font-weight:700}.ppshome-content p{font-size:var(--fs-14);color:var(--text-muted);line-height:1.7}.user-dropdown .dropdown-item{width:100%;border:none;background:transparent;text-align:left;cursor:pointer}@media(max-width:768px){.sidebar{position:absolute;z-index:999;height:calc(100% - var(--topbar-h));max-width:min(82vw,320px);box-shadow:var(--shadow-md)}.sidebar.collapsed{transform:translate(-100%)}.ppshome-content{padding:var(--pps-page-pad, 16px)}.app-title{font-size:var(--fs-14)}.pps-logo{height:26px;max-width:92px}}@media(max-width:480px){.ppshome-topbar{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}.ppshome-content{padding:var(--pps-page-pad, 14px)}.sidebar{width:min(86vw,300px)}}@media(min-width:1800px){:root{--topbar-h: 64px}.sidebar{width:300px;padding:18px 12px}.sidebar.collapsed{width:72px}.nav-item{padding:12px 14px}.ppshome-content{padding:var(--pps-page-pad, 32px)}}@media(min-width:2560px){.sidebar{width:340px}.sidebar.collapsed{width:80px}.ppshome-content{padding:var(--pps-page-pad, 40px)}}.sidebar::-webkit-scrollbar,.ppshome-content::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track,.ppshome-content::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb,.ppshome-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:999px}.sidebar::-webkit-scrollbar-thumb:hover,.ppshome-content::-webkit-scrollbar-thumb:hover{background:#bfc5cf}.sidebar.collapsed .nav-item{position:relative}.sidebar.collapsed .nav-item:hover:after{content:attr(title);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:var(--text);color:#fff;padding:6px 10px;border-radius:10px;font-size:var(--fs-12);white-space:nowrap;z-index:1000;pointer-events:none;box-shadow:var(--shadow-md)}.topbar-right{display:flex;align-items:center;gap:12px;min-width:0}.pps-login-scope{display:flex;align-items:center;gap:10px;min-width:0;max-width:70vw;justify-content:flex-end}.pps-scope-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;border:1px solid #7dd3fc;background:#e0f2fe;color:#0f172a;font-size:var(--fs-12);font-weight:700;white-space:nowrap;max-width:34vw;overflow:hidden;text-overflow:ellipsis}.pps-more{font-style:normal;font-weight:900;opacity:.8}@media(max-width:640px){.pps-login-scope{display:none}}.tg-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:16px;z-index:9999}.tg-modal{width:min(520px,100%);background:#fff;border-radius:18px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #0003;overflow:hidden}.tg-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.tg-title{font-size:var(--fs-14);font-weight:600;color:#111827}.tg-x{height:34px;width:34px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-size:var(--fs-20);line-height:1}.tg-x:hover{background:#f8fafc}.tg-body{padding:14px}.tg-qr{display:flex;justify-content:center;padding:10px;background:#f8fafc;border:1px dashed #e5e7eb;border-radius:14px}.tg-hint{margin-top:12px;font-size:var(--fs-13);color:#111827;line-height:1.5}.tg-muted{display:inline-block;margin-top:6px;color:#6b7280;font-size:var(--fs-12)}.tg-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}.tg-btn{height:40px;padding:0 16px;border-radius:12px;border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;font-weight:700;display:inline-flex;align-items:center;text-decoration:none}.tg-btn:hover{background:#bae6fd;border-color:#7dd3fc}.tg-btn-ghost{height:40px;width:100%;padding:0 14px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;color:#111827;font-weight:500;cursor:pointer}.tg-btn-ghost:hover{background:#f8fafc;border-color:#cbd5e1}.tg-loading{padding:10px;text-align:center;color:#6b7280;font-weight:700}.tg-error{padding:12px;border:1px solid #fecaca;background:#fff1f2;border-radius:12px;color:#991b1b;font-weight:700}.tg-foot{margin-top:12px;font-size:var(--fs-12);color:#6b7280}.tg-actions{display:flex;gap:10px;margin-top:14px}.tg-actions>.tg-btn,.tg-actions>.tg-btn-ghost{flex:1;width:100%;justify-content:center}.tg-btn{cursor:pointer;border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;font-weight:500;height:40px;border-radius:12px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.webpush-gate{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));background:#0f172aad;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);overflow:auto;overscroll-behavior:contain;touch-action:manipulation}.webpush-gate-panel{width:min(620px,100%);max-height:calc(100dvh - 32px);overflow:auto;border-radius:28px;padding:clamp(20px,4vw,34px);background:#fff;box-shadow:0 28px 80px #0f172a59;color:#0f172a;-webkit-overflow-scrolling:touch}.webpush-gate-icon{width:clamp(56px,12vw,70px);height:clamp(56px,12vw,70px);border-radius:22px;display:grid;place-items:center;font-size:clamp(28px,7vw,34px);background:#ecfeff;margin-bottom:18px}.webpush-gate-panel h2{margin:0 0 10px;font-size:clamp(22px,5vw,28px);line-height:1.28;letter-spacing:-.02em}.webpush-gate-panel p{margin:0 0 18px;color:#64748b;font-size:clamp(14px,3.6vw,16px);line-height:1.7}.webpush-gate-status{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:18px 0}.webpush-gate-status div{min-width:0;border:1px solid #e2e8f0;border-radius:16px;padding:12px;background:#f8fafc}.webpush-gate-status span{display:block;color:#64748b;font-size:12px;margin-bottom:5px}.webpush-gate-status b{display:block;min-width:0;font-size:clamp(14px,3.5vw,15px);overflow-wrap:anywhere;word-break:break-word}.webpush-gate-warning{margin:14px 0;padding:12px 14px;border-radius:16px;color:#92400e;background:#fffbeb;border:1px solid #fde68a;font-size:clamp(14px,3.5vw,15px);line-height:1.6;overflow-wrap:anywhere}.webpush-gate-steps{margin:14px 0 22px;padding-left:22px;color:#334155;line-height:1.7;font-size:clamp(14px,3.7vw,16px)}.webpush-gate-steps li{margin:4px 0}.webpush-gate-actions{display:flex;flex-wrap:wrap;gap:12px}.webpush-gate-actions button{min-height:46px;border:0;border-radius:14px;padding:13px 18px;color:#fff;background:#0f766e;font-size:clamp(14px,3.5vw,15px);font-weight:700;line-height:1.2;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.webpush-gate-actions button:disabled{cursor:not-allowed;opacity:.55}.webpush-gate-actions .secondary{background:#475569}.webpush-gate-actions .ghost{color:#334155;background:#e2e8f0}@media(max-width:768px){.webpush-gate{align-items:flex-start}.webpush-gate-panel{margin:auto 0;border-radius:24px}.webpush-gate-status{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:640px){.webpush-gate{padding:max(12px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) max(12px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left))}.webpush-gate-panel{width:100%;max-height:calc(100dvh - 24px);border-radius:22px;padding:22px}.webpush-gate-status{grid-template-columns:1fr}.webpush-gate-actions{display:grid;grid-template-columns:1fr}.webpush-gate-actions button{width:100%}}@media(max-width:380px){.webpush-gate-panel{padding:18px;border-radius:18px}.webpush-gate-icon{margin-bottom:14px}.webpush-gate-steps{padding-left:18px}}@media(max-height:560px){.webpush-gate{align-items:flex-start}.webpush-gate-panel{max-height:calc(100dvh - 20px);padding:18px;border-radius:20px}.webpush-gate-icon{width:48px;height:48px;border-radius:16px;font-size:24px;margin-bottom:10px}.webpush-gate-panel h2{font-size:20px}.webpush-gate-panel p{margin-bottom:12px}.webpush-gate-status{margin:12px 0}.webpush-gate-steps{margin-bottom:14px}}@media(prefers-reduced-motion:reduce){.webpush-gate,.webpush-gate-panel,.webpush-gate-actions button{scroll-behavior:auto;transition:none}}@supports not (height: 100dvh){.webpush-gate-panel{max-height:calc(100vh - 32px)}@media(max-width:640px){.webpush-gate-panel{max-height:calc(100vh - 24px)}}}.pf-page{width:100%;height:100%;background:#f8fafc;padding:16px 24px;color:#111827}.pf-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.pf-title{display:inline-flex;align-items:center;gap:10px;color:#111827}.pf-title h2{margin:0;font-size:var(--fs-16);font-weight:700}.pf-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:12px}.pf-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:14px;box-shadow:0 10px 26px #0000000f}.pf-card-title{font-size:var(--fs-16);font-weight:700;color:#111827;margin-bottom:10px}.pf-form{display:grid;gap:10px}.pf-field label{display:block;font-size:var(--fs-16);font-weight:600;margin-bottom:6px;color:#111827}.pf-field input{width:100%;height:40px;border-radius:8px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-16);font-weight:400;color:#111827}.pf-field input:focus{outline:none;background:#fff;border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f626}.pf-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}.pf-btn-primary{height:42px;padding:0 16px;border-radius:8px;border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;font-size:var(--fs-16);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.pf-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.pf-btn-secondary{height:42px;padding:0 16px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;color:#0f172a;font-size:var(--fs-16);font-weight:600;cursor:pointer}.pf-btn-secondary:hover{background:#f8fafc}.pf-loading{margin-top:10px;font-size:var(--fs-16);font-weight:400;color:#6b7280}.pf-hint{margin-top:6px;font-size:var(--fs-16);font-weight:400;color:#6b7280}@media(max-width:1100px){.pf-grid{grid-template-columns:1fr}}.pf-signature-wrap{display:grid;gap:10px}.pf-signature-head{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.pf-signature-meta{color:#64748b;font-size:var(--fs-15)}.pf-signature-preview{width:100%;max-width:320px;min-height:110px;border:1px dashed #cbd5e1;border-radius:12px;background:#fff;overflow:hidden;display:flex;align-items:center;justify-content:center}.pf-signature-preview img{display:block;max-width:100%;max-height:150px;object-fit:contain;background:#fff}.pf-signature-placeholder{min-height:110px;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;color:#64748b;font-size:var(--fs-15)}.pf-signature-actions{display:flex;gap:10px;flex-wrap:wrap}.pf-upload-btn{position:relative;overflow:hidden}.pf-btn-danger{border-color:#fecaca;color:#b91c1c}.pf-btn-danger:hover{background:#fef2f2}.pf-face-register{width:100%}.pf-face-video-wrap{width:100%;max-width:520px;aspect-ratio:4 / 3;background:#0f172a;border:1px solid #d8e2ef;border-radius:16px;overflow:hidden;display:flex;align-items:center;justify-content:center}.pf-face-video{width:100%;height:100%;object-fit:cover;background:#0f172a;transform:scaleX(-1)}.webpush-page{padding:24px;max-width:1180px;margin:0 auto;color:#0f172a}.webpush-card{background:#fff;border:1px solid #e2e8f0;border-radius:18px;box-shadow:0 10px 30px #0f172a0f;padding:22px;margin-bottom:20px}.webpush-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;background:linear-gradient(135deg,#ecfeff,#fff)}.webpush-eyebrow{margin:0 0 8px;font-weight:800;color:#0f766e;letter-spacing:.06em;text-transform:uppercase;font-size:12px}.webpush-hero h1,.webpush-card h2{margin:0 0 10px}.webpush-hero p,.muted{color:#64748b;line-height:1.65}.webpush-status-box{min-width:180px;border-radius:16px;background:#0f172a;color:#fff;padding:18px;text-align:center}.webpush-status-box span{display:inline-block;border-radius:999px;padding:4px 10px;font-size:12px;margin-bottom:8px}.webpush-status-box span.ok{background:#16a34a}.webpush-status-box span.bad{background:#dc2626}.webpush-status-box strong{display:block;font-size:34px}.webpush-status-box small{color:#cbd5e1}.webpush-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.webpush-config{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0}.webpush-config div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:12px}.webpush-config span{display:block;color:#64748b;font-size:12px;margin-bottom:4px}.webpush-warning{background:#fffbeb;border:1px solid #fde68a;border-radius:14px;padding:12px;color:#92400e;line-height:1.6}.webpush-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.webpush-page button{border:0;border-radius:12px;background:#0f766e;color:#fff;font-weight:800;padding:11px 16px;cursor:pointer}.webpush-page button.secondary{background:#475569}.webpush-page button:disabled{opacity:.55;cursor:not-allowed}.webpush-page label{display:block;font-weight:700;margin:12px 0}.webpush-page input,.webpush-page textarea{display:block;width:100%;margin-top:6px;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px;font:inherit}.webpush-table-wrap{overflow-x:auto}.webpush-page table{width:100%;border-collapse:collapse}.webpush-page th,.webpush-page td{border-bottom:1px solid #e2e8f0;padding:10px;text-align:left}.webpush-page .endpoint{max-width:620px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#475569}@media(max-width:900px){.webpush-page{padding:14px}.webpush-hero,.webpush-grid{grid-template-columns:1fr;display:grid}.webpush-config{grid-template-columns:1fr}}.webpush-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.webpush-section-head h2{margin-bottom:6px}.webpush-mini-counter{min-width:150px;border-radius:18px;padding:14px 16px;background:#0f172a;color:#fff;text-align:center}.webpush-mini-counter b{display:block;font-size:32px;line-height:1}.webpush-mini-counter span{display:block;margin-top:6px;color:#cbd5e1;font-size:13px}.webpush-broadcast-card button{margin-top:8px}@media(max-width:720px){.webpush-section-head{flex-direction:column}.webpush-mini-counter{width:100%}}html,body,#root{width:100%;height:100%;margin:0;font-size:var(--fs-16);font-weight:400}.po-page{box-sizing:border-box;width:100%;height:100%;padding:0 24px 24px;background:#fff}.po-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.po-header h2{margin:0;font-size:var(--fs-16);font-weight:700;color:#111827}.po-nav{display:flex;align-items:center;gap:8px}.po-nav .po-month-label{min-width:160px;text-align:center;font-size:var(--fs-16);font-weight:400;color:#374151}.po-nav button{appearance:none;border:1px solid #e5e7eb;background:#f9fafb;color:#374151;border-radius:3px;padding:6px 10px;cursor:pointer;transition:background-color .15s,border-color .15s;height:38px;font-size:var(--fs-16);font-weight:600}.po-nav button:hover{background:#eef2ff;border-color:#c7d2fe}.po-nav select{border:1px solid #e5e7eb;border-radius:6px;padding:6px 8px;background:#e8edf5;font-size:var(--fs-16);font-weight:400;color:#000;cursor:pointer;transition:all .2s}.po-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.po-week-header{margin-bottom:8px}.po-week-cell{padding:10px 8px;background:#eef2f7;color:#374151;font-size:var(--fs-16);font-weight:700;border:1px solid #e5e7eb;border-radius:8px;text-align:center;-webkit-user-select:none;user-select:none}.po-cell{display:flex;flex-direction:column;min-height:120px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 2px #0000000f;overflow:hidden;position:relative;transition:box-shadow .15s,transform .05s}.po-cell:hover{box-shadow:0 2px 6px #0000001f}.po-cell.po-empty{background:#f9fafb;border-style:dashed}.po-date-number{padding:8px 10px 6px;font-size:var(--fs-16);font-weight:700;color:#111827;border-bottom:1px solid #f3f4f6}.po-plans{flex:1;display:flex;flex-direction:column;gap:6px;padding:8px;overflow-y:auto}.po-plan-item{display:flex;align-items:center;gap:6px;font-size:var(--fs-16);font-weight:400;background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;padding:6px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.35)}.po-plan-item:hover{background:#e0e7ff}.po-wo-count{margin:10px 10px 0;display:inline-flex;align-items:center;justify-content:center;height:32px;padding:0 10px;border-radius:999px;background:#e0f2fe;border:1px solid #bae6fd;color:#075985;font-size:var(--fs-16);font-weight:700;width:fit-content;max-width:calc(100% - 20px)}.po-po-count{margin:8px 10px 0;display:inline-flex;align-items:center;justify-content:center;height:32px;padding:0 10px;border-radius:999px;background:#fef3c7;border:1px solid #fde68a;color:#92400e;font-size:var(--fs-16);font-weight:700;width:fit-content;max-width:calc(100% - 20px)}.po-cell.is-today{border-color:#60a5fa;box-shadow:0 0 0 2px #60a5fa59 inset}.po-cell.is-weekend{background:#fcfcff}.po-plan-count-badge{position:absolute;top:6px;right:8px;background:#1d4ed8;color:#fff;border-radius:999px;font-size:var(--fs-16);font-weight:700;padding:2px 6px}.po-plans::-webkit-scrollbar{width:10px}.po-plans::-webkit-scrollbar-track{background:#f3f4f6;border-radius:6px}.po-plans::-webkit-scrollbar-thumb{background:#9ca3af;border-radius:6px}.po-plans::-webkit-scrollbar-thumb:hover{background:#6b7280}@media(max-width:1024px){.po-cell{min-height:110px}}@media(max-width:768px){.po-page{padding:12px}.po-nav .po-month-label{min-width:140px}.po-cell{min-height:100px}}@media(max-width:520px){.po-grid{grid-template-columns:repeat(2,1fr)}}.po-summary{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px;display:none}.po-summary-item{background:#e8edf5;border-radius:8px;padding:8px 12px;font-size:var(--fs-16);font-weight:400;display:flex;align-items:center;color:#000;cursor:pointer;transition:all .2s}.dp-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-light: #e0f2fe;--primary-lighter: #bae6fd;--green: #166534;--green-bg: #ecfdf5;--green-border: #86efac;--green-soft: #d1fae5;--red: #991b1b;--red-light: #fee2e2;--red-soft: #fecaca;--gray-50: #f9fafb;--gray-100: #f1f5f9;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .2);--radius: 16px;--radius-sm: 10px;height:100%;width:100%;padding:16px 24px;display:grid;grid-template-columns:420px 1fr;gap:12px;overflow:hidden;background:var(--bg);color:var(--text)}.dp-left{display:flex;flex-direction:column;gap:16px;overflow-y:auto;padding-right:4px;height:100%;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.dp-left::-webkit-scrollbar{width:8px}.dp-left::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.dp-left::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.dp-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.dp-title{font-size:var(--fs-16);font-weight:700;color:var(--text);margin-bottom:4px}.dp-sub{margin-top:4px;font-size:var(--fs-16);font-weight:400;line-height:1.5;color:var(--muted)}.dp-search{position:relative;margin-top:12px}.dp-search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--gray-500);opacity:.95;pointer-events:none}.dp-search input{width:100%;height:44px;border-radius:16px;border:1.5px solid var(--gray-300);background:#e8edf5;color:var(--text);padding:0 64px 0 44px;font-size:var(--fs-18);font-weight:500;outline:none;transition:all .18s ease}.dp-search input:focus{background:var(--card);border-color:#60a5fa;box-shadow:0 0 0 4px #3b82f62e}.dp-search input::placeholder{color:#94a3b8;font-weight:500}.dp-search>button.dp-btn-ghost{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:14px;border:2px solid #cbd5e1;background:var(--card);color:var(--gray-600);box-shadow:0 6px 16px #00000014}.dp-search>button.dp-btn-ghost:hover{border-color:#93c5fd;color:var(--primary);background:#f8fafc}.dp-search>button.dp-btn-ghost:active{transform:translateY(-50%) scale(.98);box-shadow:0 3px 10px #00000014}.dp-search>button.dp-btn-ghost:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.dp-search>button.dp-btn-ghost.is-primary{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb2e,0 6px 16px #00000014}.dp-order-list{display:flex;flex-direction:column;gap:10px}.dp-order-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--gray-50);border:1px solid var(--gray-200);align-items:center}.dp-order-no{font-size:var(--fs-16);font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dp-order-mat{margin-top:2px;font-size:var(--fs-16);color:var(--muted);font-weight:400;font-family:var(--pps-font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dp-order-basic{font-size:var(--fs-16);font-weight:400;color:var(--muted);margin-top:2px}.dp-order-remain{margin-top:4px;font-size:var(--fs-16);font-weight:400;color:var(--red)}.dp-btn-add{width:40px;height:40px;border-radius:999px;border:1.5px solid var(--green-border);background:var(--green-bg);color:#16a34a;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;box-shadow:0 1px 3px #0000000d}.dp-btn-add:hover{background:var(--green-soft);border-color:#4ade80;box-shadow:0 2px 4px #22c55e26}.dp-btn-add:active{background:#bbf7d0;transform:scale(.98)}.dp-btn-add:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;filter:grayscale(.2)}.dp-btn-add:disabled:hover{background:var(--green-bg);border-color:var(--green-border);box-shadow:none}.dp-btn-remove{width:40px;height:40px;border-radius:999px;border:1.5px solid #fecaca;background:var(--red-light);color:var(--red);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;box-shadow:0 1px 3px #0000000d}.dp-btn-remove:hover{background:#fecaca;border-color:#fca5a5;box-shadow:0 2px 4px #ef44441f}.dp-btn-remove:active{background:#fca5a5;transform:scale(.98)}.dp-btn-remove:disabled{opacity:.5;cursor:not-allowed}.dp-btn-ghost{width:40px;height:40px;border-radius:12px;border:1px solid #e5e7eb;background:var(--card);color:var(--gray-500);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;box-shadow:0 1px 3px #0000000f}.dp-btn-ghost:hover{background:var(--gray-50);border-color:#7dd3fc;box-shadow:0 2px 4px #00000014}.dp-btn-ghost:active{background:var(--gray-100);box-shadow:0 1px 2px #0000000d;transform:scale(.98)}.dp-btn-ghost.collapsed{background:var(--primary-light);border-color:#7dd3fc;color:var(--primary)}.dp-btn-ghost-split{width:40px;height:40px;border-radius:999px;border:1.5px solid #bae6fd;background:#e0f2fe;color:#0369a1;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;box-shadow:0 1px 3px #0000000d}.dp-btn-ghost-split:hover{background:#bae6fd;border-color:#7dd3fc;box-shadow:0 2px 4px #0369a126}.dp-btn-ghost-split:active{background:#7dd3fc;transform:scale(.96)}.dp-btn-ghost-split:disabled{opacity:.45;cursor:not-allowed}.dp-right{display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow);background:var(--card)}.dp-right-header{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--card)}.dp-right-body{flex:1;padding:16px;overflow-y:auto;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--border) transparent}.dp-right-body::-webkit-scrollbar{width:8px}.dp-right-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.dp-right-body::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.dp-plan-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--gray-200);padding:14px 16px;display:grid;grid-template-columns:1fr 1.35fr 1fr;gap:16px;margin-bottom:12px;align-items:flex-start;box-shadow:var(--shadow-sm);transition:box-shadow .2s}.dp-plan-card:hover{box-shadow:var(--shadow)}.dp-plan-title{font-size:var(--fs-16);font-weight:700;color:var(--text)}.dp-plan-mat{font-size:var(--fs-16);color:var(--muted);margin-top:2px;font-weight:400;font-family:var(--pps-font-mono)}.dp-plan-left{min-width:0}.dp-mini-grid{display:grid;gap:8px;margin-top:10px}.dp-mini-row{display:flex;justify-content:space-between;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);background:var(--gray-50);border:1px solid var(--gray-200)}.dp-mini-row .k{font-size:var(--fs-16);font-weight:400;color:var(--gray-500)}.dp-mini-row .v{font-size:var(--fs-16);font-weight:700;color:var(--text);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dp-mini-row .v.red{color:var(--red)}.dp-label{font-size:var(--fs-16);color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.dp-input,.dp-select{width:100%;height:40px;border-radius:10px;border:1px solid var(--gray-400);background:#e8edf5;color:var(--text);padding:0 12px;font-size:var(--fs-16);font-weight:400;outline:none;transition:all .2s}.dp-input:focus,.dp-select:focus{border-color:var(--primary);background:var(--card);box-shadow:0 0 0 3px #0369a11a}.dp-input:disabled,.dp-select:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.dp-field{display:grid;gap:6px}.dp-fields-mid{display:grid;gap:10px;padding-top:0}.dp-fields-mid.with-mold{grid-template-columns:1fr}.dp-fields-mid.without-mold{grid-template-columns:1fr 1fr}.dp-plan-card>div{display:flex;flex-direction:column;justify-content:flex-start}.dp-fields-right{display:grid;gap:12px;align-content:start}.dp-fields-actions{display:flex;justify-content:flex-end;margin-top:4px}.dp-empty{color:var(--muted);font-weight:400;padding:16px;background:var(--gray-50);border:1px dashed var(--border);border-radius:var(--radius-sm);text-align:center}.dp-footer{padding:16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px;background:var(--card)}.dp-btn-clear{width:100%;max-width:200px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--gray-300);background:var(--red-light);color:var(--gray-700);font-weight:600;font-size:var(--fs-16);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.dp-btn-clear:hover{background:var(--red-soft);border-color:#fca5a5;color:var(--red)}.dp-btn-clear:disabled{background:var(--gray-100);color:var(--gray-400);border-color:var(--gray-200);cursor:not-allowed}.dp-btn-create{width:100%;max-width:200px;height:40px;border-radius:10px;border:none;background:#bbf7d0;color:var(--gray-700);font-weight:600;font-size:var(--fs-16);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.dp-btn-create:hover{background:#4ade80}.dp-btn-create:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.dp-footer .dp-btn-ghost-split{width:100%;max-width:200px;height:40px;border-radius:var(--radius-sm);border:1px solid #bae6fd;background:#e0f2fe;color:#0369a1;font-weight:600;font-size:var(--fs-16);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;box-shadow:0 1px 3px #0000000d}.dp-footer .dp-btn-ghost-split:hover{background:#bae6fd;border-color:#7dd3fc;box-shadow:0 2px 4px #0369a126}.dp-footer .dp-btn-ghost-split:active{background:#7dd3fc;transform:scale(.98)}.dp-footer .dp-btn-ghost-split:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.dp-card-scroll{flex:1;overflow-y:auto;padding-right:6px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.dp-card-scroll::-webkit-scrollbar{width:8px}.dp-card-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.dp-card-scroll::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.dp-order-row-norouting{border-color:#fecaca;background:#fff1f2}.dp-order-row-norouting .dp-order-no{color:#991b1b}.dp-order-row-nolinematerial{border-color:#fde68a;background:#fffbeb}.dp-order-row-nolinematerial .dp-order-no{color:#92400e}.dp-order-row-nolinemold{border-color:#e7d3c5;background:#faf5f1}.dp-order-row-nolinemold .dp-order-no{color:#7c3f1d}.dp-order-row-usagezero{border-color:#fdba74;background:#fff7ed}.dp-order-row-usagezero .dp-order-no{color:#9a3412}.dp-order-row-locked{opacity:.75;filter:grayscale(.1)}.dp-order-badges{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.dp-badge{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:999px;border:1px solid transparent;font-size:var(--fs-16);font-weight:700;letter-spacing:.2px}.dp-badge-red{border-color:#fecaca;background:#fee2e2;color:#991b1b}.dp-badge-amber{border-color:#fde68a;background:#fef3c7;color:#92400e}.dp-badge-brown{border-color:#e7d3c5;background:#f3e8df;color:#7c3f1d}.dp-badge-orange{border-color:#fdba74;background:#ffedd5;color:#9a3412}.dp-badge-gray{border-color:#cbd5e1;background:#f1f5f9;color:#475569}@media(max-height:720px){.dp-page{overflow:auto}}@media(max-width:1150px){.dp-page{grid-template-columns:1fr;padding:16px;gap:12px;overflow:auto}.dp-left{padding-right:0}.dp-right-body{padding:14px}.dp-plan-card{grid-template-columns:1fr;gap:14px;align-items:stretch}.dp-plan-card *{min-width:0}.dp-fields-mid.with-mold,.dp-fields-mid.without-mold{grid-template-columns:1fr 1fr;gap:12px;align-items:start}.dp-fields-mid .dp-field.shift{grid-column:1 / -1}.dp-fields-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;margin-top:4px}.dp-input,.dp-select{width:100%;max-width:100%}}@media(max-width:640px){.dp-footer{flex-direction:column;align-items:stretch;gap:10px}.dp-btn-clear,.dp-btn-create,.dp-footer .dp-btn-ghost-split{max-width:none;width:100%}.dp-right-header{padding:14px}.dp-right-body{padding:12px}.dp-card{padding:14px}.dp-fields-mid.with-mold,.dp-fields-mid.without-mold{grid-template-columns:1fr}.dp-fields-mid .dp-field.shift{grid-column:auto}}@media(max-width:480px){.dp-page{padding:12px}.dp-order-row{padding:10px 12px;gap:10px}.dp-btn-ghost-split,.dp-btn-add,.dp-btn-remove{width:38px;height:38px}.dp-plan-card{padding:12px;gap:12px}.dp-mini-row{padding:9px 12px}.dp-input,.dp-select{height:38px;font-size:var(--fs-16);font-weight:400}}.dp-tooltip-wrap{position:relative;display:inline-flex;align-items:center}.dp-tooltip{position:absolute;left:50%;bottom:calc(100% + 10px);transform:translate(-50%);z-index:50;max-width:320px;white-space:normal;padding:8px 10px;border-radius:10px;background:#0f172a;color:#fff;font-size:var(--fs-12);line-height:1.35;box-shadow:0 10px 25px #0003;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s ease,transform .15s ease}.dp-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#0f172a}.dp-tooltip-wrap:hover .dp-tooltip,.dp-tooltip-wrap:focus-within .dp-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-2px)}.panel{scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.panel::-webkit-scrollbar{width:8px;height:8px}.panel::-webkit-scrollbar-track{background:transparent}.panel::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:8px}.panel::-webkit-scrollbar-thumb:hover{background-color:#94a3b8}.planning-table{scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.planning-table::-webkit-scrollbar{height:8px}.planning-table::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:8px}.planning-table::-webkit-scrollbar-thumb:hover{background-color:#94a3b8}.dpV1-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-light: #e0f2fe;--primary-lighter: #bae6fd;--green: #166534;--green-bg: #ecfdf5;--green-border: #86efac;--green-soft: #d1fae5;--red: #991b1b;--red-light: #fee2e2;--red-soft: #fecaca;--amber: #92400e;--amber-bg: #fffbeb;--amber-border: #fde68a;--gray-50: #f9fafb;--gray-100: #f1f5f9;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .2);--radius: 16px;--radius-sm: 10px;height:100%;width:100%;padding:16px 24px;display:grid;grid-template-columns:420px 1fr;gap:12px;overflow:hidden;background:var(--bg);color:var(--text)}.dpV1-left{display:flex;flex-direction:column;gap:16px;overflow-y:auto;padding-right:4px;height:100%;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.dpV1-left::-webkit-scrollbar{width:8px}.dpV1-left::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.dpV1-left::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.dpV1-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.dpV1-title{font-size:var(--fs-16);font-weight:700;color:var(--text);margin-bottom:4px}.dpV1-sub{margin-top:4px;font-size:var(--fs-16);font-weight:400;line-height:1.5;color:var(--muted)}.dpV1-search{position:relative;margin-top:12px}.dpV1-search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--gray-500);opacity:.95;pointer-events:none}.dpV1-search input{width:100%;height:44px;border-radius:16px;border:1.5px solid var(--gray-300);background:#e8edf5;color:var(--text);padding:0 16px 0 44px;font-size:var(--fs-18);font-weight:500;outline:none;transition:all .18s ease}.dpV1-search input:focus{background:var(--card);border-color:#60a5fa;box-shadow:0 0 0 4px #3b82f62e}.dpV1-search input::placeholder{color:#94a3b8;font-weight:500}.dpV1-card-scroll{flex:1;overflow-y:auto;padding-right:6px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.dpV1-card-scroll::-webkit-scrollbar{width:8px}.dpV1-card-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.dpV1-card-scroll::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.dpV1-order-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--gray-50);border:1px solid var(--gray-200);align-items:center}.dpV1-order-no{font-size:var(--fs-16);font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dpV1-order-no2{font-size:var(--fs-12);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dpV1-order-mat{margin-top:2px;font-size:var(--fs-16);color:var(--muted);font-weight:400;font-family:var(--pps-font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dpV1-order-basic{font-size:var(--fs-16);font-weight:400;color:var(--muted);margin-top:2px}.dpV1-order-badges{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.dpV1-order-row-norouting{border-color:#fecaca;background:#fff1f2}.dpV1-order-row-norouting .dpV1-order-no{color:var(--red)}.dpV1-order-row-nolinematerial{border-color:var(--amber-border);background:var(--amber-bg)}.dpV1-order-row-nolinematerial .dpV1-order-no{color:var(--amber)}.dpV1-order-row-usagezero{border-color:#fdba74;background:#fff7ed}.dpV1-order-row-usagezero .dpV1-order-no{color:#9a3412}.dpV1-order-row-locked{opacity:.75;filter:grayscale(.1)}.dpV1-badge{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:999px;border:1px solid transparent;font-size:var(--fs-12);font-weight:600;letter-spacing:.2px}.dpV1-badge-red{border-color:#fecaca;background:#fee2e2;color:#991b1b}.dpV1-badge-amber{border-color:#fde68a;background:#fef3c7;color:#92400e}.dpV1-badge-orange{border-color:#fdba74;background:#ffedd5;color:#9a3412}.dpV1-badge-gray{border-color:#cbd5e1;background:#f1f5f9;color:#475569}.dpV1-badge-sky{border-color:#7dd3fc;background:#e0f2fe;color:#0369a1}.dpV1-btn-ghost{width:34px;height:34px;border-radius:8px;border:1px solid var(--gray-300);background:var(--card);color:var(--gray-600);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:transform .12s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,color .18s ease;box-shadow:0 1px 3px #0000000f}.dpV1-btn-ghost:hover{background:var(--gray-50);border-color:#7dd3fc;color:var(--text);box-shadow:0 6px 16px #00000014}.dpV1-btn-ghost:active{transform:scale(.98)}.dpV1-btn-ghost:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.dpV1-btn-ghost:focus-visible{outline:none;border-color:#60a5fa;box-shadow:0 0 0 4px #3b82f62e,0 6px 16px #00000014}.dpV1-btn-add{width:40px;height:40px;border-radius:999px;border:1.5px solid var(--green-border);background:var(--green-bg);color:#16a34a;cursor:pointer;transition:all .18s ease;display:inline-flex;align-items:center;justify-content:center;padding:0;box-shadow:0 1px 3px #0000000d}.dpV1-btn-add:hover{background:var(--green-soft);border-color:#4ade80;box-shadow:0 2px 4px #22c55e26}.dpV1-btn-add:active{transform:scale(.98)}.dpV1-btn-add:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.dpV1-btn-primary{height:40px;padding:0 14px;border-radius:12px;border:1px solid var(--primary-lighter);background:var(--primary-light);color:var(--primary);font-size:var(--fs-16);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .18s ease}.dpV1-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.dpV1-btn-primary:active{transform:scale(.98)}.dpV1-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.dpV1-btn-danger{height:34px;padding:0 14px;border-radius:12px;border:1px solid #fecaca;background:var(--red-light);color:var(--red);font-size:var(--fs-16);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .18s ease;width:120px}.dpV1-btn-danger:hover{background:var(--red-soft);border-color:#fca5a5}.dpV1-btn-danger:active{transform:scale(.98)}.dpV1-btn-danger:disabled{opacity:.6;cursor:not-allowed;transform:none}.dpV1-right{display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow);background:var(--card)}.dpV1-right-header{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--card)}.dpV1-right-body{flex:1;padding:16px;overflow-y:auto;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--border) transparent}.dpV1-right-body::-webkit-scrollbar{width:8px}.dpV1-right-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.dpV1-right-body::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.dpV1-plan-row{border:1px solid var(--gray-200);background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.dpV1-plan-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:10px;border-bottom:1px solid var(--gray-200);margin-bottom:12px}.dpV1-plan-title{font-size:var(--fs-16);font-weight:600;color:var(--text)}.dpV1-plan-sub{font-size:var(--fs-13);font-weight:700;color:var(--muted)}.dpV1-plan-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}@media(max-width:1150px){.dpV1-plan-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.dpV1-plan-grid{grid-template-columns:1fr}}.dpV1-label{font-size:var(--fs-12);color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.dpV1-field{display:grid;gap:6px;min-width:0}.dpV1-input,.dpV1-select{width:100%;height:40px;border-radius:10px;border:1px solid var(--gray-300);background:#e8edf5;color:var(--text);padding:0 12px;font-size:var(--fs-16);font-weight:500;outline:none;transition:all .2s}.dpV1-input:focus,.dpV1-select:focus{border-color:var(--primary);background:var(--card);box-shadow:0 0 0 3px #0369a11a}.dpV1-input:disabled,.dpV1-select:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.dpV1-input-warn{border-color:#fdba74!important;box-shadow:0 0 0 3px #fb923c2e!important}.dpV1-hint-warn{font-size:var(--fs-12);font-weight:800;color:#9a3412}.dpV1-empty{color:var(--muted);font-weight:500;padding:16px;background:var(--gray-50);border:1px dashed var(--border);border-radius:var(--radius-sm);text-align:center}.dpV1-chip{height:34px;padding:0 12px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;font-weight:600;color:#0f172a;transition:all .15s ease;border-radius:12px}.dpV1-cal-cell{border:1px solid #e2e8f0;background:#fff;border-radius:14px;padding:10px;cursor:pointer;min-height:120px;transition:all .15s ease}.dpV1-cal-cell:hover{background:#f8fafc;border-color:#7dd3fc;box-shadow:0 8px 22px #0000000f}.dpV1-cal-pill{border-radius:999px;padding:2px 10px;display:inline-flex;width:fit-content;border:1px solid transparent;font-weight:600;font-size:var(--fs-12)}.dpV1-tab{height:34px;padding:0 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;font-weight:600;cursor:pointer;transition:all .15s ease}.dpV1-tab:hover{background:#f8fafc}.dpV1-tooltip-wrap{position:relative;display:inline-flex;align-items:center}.dpV1-tooltip{position:absolute;left:50%;bottom:calc(100% + 10px);transform:translate(-50%);z-index:50;max-width:320px;white-space:normal;padding:8px 10px;border-radius:10px;background:#0f172a;color:#fff;font-size:var(--fs-12);line-height:1.35;box-shadow:0 10px 25px #0003;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s ease,transform .15s ease}.dpV1-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#0f172a}.dpV1-tooltip-wrap:hover .dpV1-tooltip,.dpV1-tooltip-wrap:focus-within .dpV1-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-2px)}@media(max-height:720px){.dpV1-page{overflow:auto}}@media(max-width:1150px){.dpV1-page{grid-template-columns:1fr;padding:16px;gap:12px;overflow:auto}.dpV1-left{padding-right:0}.dpV1-right-body,.dpV1-card{padding:14px}}@media(max-width:640px){.dpV1-right-header{padding:14px}.dpV1-right-body{padding:12px}}@media(max-width:480px){.dpV1-page{padding:12px}.dpV1-order-row{padding:10px 12px;gap:10px}.dpV1-btn-ghost,.dpV1-btn-add{width:38px;height:38px}.dpV1-input,.dpV1-select{height:38px;font-size:var(--fs-16)}}.dpV1-cal-today{border:2px solid #2563eb;background:#eff6ff;box-shadow:0 0 0 3px #2563eb26,0 6px 16px #00000014}.dpV1-cal-today>div:first-child{color:#1d4ed8}.dpV1-cal-today:hover{background:#e0f2fe;border-color:#1d4ed8}.dpV1-locked-indicator{height:32px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px dashed #fecaca;background:#fff1f2;color:#991b1b;font-size:var(--fs-14);font-weight:800;white-space:nowrap;cursor:not-allowed;-webkit-user-select:none;user-select:none;opacity:.9}.dpV1-order-row{margin-bottom:10px}.dpV1-order-row:last-child{margin-bottom:0}.dpV1-btn-nav{height:34px;padding:0 12px;border-radius:12px;border:1px solid var(--gray-300);background:var(--card);color:var(--gray-700);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;min-width:96px}.dpV1-btn-nav:hover{background:var(--gray-50);border-color:#7dd3fc;box-shadow:0 6px 16px #00000014}.dpV1-btn-nav:active{transform:scale(.98)}.dpV1-btn-nav:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.dpV1-chip{height:34px;padding:0 12px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;font-weight:800;color:#0f172a;border-radius:12px;width:120px}.dpV1-chip.active{border-color:#7dd3fc;background:#e0f2fe}.dpV1-chip:hover{background:#f8fafc}.dpV1-btn-primary{height:34px;padding:0 12px;border-radius:10px;border:1px solid #bae6fd;background:#e0f2fe;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;width:120px}.dpV1-btn-primary:disabled{opacity:.6;cursor:not-allowed}.dpV1-cal-cell{border:1px solid #e2e8f0;background:#fff;border-radius:12px;padding:10px;cursor:pointer;min-height:132px}.dpV1-cal-cell:hover{background:#f8fafc}.dpV1-cal-cell-today{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb2e;background:#eff6ff}.dpV1-cal-daynum{font-weight:600;color:#0f172a}.dpV1-cal-pill{border-radius:999px;padding:2px 10px;display:inline-block;width:fit-content;border:1px solid transparent;font-weight:800}.dpV1-cal-pill-purple{background:#f5f3ff;border-color:#ddd6fe;color:#6d28d9}.dpV1-cal-pill-blue{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.dpV1-cal-pill-green{background:#ecfdf5;border-color:#bbf7d0;color:#047857}.dpV1-cal-pill-red{background:#fff1f2;border-color:#fecdd3;color:#b91c1c}.dpV1-cal-nav{display:flex;gap:8px;flex-wrap:wrap}.dpV1-cal-navbtn{height:34px;padding:0 12px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;font-weight:600;cursor:pointer;white-space:nowrap}.dpV1-cal-navbtn:hover{background:#f8fafc;border-color:#7dd3fc}.dpV1-drawer-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;justify-content:flex-end;z-index:50}.dpV1-drawer{width:min(720px,96vw);height:100%;background:#fff;border-left:1px solid #e2e8f0;display:flex;flex-direction:column}.dpV1-drawer-header{padding:14px 16px;border-bottom:1px solid #e2e8f0;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.dpV1-drawer-tabs{padding:10px 16px;border-bottom:1px solid #e2e8f0;display:flex;gap:8px;flex-wrap:wrap}.dpV1-tab{height:34px;padding:0 12px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;font-weight:600;cursor:pointer;white-space:nowrap}.dpV1-tab.active{border-color:#7dd3fc;background:#e0f2fe}.dpV1-drawer-body{padding:14px 16px;overflow:auto}.dpV1-mini-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.dpV1-lockbadge{display:inline-flex;align-items:center;height:34px;padding:0 12px;border-radius:999px;border:1px solid #cbd5e1;background:#f1f5f9;color:#475569;font-weight:600;white-space:nowrap;-webkit-user-select:none;user-select:none}.dpV1-kbadge{display:inline-flex;align-items:center;height:30px;padding:0 10px;border-radius:999px;border:1px solid #ddd6fe;background:#f5f3ff;color:#6d28d9;font-weight:600;white-space:nowrap}.dpV1-order-list{display:flex;flex-direction:column;gap:2px}.dpV1-order-row-blocked{border-color:#fecaca;background:#fff1f2}.dpV1-page button,.dpV1-page a,.dpV1-page input,.dpV1-page select,.dpV1-page textarea{color:var(--text)}.dpV1-page button{-webkit-text-fill-color:currentColor;color:var(--text)}.dpV1-page button svg,.dpV1-page .dpV1-btn-ghost svg,.dpV1-page .dpV1-btn-add svg,.dpV1-page .dpV1-btn-primary svg,.dpV1-page .dpV1-btn-danger svg,.dpV1-page .dpV1-btn-nav svg,.dpV1-page .dpV1-cal-navbtn svg{color:currentColor}.dpV1-page .dpV1-btn-ghost{color:var(--gray-700);background:var(--card)}.dpV1-page .dpV1-btn-add{color:#16a34a;background:var(--green-bg)}.dpV1-page .dpV1-btn-primary{color:var(--primary);background:var(--primary-light)}.dpV1-page .dpV1-btn-danger{color:var(--red);background:var(--red-light)}.dpV1-page .dpV1-btn-nav,.dpV1-page .dpV1-cal-navbtn{color:var(--gray-700);background:var(--card)}.dpV1-page .dpV1-tab,.dpV1-page .dpV1-chip{color:var(--text);background:#fff}.dpV1-page .dpV1-tab.active,.dpV1-page .dpV1-chip.active{color:var(--primary)}.dpV1-page .dpV1-input,.dpV1-page .dpV1-select,.dpV1-page .dpV1-search input{color:var(--text);-webkit-text-fill-color:var(--text);caret-color:var(--text)}@media(forced-colors:active){.dpV1-page{forced-color-adjust:auto}.dpV1-page .dpV1-btn-ghost,.dpV1-page .dpV1-btn-add,.dpV1-page .dpV1-btn-primary,.dpV1-page .dpV1-btn-danger,.dpV1-page .dpV1-btn-nav,.dpV1-page .dpV1-cal-navbtn,.dpV1-page .dpV1-tab,.dpV1-page .dpV1-chip{border:1px solid ButtonText;background:ButtonFace;color:ButtonText}.dpV1-page .dpV1-input,.dpV1-page .dpV1-select,.dpV1-page .dpV1-search input{border:1px solid ButtonText;background:Field;color:FieldText}}.dpV1-dt-wrap{position:relative;display:flex;align-items:center;gap:8px}.dpV1-dt-text{flex:1 1 auto;min-width:0}.dpV1-dt-btn{flex:0 0 44px;height:44px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;border-radius:12px;cursor:pointer;font-size:var(--fs-18);line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:.18s ease}.dpV1-dt-btn:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8}.dpV1-dt-btn:disabled{opacity:.55;cursor:not-allowed}.dpV1-dt-native{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.dpV1-lunch{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:4px 10px;border-radius:999px;border:1px solid #fde68a;background:#fffbeb;color:#92400e;font-size:var(--fs-12);font-weight:700;width:fit-content}.dpV1-lunch-icon{font-size:var(--fs-14);line-height:1}.dpV1-lunch-text{font-family:var(--pps-font-mono)}.dpV2-page{--bg: #f8fafc;--card: #ffffff;--card-2: #ffffff;--surface: #f1f5f9;--border: #cbd5e1;--border-soft: #e5e7eb;--border-strong: #9ca3af;--text: #111827;--text-soft: #374151;--text-muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-soft: #e0f2fe;--primary-soft-2: #bae6fd;--primary-border: #7dd3fc;--green: #166534;--green-soft: #ecfdf5;--green-soft-2: #d1fae5;--green-border: #86efac;--red: #991b1b;--red-soft: #fee2e2;--red-soft-2: #fecaca;--red-border: #fecaca;--amber: #92400e;--amber-soft: #fffbeb;--amber-soft-2: #fef3c7;--amber-border: #fde68a;--purple: #6d28d9;--purple-soft: #f5f3ff;--purple-border: #ddd6fe;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .2);--radius-xs: 10px;--radius-sm: 10px;--radius: 16px;--radius-lg: 16px;--radius-xl: 20px;min-height:100%;width:100%;padding:16px 24px 24px;background:var(--bg);color:var(--text);box-sizing:border-box}.dpV2-page *,.dpV2-page *:before,.dpV2-page *:after{box-sizing:border-box}.dpV2-page button,.dpV2-page input,.dpV2-page select,.dpV2-page textarea{font:inherit;color:var(--text);-webkit-text-fill-color:currentColor}.dpV2-page button svg{color:currentColor;flex:0 0 auto}.dpV2-page-redesign{display:grid;gap:14px}.dpV2-card{background:var(--card);border:1px solid rgba(203,213,225,.78);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:18px}.dpV2-topbar{display:grid;gap:14px;background:radial-gradient(circle at top right,rgba(186,230,253,.3),transparent 28%),linear-gradient(180deg,#fff,#fbfdff)}.dpV2-topbar-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.dpV2-title{font-size:var(--fs-24);line-height:1.15;font-weight:700;color:var(--text);letter-spacing:0}.dpV2-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-16);line-height:1.5;font-weight:400}.dpV2-sub{font-size:var(--fs-16);font-weight:400;color:var(--text-muted)}.dpV2-topbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.dpV2-filter-row{display:grid;grid-template-columns:180px 180px minmax(220px,1fr) minmax(220px,1fr);gap:14px;align-items:center}.dpV2-summary-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.dpV2-summary-card{border:1px solid var(--border-soft);border-radius:16px;background:linear-gradient(180deg,#fff,#f8fbff);padding:16px 18px;min-width:0;box-shadow:var(--shadow)}.dpV2-summary-label{font-size:var(--fs-12);color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.dpV2-summary-value{margin-top:6px;font-size:var(--fs-22);line-height:1.1;font-weight:700;color:var(--text);letter-spacing:0}.dpV2-inline-warn,.dpV2-inline-info{padding:14px 16px;border-radius:16px;font-size:var(--fs-13);font-weight:700;line-height:1.5}.dpV2-inline-warn{border:1px solid var(--red-border);background:#fff7f7;color:var(--red)}.dpV2-inline-info{border:1px solid var(--primary-border);background:var(--primary-soft);color:var(--primary)}.dpV2-main-grid{display:grid;grid-template-columns:minmax(300px,420px) minmax(0,1fr);gap:16px;min-height:0;align-items:start}.dpV2-left-board,.dpV2-right-board{min-width:0}.dpV2-right-board{display:grid;gap:14px;min-width:0}.dpV2-section-title{font-size:var(--fs-16);font-weight:700;color:var(--text);line-height:1.25}.dpV2-section-sub{font-size:var(--fs-13);font-weight:700;color:var(--text-muted)}.dpV2-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.dpV2-chip-row{display:flex;gap:10px;flex-wrap:wrap}.dpV2-search{position:relative;min-width:0}.dpV2-search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;font-size:var(--fs-16)}.dpV2-search input{width:100%;height:40px;border-radius:16px;border:1px solid #d1d5db;background:#e8edf5;color:var(--text);padding:0 12px 0 44px;font-size:var(--fs-16);font-weight:500;outline:none;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}.dpV2-search input:hover{background:#eef3f8;border-color:#cbd5e1}.dpV2-search input:focus{background:#fff;border-color:#60a5fa;box-shadow:0 0 0 4px #3b82f62e}.dpV2-search input::placeholder{color:#94a3b8;font-weight:500}.dpV2-field{display:grid;gap:7px;min-width:0}.dpV2-label{font-size:var(--fs-12);color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.dpV2-input,.dpV2-select{width:100%;height:40px;border-radius:10px;border:1px solid #d1d5db;background:#e8edf5;color:var(--text);padding:0 12px;font-size:var(--fs-16);font-weight:500;outline:none;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}.dpV2-input:hover,.dpV2-select:hover{background:#eef3f8;border-color:#cbd5e1}.dpV2-input:focus,.dpV2-select:focus{border-color:#60a5fa;background:#fff;box-shadow:0 0 0 4px #3b82f62e}.dpV2-input:disabled,.dpV2-select:disabled{background:var(--surface);color:#94a3b8;cursor:not-allowed}.dpV2-input::placeholder{color:#94a3b8;font-weight:500}.dpV2-input-warn{border-color:#fb923c!important;box-shadow:0 0 0 4px #fb923c1f!important}.dpV2-hint-warn{font-size:var(--fs-12);font-weight:700;color:#9a3412}.dpV2-btn-ghost,.dpV2-btn-add,.dpV2-btn-primary,.dpV2-btn-danger,.dpV2-chip{transition:background .15s ease,border-color .15s ease,transform .1s ease,box-shadow .15s ease,color .15s ease}.dpV2-btn-ghost:active,.dpV2-btn-add:active,.dpV2-btn-primary:active,.dpV2-btn-danger:active,.dpV2-chip:active{transform:scale(.98)}.dpV2-btn-ghost{width:34px;height:34px;min-width:34px;border-radius:8px;border:1px solid #d1d5db;background:#fff;color:#4b5563;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000000f}.dpV2-btn-ghost:hover{background:#f9fafb;border-color:#7dd3fc;color:var(--text);transform:translateY(-1px)}.dpV2-btn-add{width:40px;height:40px;min-width:40px;border-radius:999px;border:1.5px solid var(--green-border);background:var(--green-soft);color:#16a34a;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000000d;align-self:center}.dpV2-btn-add:hover{background:var(--green-soft-2);border-color:#4ade80;transform:translateY(-1px)}.dpV2-btn-primary{height:40px;padding:0 14px;border-radius:12px;border:1px solid var(--primary-soft-2);background:var(--primary-soft);color:var(--primary);font-size:var(--fs-16);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:none;white-space:nowrap}.dpV2-btn-primary:hover{background:var(--primary-soft-2);border-color:var(--primary-border);transform:translateY(-1px)}.dpV2-btn-danger{height:34px;padding:0 14px;border-radius:12px;border:1px solid var(--red-border);background:var(--red-soft);color:var(--red);font-size:var(--fs-16);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.dpV2-btn-danger:hover{background:var(--red-soft-2);border-color:#fca5a5;transform:translateY(-1px)}.dpV2-btn-ghost:disabled,.dpV2-btn-add:disabled,.dpV2-btn-primary:disabled,.dpV2-btn-danger:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.dpV2-chip{height:34px;padding:0 12px;border-radius:999px;border:1px solid #cbd5e1;background:#f8fafc;color:#475569;font-size:var(--fs-12);font-weight:600;cursor:pointer;white-space:nowrap}.dpV2-chip:hover{background:#f1f5f9;border-color:#94a3b8;transform:translateY(-1px)}.dpV2-chip.active{border-color:#7dd3fc;background:#e0f2fe;color:#0369a1}.dpV2-line-grid{display:grid;gap:12px;max-height:680px;overflow:auto;padding-right:2px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.dpV2-line-grid::-webkit-scrollbar{width:8px}.dpV2-line-grid::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.dpV2-line-grid::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dpV2-line-card{width:100%;text-align:left;border:1px solid var(--border-soft);background:#fff;border-radius:16px;padding:16px 18px;cursor:pointer;box-shadow:var(--shadow);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .1s ease}.dpV2-line-card:hover{background:#fff;border-color:var(--primary-border);box-shadow:0 10px 20px #0f172a0f;transform:translateY(-1px)}.dpV2-line-card.active{background:linear-gradient(180deg,#f0f9ff,#eff6ff);border-color:var(--primary-border);box-shadow:0 12px 24px #0ea5e91f}.dpV2-line-name{font-size:var(--fs-16);font-weight:700;color:var(--text);line-height:1.3;word-break:break-word}.dpV2-line-meta{margin-top:8px;font-size:var(--fs-13);color:var(--text-muted);font-weight:700;line-height:1.5}.dpV2-vlist-outer{height:min(66vh,780px);min-height:560px;overflow:auto;padding-right:2px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.dpV2-vlist-outer::-webkit-scrollbar{width:8px;height:8px}.dpV2-vlist-outer::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.dpV2-vlist-outer::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dpV2-order-list{display:flex;flex-direction:column;gap:12px}.dpV2-order-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:stretch;padding:12px 14px;border-radius:16px;background:#f9fafb;border:1px solid #e5e7eb;box-shadow:var(--shadow);min-height:auto}.dpV2-order-row:hover{background:#fff;border-color:var(--border)}.dpV2-order-row-blocked{background:#fff1f2;border-color:#fecaca}.dpV2-order-no{font-size:var(--fs-16);font-weight:700;color:var(--text);line-height:1.3;word-break:break-word}.dpV2-order-no2{margin-top:4px;font-size:var(--fs-12);font-weight:600;color:var(--text);line-height:1.45;white-space:normal;word-break:break-word}.dpV2-order-mat{margin-top:4px;font-size:var(--fs-16);color:var(--text-muted);font-weight:400;line-height:1.5}.dpV2-order-basic{margin-top:5px;font-size:var(--fs-16);color:var(--text-muted);font-weight:400;line-height:1.5;white-space:normal;word-break:break-word}.dpV2-order-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px;align-items:center}.dpV2-badge{display:inline-flex;align-items:center;min-height:24px;padding:0 10px;border-radius:999px;border:1px solid transparent;font-size:var(--fs-12);font-weight:600;letter-spacing:.2px}.dpV2-badge-red{border-color:var(--red-border);background:var(--red-soft);color:var(--red)}.dpV2-badge-amber{border-color:var(--amber-border);background:var(--amber-soft);color:var(--amber)}.dpV2-badge-orange{border-color:#fdba74;background:#ffedd5;color:#9a3412}.dpV2-badge-gray{border-color:var(--border);background:#f1f5f9;color:var(--text-soft)}.dpV2-badge-sky{border-color:var(--primary-border);background:var(--primary-soft);color:var(--primary)}.dpV2-badge-purple{border-color:var(--purple-border);background:var(--purple-soft);color:var(--purple)}.dpV2-draft-list{display:grid;gap:14px}.dpV2-plan-row{border:1px solid #e5e7eb;background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:16px}.dpV2-plan-row-redesign{background:linear-gradient(180deg,#fff,#fbfdff)}.dpV2-plan-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding-bottom:10px;margin-bottom:12px;border-bottom:1px solid #e5e7eb}.dpV2-plan-title{font-size:var(--fs-16);font-weight:700;color:var(--text);line-height:1.3;word-break:break-word}.dpV2-plan-sub{font-size:var(--fs-13);font-weight:700;color:var(--text-muted)}.dpV2-plan-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.dpV2-plan-row .dpV2-btn-danger{width:44px;min-width:44px;height:44px;padding:0;border-radius:12px;font-size:0}.dpV2-plan-row .dpV2-btn-danger svg{width:18px;height:18px}.dpV2-empty{padding:26px 18px;border:1px dashed var(--border);border-radius:16px;background:#fbfdff;color:var(--text-muted);text-align:center;font-size:var(--fs-13);font-weight:700;line-height:1.6}.dpV2-dt-wrap{position:relative;display:flex;align-items:center;gap:8px}.dpV2-dt-text{flex:1 1 auto;min-width:0}.dpV2-dt-btn{flex:0 0 40px;height:40px;border:1px solid #d1d5db;background:#fff;color:var(--text);border-radius:10px;cursor:pointer;font-size:var(--fs-16);line-height:1;display:inline-flex;align-items:center;justify-content:center}.dpV2-dt-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong)}.dpV2-dt-btn:disabled{opacity:.55;cursor:not-allowed}.dpV2-dt-native{position:absolute;width:0;height:0;opacity:0;pointer-events:none}@media(max-width:1480px){.dpV2-plan-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:1180px){.dpV2-page{padding:14px 16px 20px}.dpV2-filter-row{grid-template-columns:1fr 1fr}.dpV2-summary-row{grid-template-columns:repeat(3,minmax(0,1fr))}.dpV2-main-grid{grid-template-columns:1fr}.dpV2-line-grid{max-height:360px}.dpV2-vlist-outer{height:540px;min-height:440px}.dpV2-plan-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.dpV2-page{padding:12px}.dpV2-title{font-size:var(--fs-22)}.dpV2-topbar-head{flex-direction:column;align-items:stretch}.dpV2-topbar-actions{width:100%;justify-content:stretch}.dpV2-topbar-actions>*{flex:1 1 auto}.dpV2-filter-row{grid-template-columns:1fr}.dpV2-summary-row{grid-template-columns:1fr 1fr}.dpV2-section-head{flex-direction:column;align-items:stretch}.dpV2-chip-row{width:100%}.dpV2-chip{flex:1 1 auto;text-align:center}.dpV2-order-row{grid-template-columns:minmax(0,1fr);min-height:auto}.dpV2-btn-add{width:100%;border-radius:12px;min-height:40px}.dpV2-plan-grid{grid-template-columns:1fr}.dpV2-plan-row .dpV2-btn-danger{width:40px;min-width:40px;height:40px;border-radius:12px}.dpV2-order-mat,.dpV2-order-basic,.dpV2-input,.dpV2-select,.dpV2-search input,.dpV2-btn-primary,.dpV2-btn-danger{font-size:var(--fs-14)}}@media(max-width:480px){.dpV2-summary-row{grid-template-columns:1fr}.dpV2-card{padding:14px}.dpV2-title{font-size:var(--fs-20)}.dpV2-order-no{font-size:var(--fs-15)}.dpV2-order-no2,.dpV2-order-mat,.dpV2-order-basic{font-size:var(--fs-12)}}@media(forced-colors:active){.dpV2-page{forced-color-adjust:auto}.dpV2-card,.dpV2-line-card,.dpV2-order-row,.dpV2-plan-row,.dpV2-summary-card{border:1px solid CanvasText;background:Canvas;color:CanvasText}.dpV2-btn-ghost,.dpV2-btn-add,.dpV2-btn-primary,.dpV2-btn-danger,.dpV2-chip{border:1px solid ButtonText;background:ButtonFace;color:ButtonText}.dpV2-input,.dpV2-select,.dpV2-search input{border:1px solid ButtonText;background:Field;color:FieldText}}.dp3-page{--bg: #f8fafc;--card: #ffffff;--card-2: #f9fafb;--surface: #f1f5f9;--border: #cbd5e1;--border-soft: #e2e8f0;--border-strong: #94a3b8;--text: #111827;--text-soft: #475569;--text-muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-soft: #e0f2fe;--primary-soft-2: #bae6fd;--green: #166534;--green-soft: #ecfdf5;--green-border: #86efac;--amber: #92400e;--amber-soft: #fef3c7;--amber-border: #fde68a;--red: #991b1b;--red-soft: #fee2e2;--red-border: #fecaca;--violet: #6d28d9;--violet-soft: #f5f3ff;--violet-border: #ddd6fe;--teal: #0f766e;--teal-soft: #ccfbf1;--teal-border: #99f6e4;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .14);--radius-xs: .5rem;--radius-sm: .625rem;--radius: 1rem;--radius-lg: 1.125rem;--sidebar-w: 22rem;--sidebar-w-collapsed: 3.75rem;--kpi-h: 3rem;--header-h: 3.25rem;--tab-h: 2.75rem;min-height:100%;height:100%;display:grid;grid-template-rows:var(--kpi-h) 1fr;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-15);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.dp3-page *,.dp3-page *:before,.dp3-page *:after{box-sizing:border-box}.dp3-page button,.dp3-page input,.dp3-page select,.dp3-page textarea{font:inherit}.dp3-page button{-webkit-tap-highlight-color:transparent;appearance:none;-webkit-appearance:none;-moz-appearance:none}.dp3-page input,.dp3-page select,.dp3-page textarea{appearance:none;-webkit-appearance:none;-moz-appearance:none}.dp3-page button,.dp3-page .dp3-btn,.dp3-page .dp3-icon-btn,.dp3-page .dp3-collapse-btn,.dp3-page .dp3-add-btn,.dp3-page .dp3-cal-navbtn,.dp3-page .dp3-chip,.dp3-page .dp3-tab,.dp3-page .dp3-drawer-tab,.dp3-page .dp3-dt-btn,.dp3-page .dp3-kpi-select,.dp3-page select,.dp3-page input,.dp3-page textarea{-webkit-text-fill-color:currentColor}.dp3-page button,.dp3-page input,.dp3-page select,.dp3-page textarea{color:inherit}.dp3-page :focus-visible{outline:0;box-shadow:0 0 0 .1875rem #0369a124}.dp3-main-body,.dp3-vlist-outer,.dp3-kb-col-body,.dp3-adj-col-body,.dp3-drawer-body,.dp3-tab-bar,.dp3-gantt-wrap,.dp3-drawer-tabs{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.dp3-main-body::-webkit-scrollbar,.dp3-vlist-outer::-webkit-scrollbar,.dp3-kb-col-body::-webkit-scrollbar,.dp3-adj-col-body::-webkit-scrollbar,.dp3-drawer-body::-webkit-scrollbar,.dp3-gantt-wrap::-webkit-scrollbar,.dp3-drawer-tabs::-webkit-scrollbar{width:.5rem;height:.5rem}.dp3-main-body::-webkit-scrollbar-thumb,.dp3-vlist-outer::-webkit-scrollbar-thumb,.dp3-kb-col-body::-webkit-scrollbar-thumb,.dp3-adj-col-body::-webkit-scrollbar-thumb,.dp3-drawer-body::-webkit-scrollbar-thumb,.dp3-gantt-wrap::-webkit-scrollbar-thumb,.dp3-drawer-tabs::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}.dp3-kpi{display:flex;align-items:center;gap:.5rem;min-width:0;padding:0 1rem;background:#74767d;border-bottom:1px solid #b7c5db;color:#e2e8f0;overflow-x:auto;overflow-y:hidden}.dp3-kpi-brand{flex-shrink:0;padding-right:.75rem;margin-right:.25rem;border-right:1px solid #334155;font-size:var(--fs-11);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#94a3b8;white-space:nowrap}.dp3-kpi-ws{width:.5rem;height:.5rem;flex-shrink:0;border-radius:999px;background:#22c55e;animation:dp3-pulse 2.2s ease-in-out infinite}@keyframes dp3-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.9)}}.dp3-kpi-pill{display:inline-flex;align-items:center;gap:.3125rem;min-height:1.75rem;padding:0 .625rem;border-radius:999px;border:1px solid transparent;white-space:nowrap;-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:var(--fs-12);font-weight:700}.dp3-kpi-pill b{font-weight:800}.dp3-kpi-pill.pu{background:#7c3aed24;border-color:#c4b5fd59;color:#c4b5fd}.dp3-kpi-pill.te{background:#0f766e2e;border-color:#99f6e438;color:#99f6e4}.dp3-kpi-pill.gn{background:#16a34a29;border-color:#86efac3d;color:#86efac}.dp3-kpi-pill.am{background:#d9770629;border-color:#fde68a33;color:#fde68a}.dp3-kpi-pill.rd{background:#dc262629;border-color:#fecaca38;color:#fca5a5}.dp3-kpi-sep{width:1px;height:1.25rem;flex-shrink:0;background:#334155}.dp3-kpi-right{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-shrink:0}.dp3-kpi-clock{font-size:var(--fs-12);color:#94a3b8;white-space:nowrap}.dp3-kpi-select{height:1.875rem;min-width:5rem;padding:0 2rem 0 .625rem;border-radius:.625rem;border:1px solid #334155;background:#8f9092;color:#e2e8f0;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);background-position:calc(100% - .95rem) calc(50% - .125rem),calc(100% - .65rem) calc(50% - .125rem);background-size:.3125rem .3125rem,.3125rem .3125rem;background-repeat:no-repeat}.dp3-kpi-select:focus,.dp3-kpi-select:hover{border-color:#38bdf8}.dp3-body{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:0;overflow:hidden;transition:grid-template-columns .2s ease}.dp3-body.collapsed{grid-template-columns:var(--sidebar-w-collapsed) 1fr}.dp3-sidebar{display:flex;flex-direction:column;min-height:0;overflow:hidden;background:var(--card);border-right:1px solid var(--border)}.dp3-sb-head{display:flex;align-items:center;justify-content:space-between;gap:.625rem;min-height:3.25rem;padding:.75rem .75rem .75rem 1rem;border-bottom:1px solid var(--border);background:var(--card)}.dp3-sb-title{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--fs-12);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.dp3-collapse-btn{width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--border);border-radius:.625rem;background:var(--card);color:var(--text-soft);cursor:pointer;transition:all .2s ease}.dp3-collapse-btn:hover{background:#f8fafc;border-color:var(--primary-soft-2);color:var(--text)}.dp3-sb-inner{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.dp3-body.collapsed .dp3-sb-inner{display:none}.dp3-body.collapsed .dp3-sb-head{justify-content:center;padding-inline:.5rem}.dp3-body.collapsed .dp3-sb-title{display:none}.dp3-search{position:relative;padding:.75rem .75rem 0;flex-shrink:0}.dp3-search input{width:100%;height:2.75rem;padding:0 .875rem 0 2.25rem;border-radius:.875rem;border:1px solid var(--border);background:#e8edf5;color:var(--text);transition:all .18s ease}.dp3-search input::placeholder{color:#94a3b8;-webkit-text-fill-color:#94a3b8}.dp3-search input:focus,.dp3-search input:hover{border-color:var(--primary);background:var(--card)}.dp3-search-icon{position:absolute;left:1.4375rem;top:2rem;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;display:inline-flex;align-items:center}.dp3-chips{display:flex;flex-wrap:wrap;gap:.375rem;padding:.75rem;flex-shrink:0}.dp3-chip{min-height:2rem;padding:0 .75rem;border-radius:999px;border:1px solid var(--border-soft);background:#fff;color:var(--text);cursor:pointer;white-space:nowrap;font-size:var(--fs-12);font-weight:700;transition:all .18s ease}.dp3-chip:hover:not(.active){background:#f8fafc;border-color:var(--primary-soft-2)}.dp3-chip.active{background:var(--primary-soft);border-color:var(--primary-soft-2);color:var(--primary)}.dp3-orders-hd{display:flex;align-items:baseline;justify-content:space-between;gap:.625rem;padding:.25rem .875rem .5rem;flex-shrink:0}.dp3-orders-hd-label{font-size:var(--fs-12);font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.dp3-orders-hd-count{font-size:var(--fs-12);color:var(--text-muted)}.dp3-orders-scroll{flex:1;min-height:0;overflow:hidden}.dp3-vlist-outer{height:100%;overflow-y:auto}.dp3-order-list{display:flex;flex-direction:column;gap:.625rem;padding:0 .5rem .75rem}.dp3-order-card{position:relative;min-height:6.5rem;padding:.875rem;border:1px solid var(--border-soft);border-radius:.875rem;background:var(--card-2);cursor:pointer;transition:all .18s ease}.dp3-order-card:hover{background:var(--card);border-color:var(--primary-soft-2);box-shadow:var(--shadow-sm)}.dp3-order-card.blocked{border-color:var(--red-border);background:#fff1f2}.dp3-order-card.blocked:hover{border-color:#fca5a5}.dp3-order-no{color:var(--text);font-size:var(--fs-15);font-weight:800;word-break:break-word}.dp3-order-mat{margin-top:.1875rem;color:var(--text-soft);font-size:var(--fs-14);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dp3-order-meta{margin-top:.25rem;color:var(--text-muted);font-size:var(--fs-13)}.dp3-order-badges{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem;padding-right:2.5rem}.dp3-add-btn{position:absolute;top:50%;right:.625rem;transform:translateY(-50%);width:2.5rem;height:2.5rem;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid var(--green-border);border-radius:999px;background:var(--green-soft);color:var(--green);cursor:pointer;opacity:0;transition:all .18s ease;font-size:var(--fs-18);font-weight:700;line-height:1}.dp3-order-card:hover .dp3-add-btn{opacity:1}.dp3-add-btn:hover:not(:disabled){background:#d1fae5;border-color:#4ade80}.dp3-add-btn:disabled{opacity:.55;cursor:not-allowed}.dp3-main{display:grid;grid-template-rows:var(--header-h) var(--tab-h) 1fr;min-height:0;overflow:hidden;background:var(--bg)}.dp3-main-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-width:0;padding:0 1rem;background:var(--card);border-bottom:1px solid var(--border)}.dp3-plan-info{min-width:0;color:var(--text-soft);font-size:var(--fs-14)}.dp3-plan-info strong{color:var(--text);font-weight:700}.dp3-plan-info .dp3-lock-msg{margin-left:.5rem;color:var(--amber);font-weight:700}.dp3-btn-group{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex-shrink:0}.dp3-tab-bar{display:flex;align-items:center;gap:.125rem;padding:0 .75rem;overflow-x:auto;background:var(--card);border-bottom:1px solid var(--border)}.dp3-tab{display:inline-flex;align-items:center;gap:.375rem;height:var(--tab-h);padding:0 .875rem;white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer;border-bottom:2px solid transparent;background:transparent;color:var(--text-muted);font-size:var(--fs-14);font-weight:600;transition:all .18s ease}.dp3-tab:hover{color:var(--text-soft)}.dp3-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.dp3-tab-icon{display:inline-flex;align-items:center}.dp3-main-body{min-height:0;overflow-y:auto;overflow-x:hidden;padding:1rem}.dp3-cal-nav,.dp3-gantt-nav{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;margin-bottom:.875rem}.dp3-cal-title{font-size:var(--fs-17);font-weight:700;color:var(--text)}.dp3-gantt-title{font-size:var(--fs-15);font-weight:700;color:var(--text)}.dp3-cal-loading{margin-left:.5rem;font-size:var(--fs-12);color:var(--text-muted)}.dp3-cal-navbtns{display:flex;gap:.375rem;flex-wrap:wrap}.dp3-cal-navbtn{height:2rem;padding:0 .875rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);color:var(--text-soft);cursor:pointer;transition:all .18s ease;font-size:var(--fs-13);font-weight:600}.dp3-cal-navbtn:hover{border-color:var(--primary-soft-2);color:var(--primary);background:var(--primary-soft)}.dp3-cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1px;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);background:var(--border);box-shadow:var(--shadow-sm)}.dp3-cal-weekday{padding:.75rem .625rem;background:#f1f5f9;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:var(--fs-12);font-weight:700}.dp3-cal-cell{position:relative;min-height:6.75rem;padding:.625rem;background:var(--card);cursor:pointer;transition:background .18s ease}.dp3-cal-cell:hover{background:#f8fbff}.dp3-cal-cell.today{background:#fff7ed}.dp3-cal-cell.today:after{content:"";position:absolute;top:.5rem;right:.5rem;width:.5rem;height:.5rem;border-radius:999px;background:#f59e0b}.dp3-cal-cell.dim{opacity:.45;pointer-events:none}.dp3-cal-daynum{margin-bottom:.375rem;color:var(--text);font-size:var(--fs-13);font-weight:700}.dp3-cal-pills{display:flex;flex-direction:column;gap:.25rem}.dp3-cal-pill{display:inline-flex;align-items:center;gap:.25rem;width:fit-content;max-width:100%;min-height:1.375rem;padding:0 .375rem;border-radius:.5rem;font-size:var(--fs-11);font-weight:700;line-height:1.2}.dp3-cp-s{background:var(--violet-soft);color:var(--violet)}.dp3-cp-p{background:var(--primary-soft);color:var(--primary)}.dp3-cp-a{background:var(--green-soft);color:var(--green)}.dp3-cp-b{background:var(--red-soft);color:var(--red)}.dp3-kb-board{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.875rem}.dp3-kb-col,.dp3-adj-col{display:flex;flex-direction:column;min-height:0;overflow:hidden;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.dp3-kb-col-header,.dp3-adj-col-header{display:flex;align-items:center;justify-content:space-between;gap:.625rem;padding:.875rem 1rem;border-bottom:1px solid var(--border-soft)}.dp3-kb-col.s6 .dp3-kb-col-header{background:var(--violet-soft)}.dp3-kb-col.s8 .dp3-kb-col-header{background:var(--teal-soft)}.dp3-kb-col.s11 .dp3-kb-col-header{background:var(--green-soft)}.dp3-kb-col-title,.dp3-adj-col-title{font-size:var(--fs-14);font-weight:700}.dp3-kb-col.s6 .dp3-kb-col-title{color:var(--violet)}.dp3-kb-col.s8 .dp3-kb-col-title{color:var(--teal)}.dp3-kb-col.s11 .dp3-kb-col-title{color:var(--green)}.dp3-kb-count,.dp3-pa-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.75rem;height:1.75rem;padding:0 .625rem;border-radius:999px;background:#0f172a0f;color:var(--text-soft);font-size:var(--fs-12);font-weight:700}.dp3-kb-col-body,.dp3-adj-col-body{flex:1;min-height:0;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.625rem}.dp3-kb-card,.dp3-adj-card{border:1px solid var(--border-soft);border-radius:.875rem;background:var(--card);padding:.875rem;transition:all .18s ease}.dp3-kb-card:hover,.dp3-adj-card:hover{border-color:var(--primary-soft-2);box-shadow:var(--shadow-sm)}.dp3-kb-wo,.dp3-adj-wo{color:var(--text);font-size:var(--fs-13);font-weight:700;word-break:break-word}.dp3-adj-wo{display:flex;align-items:center}.dp3-kb-mat,.dp3-adj-mat{margin-top:.25rem;color:var(--text-soft);font-size:var(--fs-13)}.dp3-kb-qty{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.375rem;margin-top:.625rem;padding:.5rem;border-radius:.75rem;background:var(--card-2);border:1px solid var(--border-soft)}.dp3-kb-qty>div{text-align:center;min-width:0}.dp3-kb-qty span{display:block;margin-bottom:.125rem;color:var(--text-muted);text-transform:uppercase;font-size:var(--fs-10);font-weight:700;letter-spacing:.03em}.dp3-kb-qty b{color:var(--text);font-size:var(--fs-14);font-weight:800}.dp3-kb-qty .good{color:var(--green)}.dp3-kb-qty .bad{color:var(--red)}.dp3-kb-footer{display:flex;flex-wrap:wrap;align-items:center;gap:.375rem;margin-top:.5rem;color:var(--text-muted);font-size:var(--fs-12)}.dp3-kb-line{display:inline-flex;align-items:center;min-height:1.5rem;padding:0 .5rem;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:var(--fs-12);font-weight:700}.dp3-gantt-wrap{overflow-x:auto;border-radius:var(--radius)}.dp3-gantt{min-width:40rem;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow-sm)}.dp3-gantt-hrow,.dp3-gantt-row{display:grid;grid-template-columns:7rem 1fr}.dp3-gantt-hrow{background:#f1f5f9;border-bottom:1px solid var(--border)}.dp3-gantt-row{border-bottom:1px solid var(--border-soft)}.dp3-gantt-row:last-child{border-bottom:none}.dp3-gantt-hlabel,.dp3-gantt-rlabel{border-right:1px solid var(--border-soft)}.dp3-gantt-hlabel{padding:.625rem .75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:var(--fs-11);font-weight:700}.dp3-gantt-rlabel{display:flex;align-items:center;min-height:3.25rem;padding:0 .75rem;background:var(--card-2);color:var(--text);font-size:var(--fs-13);font-weight:700}.dp3-gantt-days,.dp3-gantt-track-bg{display:flex}.dp3-gantt-day,.dp3-gantt-tick{flex:1;border-right:1px solid var(--border-soft)}.dp3-gantt-day:last-child,.dp3-gantt-tick:last-child{border-right:none}.dp3-gantt-day{padding:.5rem .125rem;text-align:center;color:var(--text-muted);font-size:var(--fs-11);font-weight:700;white-space:nowrap}.dp3-gantt-day.today{background:#fff7ed;color:var(--amber)}.dp3-gantt-track{position:relative;height:3.25rem;overflow:hidden;background:var(--card)}.dp3-gantt-track-bg{position:absolute;inset:0;pointer-events:none}.dp3-gantt-tick.today{background:#f59e0b0f;border-right-color:#f59e0b33}.dp3-gantt-bar{position:absolute;top:.75rem;height:1.75rem;display:flex;align-items:center;padding:0 .625rem;border-radius:.625rem;color:#fff;box-shadow:0 1px 4px #00000024;cursor:pointer;overflow:hidden;white-space:nowrap;z-index:1;font-size:var(--fs-11);font-weight:700;transition:transform .14s ease,opacity .14s ease}.dp3-gantt-bar:hover{opacity:.92;transform:scaleY(1.04)}.dp3-gantt-empty,.dp3-empty{padding:2rem 1rem;text-align:center;color:var(--text-muted);font-size:var(--fs-14)}.dp3-plan-card{margin-bottom:.75rem;padding:1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow-sm);transition:all .18s ease}.dp3-plan-card:hover{border-color:var(--primary-soft-2)}.dp3-plan-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.875rem}.dp3-plan-title{color:var(--text);font-size:var(--fs-15);font-weight:700}.dp3-plan-subtitle{margin-top:.1875rem;color:var(--text-soft);font-size:var(--fs-14)}.dp3-plan-basic{margin-top:.125rem;color:var(--text-muted);font-size:var(--fs-12)}.dp3-plan-badges{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.dp3-plan-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.dp3-plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(10rem,1fr));gap:.75rem}.dp3-field label{display:block;margin-bottom:.375rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:var(--fs-12);font-weight:700}.dp3-field input,.dp3-field select{width:100%;height:2.5rem;padding:0 .75rem;border:1px solid var(--border);border-radius:.75rem;background:#e8edf5;color:var(--text);transition:all .18s ease}.dp3-field input:focus,.dp3-field select:focus,.dp3-field input:hover,.dp3-field select:hover{border-color:var(--primary);background:var(--card)}.dp3-field input:disabled,.dp3-field select:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}.dp3-field input.warn{border-color:var(--amber-border);background:#fffaf0}.dp3-hint-warn{margin-top:.25rem;color:var(--amber);font-size:var(--fs-12)}.dp3-dt-wrap{position:relative;display:flex;align-items:center;gap:.375rem}.dp3-dt-text{flex:1;min-width:0}.dp3-dt-btn{width:2.5rem;height:2.5rem;flex-shrink:0;border:1px solid var(--border);border-radius:.75rem;background:#e8edf5;color:var(--text-soft);cursor:pointer;transition:all .18s ease}.dp3-dt-btn:hover:not(:disabled){border-color:var(--primary);background:var(--card)}.dp3-dt-btn:disabled{opacity:.5;cursor:not-allowed}.dp3-dt-native{position:absolute;width:0;height:0;opacity:0;pointer-events:none;overflow:hidden}.dp3-adj-board{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.875rem}.dp3-adj-col.sub .dp3-adj-col-header{background:var(--amber-soft)}.dp3-adj-col.sch .dp3-adj-col-header{background:var(--green-soft)}.dp3-adj-col.sub .dp3-adj-col-title{color:var(--amber)}.dp3-adj-col.sch .dp3-adj-col-title{color:var(--green)}.dp3-adj-card.draggable{cursor:grab}.dp3-adj-card.draggable:active{cursor:grabbing;opacity:.86}.dp3-adj-card.drag-over{background:var(--primary-soft);border-color:var(--primary-soft-2)}.dp3-adj-seq{width:1.625rem;height:1.625rem;margin-right:.5rem;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;background:#f1f5f9;color:var(--text-soft);font-size:var(--fs-11);font-weight:700}.dp3-adj-footer{display:flex;align-items:center;justify-content:space-between;gap:.625rem;margin-top:.625rem}.dp3-adj-time{flex:1;color:var(--text-muted);font-size:var(--fs-12)}.dp3-adj-actions{display:flex;gap:.375rem;flex-shrink:0}.dp3-drawer-backdrop{position:fixed;inset:0;z-index:200;background:#0f172a6b;backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(1px)}.dp3-drawer{position:fixed;inset:0 0 0 auto;width:min(100vw,30rem);z-index:201;display:flex;flex-direction:column;background:var(--card);border-left:1px solid var(--border);box-shadow:var(--shadow-lg)}.dp3-drawer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:1rem;border-bottom:1px solid var(--border);flex-shrink:0}.dp3-drawer-date{color:var(--text);font-size:var(--fs-16);font-weight:700}.dp3-drawer-summary{margin-top:.1875rem;color:var(--text-soft);font-size:var(--fs-13)}.dp3-drawer-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto}.dp3-drawer-tab{flex:1 0 auto;min-width:5rem;padding:.75rem .375rem;text-align:center;cursor:pointer;border-bottom:2px solid transparent;color:var(--text-muted);font-size:var(--fs-13);font-weight:600;transition:all .18s ease}.dp3-drawer-tab:hover{color:var(--text-soft)}.dp3-drawer-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.dp3-drawer-body{flex:1;min-height:0;overflow-y:auto;padding:.875rem}.dp3-drawer-wo{position:relative;margin-bottom:.625rem;padding:.875rem;border:1px solid var(--border-soft);border-radius:.875rem;background:var(--card)}.dp3-drawer-wo.blocked{border-color:var(--red-border);background:#fff8f8}.dp3-drawer-wo-title{padding-right:5rem;color:var(--text);font-size:var(--fs-14);font-weight:700}.dp3-drawer-wo-mat{margin-top:.1875rem;color:var(--text-soft);font-size:var(--fs-13)}.dp3-drawer-wo-time{margin-top:.375rem;color:var(--text-muted);font-size:var(--fs-12)}.dp3-drawer-wo-badge{position:absolute;top:.75rem;right:.75rem;display:inline-flex;align-items:center;min-height:1.5rem;padding:0 .5rem;border-radius:999px;font-size:var(--fs-11);font-weight:700}.dp3-drawer-wo-badge.sched{background:var(--violet-soft);color:var(--violet)}.dp3-drawer-wo-badge.planned{background:var(--primary-soft);color:var(--primary)}.dp3-drawer-wo-badge.blocked{background:var(--red-soft);color:var(--red)}.dp3-btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;min-height:2.25rem;padding:0 .875rem;border:1px solid var(--border);border-radius:.75rem;background:var(--card);color:var(--text);cursor:pointer;white-space:nowrap;font-size:var(--fs-14);font-weight:600;line-height:1;text-decoration:none;transition:all .18s ease}.dp3-btn:hover:not(:disabled){background:#f8fafc;border-color:#a8b1bb}.dp3-btn:disabled{opacity:.45;cursor:not-allowed}.dp3-btn.primary{background:var(--primary-soft);border-color:var(--primary-soft-2);color:var(--primary)}.dp3-btn.primary:hover:not(:disabled){background:var(--primary-soft-2);border-color:#7dd3fc;color:var(--primary)}.dp3-btn.danger{background:#fff;border-color:var(--red-border);color:var(--red)}.dp3-btn.danger:hover:not(:disabled){background:var(--red-soft);color:var(--red)}.dp3-btn.ghost{padding-inline:.625rem;border-color:transparent;background:transparent;color:var(--text-soft)}.dp3-btn.ghost:hover:not(:disabled){background:#f1f5f9;color:var(--text);border-color:transparent}.dp3-icon-btn{width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-soft);border-radius:.625rem;background:#fff;color:var(--text-soft);cursor:pointer;transition:all .18s ease}.dp3-icon-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border);color:var(--text)}.dp3-icon-btn:disabled{opacity:.4;cursor:not-allowed}.dp3-icon-btn.approve:hover:not(:disabled){background:var(--green-soft);border-color:var(--green-border);color:var(--green)}.dp3-icon-btn.del:hover:not(:disabled){background:var(--red-soft);border-color:var(--red-border);color:var(--red)}.dp3-btn,.dp3-icon-btn,.dp3-collapse-btn,.dp3-add-btn,.dp3-cal-navbtn,.dp3-dt-btn{display:inline-flex;align-items:center;justify-content:center}.dp3-btn svg,.dp3-icon-btn svg,.dp3-collapse-btn svg,.dp3-cal-navbtn svg,.dp3-dt-btn svg,.dp3-tab-icon svg,.dp3-search-icon svg{width:1em;height:1em;display:block;flex-shrink:0;overflow:visible;color:currentColor}.dp3-btn svg *,.dp3-icon-btn svg *,.dp3-collapse-btn svg *,.dp3-cal-navbtn svg *,.dp3-dt-btn svg *,.dp3-tab-icon svg *,.dp3-search-icon svg *{vector-effect:non-scaling-stroke}.dp3-badge{display:inline-flex;align-items:center;gap:.25rem;min-height:1.5rem;padding:0 .5rem;border-radius:999px;font-size:var(--fs-11);font-weight:700}.dp3-badge.red{background:var(--red-soft);color:var(--red);border:1px solid var(--red-border)}.dp3-badge.amber{background:var(--amber-soft);color:var(--amber);border:1px solid var(--amber-border)}.dp3-badge.green{background:var(--green-soft);color:var(--green);border:1px solid var(--green-border)}.dp3-badge.blue{background:var(--primary-soft);color:var(--primary);border:1px solid var(--primary-soft-2)}.dp3-badge.purple{background:var(--violet-soft);color:var(--violet);border:1px solid var(--violet-border)}.dp3-badge.sky{background:#e0f2fe;color:#0369a1;border:1px solid #7dd3fc}.dp3-sb-hint{padding:.25rem .875rem .75rem;color:var(--text-muted);font-size:var(--fs-12)}@media(max-width:1280px){.dp3-kb-board,.dp3-adj-board{grid-template-columns:1fr}.dp3-plan-grid{grid-template-columns:repeat(auto-fit,minmax(9rem,1fr))}}@media(max-width:1024px){.dp3-page{grid-template-rows:auto 1fr}.dp3-kpi{min-height:var(--kpi-h);padding:.5rem .875rem;overflow-x:auto}.dp3-body{grid-template-columns:1fr}.dp3-sidebar{display:none}.dp3-main{grid-template-rows:auto auto 1fr}.dp3-main-header{min-height:var(--header-h);padding:.75rem 1rem;align-items:flex-start;flex-direction:column}.dp3-btn-group{width:100%}.dp3-cal-grid{min-width:44rem}.dp3-main-body{overflow:auto}}@media(max-width:768px){.dp3-main-body{padding:.75rem}.dp3-tab-bar{padding-inline:.5rem}.dp3-tab{padding-inline:.75rem}.dp3-plan-head,.dp3-cal-nav,.dp3-gantt-nav{flex-direction:column;align-items:stretch}.dp3-plan-actions,.dp3-cal-navbtns{width:100%;justify-content:flex-start;flex-wrap:wrap}.dp3-plan-grid{grid-template-columns:1fr}.dp3-gantt{min-width:36rem}.dp3-drawer{width:100vw}}@media(max-width:640px){.dp3-kpi-brand,.dp3-kpi-clock{display:none}.dp3-kpi-right{margin-left:0}.dp3-cal-weekday,.dp3-cal-daynum,.dp3-cal-pill{font-size:var(--fs-10)}.dp3-cal-cell{min-height:4.75rem;padding:.5rem}.dp3-kb-qty{grid-template-columns:repeat(2,minmax(0,1fr))}.dp3-btn{width:100%}.dp3-btn-group{display:grid;grid-template-columns:1fr 1fr}.dp3-adj-footer{flex-direction:column;align-items:stretch}}@media(max-width:480px){.dp3-main-body{padding:.625rem}.dp3-kpi{padding-inline:.625rem}.dp3-kpi-pill{font-size:var(--fs-11);padding-inline:.5rem}.dp3-tab{font-size:var(--fs-13)}.dp3-plan-card,.dp3-kb-card,.dp3-adj-card,.dp3-drawer-wo,.dp3-main-header,.dp3-drawer-header{padding:.75rem}.dp3-btn-group{grid-template-columns:1fr}}@media(forced-colors:active){.dp3-page{forced-color-adjust:auto}.dp3-btn,.dp3-icon-btn,.dp3-chip,.dp3-tab,.dp3-cal-navbtn,.dp3-kpi-select,.dp3-collapse-btn{border:1px solid ButtonText;background:ButtonFace;color:ButtonText;-webkit-text-fill-color:ButtonText}.dp3-field input,.dp3-field select,.dp3-search input{border:1px solid ButtonText;background:Field;color:FieldText;-webkit-text-fill-color:FieldText}.dp3-btn svg,.dp3-icon-btn svg,.dp3-collapse-btn svg,.dp3-cal-navbtn svg,.dp3-dt-btn svg,.dp3-tab-icon svg,.dp3-search-icon svg{color:ButtonText}}.dpmx-page{--dpmx-bg: #f8fafc;--dpmx-card: #ffffff;--dpmx-border: #dbe3ef;--dpmx-border-strong: #cbd5e1;--dpmx-text: #0f172a;--dpmx-muted: #475569;--dpmx-muted-2: #64748b;--dpmx-primary: #2563eb;--dpmx-primary-hover: #1d4ed8;--dpmx-primary-soft: #eff6ff;--dpmx-ok: #15803d;--dpmx-ok-soft: #dcfce7;--dpmx-bad: #991b1b;--dpmx-bad-soft: #fee2e2;--dpmx-warn: #b45309;--dpmx-warn-soft: #fffbeb;min-height:100dvh;padding:14px;background:var(--dpmx-bg);color:var(--dpmx-text);font-family:var(--pps-font-main);font-size:var(--fs-14);font-weight:550;line-height:1.45;letter-spacing:-.01em;font-feature-settings:"tnum" 1;display:flex;flex-direction:column;gap:12px;overflow-x:hidden}.dpmx-page,.dpmx-page *{box-sizing:border-box;min-width:0}.dpmx-card{background:var(--dpmx-card);border:1px solid var(--dpmx-border);border-radius:18px;box-shadow:0 8px 24px #0f172a0e}.dpmx-topbar,.dpmx-filter-card,.dpmx-orders-card,.dpmx-plan-card{padding:12px}.dpmx-topbar,.dpmx-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.dpmx-title,.dpmx-section-title{display:inline-flex;align-items:center;gap:8px;color:var(--dpmx-text);line-height:1.2;letter-spacing:-.03em}.dpmx-title{font-size:var(--fs-24);font-weight:850}.dpmx-section-title{font-size:var(--fs-17);font-weight:800}.dpmx-subtitle,.dpmx-section-sub,.dpmx-muted,.dpmx-footnote,.dpmx-filter-note{color:var(--dpmx-muted);font-size:var(--fs-13);font-weight:550;line-height:1.45}.dpmx-strong{font-weight:800;color:var(--dpmx-text)}.mono,.dpmx-order-no{font-family:var(--pps-font-mono)}.dpmx-order-no{color:var(--dpmx-primary-hover);font-size:var(--fs-16);font-weight:850;line-height:1.2;letter-spacing:.01em}.dpmx-muted.mono{margin-top:3px;color:#334155;font-size:var(--fs-13);font-weight:700}.dpmx-ellipsis{margin-top:4px;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--dpmx-text);font-size:var(--fs-14);font-weight:550;line-height:1.35}.dpmx-line-cell{max-width:280px;color:var(--dpmx-muted);font-size:var(--fs-13);font-weight:650}.dpmx-top-actions,.dpmx-head-actions{display:flex;gap:8px;flex-wrap:wrap}.dpmx-btn,.dpmx-icon-btn{min-height:40px;border-radius:12px;border:1px solid var(--dpmx-border-strong);background:#fff;color:var(--dpmx-text);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 13px;font-family:inherit;font-size:var(--fs-13);font-weight:800;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .12s ease,box-shadow .15s ease}.dpmx-btn:hover,.dpmx-icon-btn:hover{background:#f8fafc}.dpmx-btn:active,.dpmx-icon-btn:active{transform:translateY(1px)}.dpmx-btn:disabled,.dpmx-icon-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.dpmx-btn-primary{border-color:#93c5fd;background:var(--dpmx-primary);color:#fff}.dpmx-btn-soft{border-color:#bfdbfe;background:var(--dpmx-primary-soft);color:var(--dpmx-primary-hover)}.dpmx-btn-sm{min-height:34px;padding:0 10px;font-size:var(--fs-12)}.dpmx-icon-btn{width:34px;height:34px;min-height:34px;padding:0}.dpmx-icon-btn.add{border-color:#86efac;background:#ecfdf5;color:#16a34a}.dpmx-icon-btn.danger{border-color:#fecaca;background:#fff1f2;color:#dc2626}.dpmx-filter-grid{display:grid;grid-template-columns:minmax(260px,1.6fr) 150px repeat(4,minmax(120px,.8fr));gap:10px;align-items:end}.dpmx-field,.dpmx-plan-field{display:grid;gap:5px}.dpmx-field>span,.dpmx-plan-field>span{color:var(--dpmx-muted-2);font-size:var(--fs-11);font-weight:800;letter-spacing:.02em;text-transform:uppercase}.dpmx-field input,.dpmx-field select,.dpmx-search input,.dpmx-detail-grid input,.dpmx-detail-grid select,.dpmx-plan-field input,.dpmx-plan-field select{width:100%;min-height:40px;border-radius:12px;border:1px solid var(--dpmx-border-strong);background:#fff;color:var(--dpmx-text);padding:0 10px;font-family:inherit;font-size:var(--fs-13);font-weight:700;outline:none}.dpmx-plan-field input,.dpmx-plan-field select{min-height:42px;border-radius:14px;background:linear-gradient(180deg,#fff,#fbfdff);font-size:var(--fs-14);font-weight:750}.dpmx-field input:focus,.dpmx-field select:focus,.dpmx-search:focus-within,.dpmx-detail-grid input:focus,.dpmx-detail-grid select:focus,.dpmx-plan-field input:focus,.dpmx-plan-field select:focus{border-color:var(--dpmx-primary);box-shadow:0 0 0 3px #2563eb24}.dpmx-plan-field input::placeholder{color:#94a3b8;font-weight:600}.dpmx-plan-field select:disabled,.dpmx-plan-field input:disabled{background:#f8fafc;color:#94a3b8;opacity:1;cursor:not-allowed}.dpmx-search{min-height:40px;border:1px solid var(--dpmx-border-strong);border-radius:12px;display:flex;align-items:center;gap:8px;padding:0 10px;background:#fff;color:var(--dpmx-muted-2)}.dpmx-search input{border:0;box-shadow:none!important;padding:0;background:transparent}.dpmx-filter-note{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap}.dpmx-lock-text{color:var(--dpmx-warn)}.dpmx-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.dpmx-kpi{padding:12px;display:flex;align-items:center;gap:10px}.dpmx-kpi-icon{width:36px;height:36px;border-radius:12px;background:var(--dpmx-primary-soft);color:var(--dpmx-primary-hover);display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-18)}.dpmx-kpi-value{color:var(--dpmx-text);font-size:var(--fs-22);font-weight:850;line-height:1}.dpmx-kpi-label{margin-top:3px;color:var(--dpmx-muted);font-size:var(--fs-12);font-weight:700}.dpmx-order-wrap{margin-top:10px;max-height:300px;overflow:auto;border:1px solid var(--dpmx-border);border-radius:14px;-webkit-overflow-scrolling:touch}.dpmx-order-table,.dpmx-matrix-table{border-collapse:separate;border-spacing:0;width:100%;font-size:var(--fs-13)}.dpmx-order-table{min-width:1100px}.dpmx-order-table thead th,.dpmx-matrix-table thead th{position:sticky;top:0;z-index:20;background:#f8fafc;border-bottom:1px solid var(--dpmx-border);color:var(--dpmx-text);font-size:var(--fs-12);font-weight:850;padding:9px 8px;text-align:left;white-space:nowrap}.dpmx-order-table tbody td,.dpmx-matrix-table tbody td{border-bottom:1px solid #eef2f7;background:#fff;padding:8px;vertical-align:middle;font-size:var(--fs-13);font-weight:600}.dpmx-order-table tbody tr:hover td,.dpmx-matrix-table tbody tr:hover td{background:#fcfdff}.dpmx-order-table tr.is-blocked td{background:#fff7ed}.dpmx-pill{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:26px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:850;white-space:nowrap}.dpmx-pill.ok{color:var(--dpmx-ok);background:var(--dpmx-ok-soft)}.dpmx-pill.bad{max-width:260px;overflow:hidden;text-overflow:ellipsis;color:var(--dpmx-bad);background:var(--dpmx-bad-soft)}.dpmx-mold-note{display:inline-flex;align-items:center;min-height:26px;padding:0 10px;border-radius:999px;border:1px solid #fed7aa;background:#fff7ed;color:#9a3412;font-size:var(--fs-12);font-weight:850}.dpmx-mold-note.is-off{border-color:#cbd5e1;background:#f8fafc;color:#64748b}.dpmx-matrix-wrap{margin-top:10px;max-height:58vh;overflow:auto;border:1px solid var(--dpmx-border);border-radius:14px;position:relative;-webkit-overflow-scrolling:touch}.dpmx-sticky-col{position:sticky;background:#fff!important;z-index:15}.dpmx-matrix-table thead .dpmx-sticky-col{background:#f8fafc!important;z-index:40}.dpmx-sticky-1{left:0;min-width:160px;width:160px;border-right:1px solid var(--dpmx-border)}.dpmx-sticky-2{left:260px;min-width:420px;width:420px;border-right:1px solid var(--dpmx-border)}.dpmx-sticky-right{position:sticky;right:0;min-width:86px;width:86px;background:#fff!important;z-index:16;border-left:1px solid var(--dpmx-border);text-align:center!important}.dpmx-matrix-table thead .dpmx-sticky-right{background:#f8fafc!important;z-index:42}.dpmx-day-head{min-width:48px;width:48px;text-align:center!important;padding:7px 4px!important}.dpmx-day-head>div:first-child{font-size:var(--fs-15);font-weight:850}.dpmx-day-head>div:nth-child(2),.dpmx-day-count{font-size:var(--fs-10);color:var(--dpmx-muted);font-weight:750}.dpmx-day-head.is-today{background:#fef3c7!important;color:#92400e;box-shadow:inset 0 -3px #f59e0b}.dpmx-cell-td{min-width:48px;width:48px;text-align:center;padding:4px!important;cursor:pointer}.dpmx-cell-td.is-today{background:#fffbeb!important}.dpmx-cell-td.is-active{background:var(--dpmx-primary-soft)!important;box-shadow:inset 0 0 0 2px var(--dpmx-primary)}.dpmx-cell-empty{color:#cbd5e1;font-weight:850}.dpmx-cell-td:hover .dpmx-cell-empty{color:var(--dpmx-primary)}.dpmx-plan-chip{width:100%;min-height:32px;border:0;border-radius:10px;background:#dbeafe;color:var(--dpmx-primary-hover);font-size:var(--fs-11);font-weight:850;letter-spacing:-.01em;display:grid;gap:1px;cursor:pointer;padding:3px}.dpmx-plan-chip span{font-family:var(--pps-font-mono);font-size:var(--fs-10)}.dpmx-detail-grid{display:grid;grid-template-columns:92px 88px minmax(150px,1fr) minmax(170px,1fr);gap:8px;align-items:end}.dpmx-detail-grid.has-mold{grid-template-columns:92px 88px minmax(150px,1fr) minmax(170px,1fr)}.dpmx-detail-grid.no-mold{grid-template-columns:92px 88px minmax(180px,1fr)}.dpmx-detail-grid.custom-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.field-qty{grid-column:1 / 2}.field-shift{grid-column:2 / 3}.field-line,.field-mold,.field-start,.dpmx-plan-field-start{grid-column:1 / -1}.dpmx-plan-field-start input{font-family:var(--pps-font-mono);letter-spacing:.01em}.dpmx-detail-grid .is-warn{border-color:#f59e0b!important;background:#fffbeb!important;color:#92400e!important}.dpmx-warn-text{display:inline-flex;align-items:center;width:100%;margin-top:6px;color:var(--dpmx-warn);background:var(--dpmx-warn-soft);border:1px solid #fde68a;border-radius:10px;padding:5px 8px;font-size:var(--fs-12);font-weight:800;line-height:1.35}.dpmx-mini-row{margin-top:6px;display:flex;gap:6px;flex-wrap:wrap}.dpmx-mini-row span{display:inline-flex;min-height:22px;align-items:center;border-radius:999px;padding:0 8px;background:#f1f5f9;color:var(--dpmx-muted);font-size:var(--fs-11);font-weight:800}.dpmx-actions-cell{vertical-align:middle!important}.dpmx-actions-cell .dpmx-icon-btn+.dpmx-icon-btn{margin-left:4px}.dpmx-matrix-table tr.is-selected td{background:#f8fbff}.dpmx-matrix-table tr.is-selected .dpmx-sticky-col{box-shadow:inset 4px 0 0 var(--dpmx-primary)}.dpmx-empty{padding:18px!important;color:var(--dpmx-muted);text-align:center!important;font-size:var(--fs-13);font-weight:850}.dpmx-footnote{padding:10px 4px 0}@media(max-width:1180px){.dpmx-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.dpmx-field-search{grid-column:1 / -1}.dpmx-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.dpmx-page{padding:10px;font-size:var(--fs-13)}.dpmx-title{font-size:var(--fs-19)}.dpmx-section-title{font-size:var(--fs-16)}.dpmx-filter-grid,.dpmx-kpis{grid-template-columns:1fr}.dpmx-top-actions,.dpmx-head-actions{width:100%}.dpmx-top-actions .dpmx-btn,.dpmx-head-actions .dpmx-btn{flex:1 1 auto}.dpmx-sticky-1{min-width:220px;width:220px}.dpmx-sticky-2{left:220px;min-width:360px;width:360px}.dpmx-detail-grid,.dpmx-detail-grid.has-mold,.dpmx-detail-grid.no-mold,.dpmx-detail-grid.custom-layout{grid-template-columns:1fr 1fr}.dpmx-plan-field-line,.dpmx-plan-field-mold,.dpmx-plan-field-start,.field-line,.field-mold,.field-start{grid-column:1 / -1}}.dpmx-page{color:#111827;font-family:var(--pps-font-main);font-size:var(--fs-16);font-weight:400;line-height:1.5;letter-spacing:0}.dpmx-title,.dpmx-section-title{font-size:var(--fs-16);font-weight:700;color:#111827;line-height:1.35;letter-spacing:0}.dpmx-subtitle,.dpmx-section-sub,.dpmx-muted,.dpmx-footnote,.dpmx-filter-note{font-size:var(--fs-16);font-weight:400;color:#6b7280;line-height:1.5;letter-spacing:0}.dpmx-strong{font-weight:700;color:#111827}.dpmx-btn,.dpmx-icon-btn{font-size:var(--fs-16);font-weight:600;color:#111827;letter-spacing:0}.dpmx-btn-sm{font-size:var(--fs-14);font-weight:600}.dpmx-field>span,.dpmx-plan-field>span{font-size:var(--fs-12);font-weight:600;color:#6b7280;letter-spacing:.5px;text-transform:uppercase}.dpmx-field input,.dpmx-field select,.dpmx-search input,.dpmx-detail-grid input,.dpmx-detail-grid select,.dpmx-plan-field input,.dpmx-plan-field select{font-size:var(--fs-16);font-weight:500;color:#111827;background:#e8edf5;border:1px solid #d1d5db;border-radius:10px;letter-spacing:0}.dpmx-field input:focus,.dpmx-field select:focus,.dpmx-search:focus-within,.dpmx-detail-grid input:focus,.dpmx-detail-grid select:focus,.dpmx-plan-field input:focus,.dpmx-plan-field select:focus{background:#fff;border-color:#0369a1;box-shadow:0 0 0 3px #0369a11a}.dpmx-plan-field input::placeholder,.dpmx-search input::placeholder{color:#94a3b8;font-weight:500}.dpmx-kpi-value{font-size:var(--fs-22);font-weight:700;color:#111827}.dpmx-kpi-label{font-size:var(--fs-12);font-weight:600;color:#6b7280}.dpmx-order-no{font-size:var(--fs-16);font-weight:800;color:#111827;letter-spacing:0}.dpmx-muted.mono,.dpmx-line-cell{font-size:var(--fs-16);font-weight:400;color:#6b7280}.dpmx-ellipsis{font-size:var(--fs-16);font-weight:400;color:#6b7280;line-height:1.45}.dpmx-order-table,.dpmx-matrix-table{font-size:var(--fs-16)}.dpmx-order-table thead th,.dpmx-matrix-table thead th{font-size:var(--fs-12);font-weight:700;color:#111827;letter-spacing:0}.dpmx-order-table tbody td,.dpmx-matrix-table tbody td{font-size:var(--fs-16);font-weight:400;color:#111827}.dpmx-pill,.dpmx-mold-note,.dpmx-mini-row span{font-size:var(--fs-12);font-weight:600;letter-spacing:.2px}.dpmx-day-head>div:first-child{font-size:var(--fs-16);font-weight:700}.dpmx-day-head>div:nth-child(2),.dpmx-day-count{font-size:var(--fs-12);font-weight:600}.dpmx-cell-empty{font-size:var(--fs-16);font-weight:700}.dpmx-plan-chip{font-size:var(--fs-12);font-weight:700;letter-spacing:0}.dpmx-plan-chip span{font-size:var(--fs-11);font-weight:600}.dpmx-warn-text{font-size:var(--fs-12);font-weight:800}.dpmx-empty{font-size:var(--fs-16);font-weight:500;color:#6b7280}@media(max-width:760px){.dpmx-page,.dpmx-title,.dpmx-section-title{font-size:var(--fs-16)}.dpmx-subtitle,.dpmx-section-sub,.dpmx-muted,.dpmx-footnote,.dpmx-filter-note{font-size:var(--fs-15)}}.dpmx-page{--dpmx-sticky-1-w: 220px;--dpmx-sticky-2-w: 400px}.dpmx-sticky-1{left:0;min-width:var(--dpmx-sticky-1-w)!important;width:var(--dpmx-sticky-1-w)!important;max-width:var(--dpmx-sticky-1-w)!important;border-right:1px solid var(--dpmx-border)}.dpmx-sticky-2{left:var(--dpmx-sticky-1-w)!important;min-width:var(--dpmx-sticky-2-w)!important;width:var(--dpmx-sticky-2-w)!important;max-width:var(--dpmx-sticky-2-w)!important;border-right:1px solid var(--dpmx-border)}.dpmx-material-desc{margin-top:6px;max-width:100%;color:#6b7280;font-size:var(--fs-16);font-weight:400;line-height:1.45;white-space:normal;word-break:break-word;overflow-wrap:anywhere}.dpmx-sticky-1 .dpmx-ellipsis{max-width:100%;overflow:visible;text-overflow:clip;white-space:normal;word-break:break-word;overflow-wrap:anywhere}@media(max-width:760px){.dpmx-page{--dpmx-sticky-1-w: 220px;--dpmx-sticky-2-w: 300px}}.dpmx-plan-card{height:80vh;display:flex;flex-direction:column}.dpmx-plan-card .dpmx-matrix-wrap{flex:1;min-height:0;max-height:100%;overflow:auto}.dpmx-orders-card{height:80vh;display:flex;flex-direction:column}.dpmx-orders-card .dpmx-order-wrap{flex:1;min-height:0;max-height:100%;overflow:auto}.dpmx-order-cell{display:flex;flex-direction:column;gap:6px;cursor:pointer}.dpmx-order-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.dpmx-order-actions{display:inline-flex;align-items:center;gap:4px;flex:0 0 auto}.dpmx-order-actions .dpmx-icon-btn{width:28px;height:28px;min-height:28px;border-radius:9px}.dpmx-order-actions .dpmx-icon-btn svg{width:15px;height:15px}.dpmx-order-cell .dpmx-material-desc{max-width:100%;white-space:normal;word-break:break-word;overflow-wrap:anywhere}.dpmx-col-order{min-width:220px;width:220px;max-width:220px}.dpmx-actions-wrap{display:flex;align-items:center;justify-content:center;gap:6px}.dpmx-ai-card{margin-top:12px;border:1px solid rgba(99,102,241,.22);background:linear-gradient(180deg,#6366f10f,#ffffffeb)}.dpmx-ai-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:10px}.dpmx-ai-block{border:1px solid rgba(15,23,42,.08);border-radius:14px;background:#ffffffdb;padding:12px}.dpmx-ai-title{font-size:var(--fs-12);font-weight:800;color:#334155;margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.dpmx-ai-text,.dpmx-ai-list{font-size:var(--fs-13);color:#0f172a;line-height:1.55}.dpmx-ai-list{margin:0;padding-left:18px}.dpmx-ai-list li+li{margin-top:4px}.dpmx-ai-decision-list{display:grid;gap:6px}.dpmx-ai-decision{display:grid;grid-template-columns:minmax(120px,.8fr) minmax(120px,.8fr) minmax(160px,1.4fr);gap:8px;align-items:center;font-size:var(--fs-12);border:1px solid rgba(15,23,42,.08);border-radius:10px;padding:8px;background:#f8fafce6}@media(max-width:900px){.dpmx-ai-grid,.dpmx-ai-decision{grid-template-columns:1fr}}.dpmx-ai-card{position:relative;overflow:hidden;padding:18px;border:1px solid rgba(79,70,229,.18);background:radial-gradient(circle at top left,rgba(79,70,229,.14),transparent 34%),linear-gradient(180deg,#f8fafffa,#fffffff5);box-shadow:0 18px 48px #0f172a14}.dpmx-ai-card:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:linear-gradient(180deg,#4f46e5,#0ea5e9,#22c55e)}.dpmx-ai-card .dpmx-section-head{position:relative;align-items:flex-start;padding-left:2px}.dpmx-ai-card .dpmx-section-title{font-size:var(--fs-20);font-weight:850;letter-spacing:-.02em;color:#0f172a}.dpmx-ai-card .dpmx-section-sub{margin-top:4px;color:#667085;font-size:var(--fs-14);font-weight:500}.dpmx-ai-card .dpmx-btn{border-color:#94a3b88c;background:#ffffffdb;box-shadow:0 8px 22px #0f172a14}.dpmx-ai-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:14px;margin-top:18px}.dpmx-ai-block{position:relative;min-height:132px;border:1px solid rgba(203,213,225,.78);border-radius:18px;background:#ffffffeb;padding:16px 18px;box-shadow:0 10px 28px #0f172a0e}.dpmx-ai-block:hover{border-color:#6366f159;box-shadow:0 16px 34px #0f172a14}.dpmx-ai-title{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:#334155;font-size:var(--fs-13);font-weight:900;letter-spacing:.08em;text-transform:uppercase}.dpmx-ai-title:before{content:"";width:9px;height:9px;border-radius:999px;background:#6366f1;box-shadow:0 0 0 4px #6366f11f}.dpmx-ai-text{color:#111827;font-size:var(--fs-15);font-weight:520;line-height:1.75;white-space:pre-line}.dpmx-ai-list{display:grid;gap:10px;margin:0;padding:0;list-style:none}.dpmx-ai-list li{position:relative;padding:10px 12px 10px 34px;border:1px solid rgba(226,232,240,.95);border-radius:14px;background:linear-gradient(180deg,#fff,#f8fafc);color:#111827;font-size:var(--fs-14);font-weight:520;line-height:1.6}.dpmx-ai-list li:before{content:"";position:absolute;left:13px;top:17px;width:8px;height:8px;border-radius:999px;background:#2563eb}.dpmx-ai-list li:has(b:first-child){padding-left:12px}.dpmx-ai-list li b:first-child{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;margin-right:6px;border-radius:999px;background:#eef2ff;color:#4338ca;font-size:var(--fs-12);font-weight:850;letter-spacing:.02em}.dpmx-ai-list li:has(b:first-child):before{display:none}.dpmx-ai-decision-list{display:grid;gap:8px}.dpmx-ai-decision{display:grid;grid-template-columns:minmax(140px,.8fr) minmax(220px,1fr) minmax(220px,1.2fr);gap:10px;align-items:center;padding:10px 12px;border:1px solid rgba(226,232,240,.95);border-radius:14px;background:linear-gradient(180deg,#fff,#f8fafc);color:#0f172a;font-size:var(--fs-13);font-weight:600}.dpmx-ai-decision .mono{color:#1d4ed8;font-weight:850}.dpmx-ai-card .dpmx-warn-text{margin-top:12px;border-color:#fed7aa;background:#fff7ed;color:#9a3412}.dpmx-ai-card .dpmx-filter-note{display:inline-flex;align-items:center;gap:10px;margin-top:14px;padding:10px 12px;border:1px solid #bfdbfe;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-weight:700}.dpmx-ai-card .dpmx-filter-note:before{content:"";width:10px;height:10px;border-radius:999px;background:#2563eb;animation:dpmx-ai-pulse 1s ease-in-out infinite}@keyframes dpmx-ai-pulse{0%,to{opacity:.35;transform:scale(.85)}50%{opacity:1;transform:scale(1.12)}}@media(max-width:1100px){.dpmx-ai-grid{grid-template-columns:1fr}.dpmx-ai-card{padding:14px}}@media(max-width:760px){.dpmx-ai-card .dpmx-section-title{font-size:var(--fs-17)}.dpmx-ai-card .dpmx-section-sub,.dpmx-ai-text,.dpmx-ai-list li{font-size:var(--fs-14)}.dpmx-ai-decision{grid-template-columns:1fr}}.dpmx-ai-risk-list li{border-left:4px solid #f59e0b;background:#fffbeb}.dpmx-ai-risk-list li:first-child{border-left-color:#dc2626;background:#fef2f2}.dpmx-page{--dpmx-bg: #f8fafc;--dpmx-card: #ffffff;--dpmx-border: #dbe3ef;--dpmx-border-strong: #cbd5e1;--dpmx-text: #111827;--dpmx-muted: #6b7280;--dpmx-primary: #2563eb;--dpmx-primary-hover: #1d4ed8;--dpmx-primary-soft: #eff6ff;--dpmx-ok: #15803d;--dpmx-bad: #dc2626;--dpmx-warn: #f59e0b;--dpmx-sticky-1-w: 220px;--dpmx-sticky-2-w: 400px;min-height:100dvh;padding:14px;background:var(--dpmx-bg);color:var(--dpmx-text);font-family:var(--pps-font-main);font-size:var(--fs-16);line-height:1.5;display:flex;flex-direction:column;gap:12px}.dpmx-card{background:var(--dpmx-card);border:1px solid var(--dpmx-border);border-radius:18px;box-shadow:0 8px 24px #0000000d;padding:12px}.dpmx-title{font-size:var(--fs-20);font-weight:700}.dpmx-section-title{font-size:var(--fs-16);font-weight:700}.dpmx-muted{color:var(--dpmx-muted)}.dpmx-btn{min-height:40px;padding:0 14px;border-radius:10px;border:1px solid var(--dpmx-border-strong);background:#fff;font-weight:600;cursor:pointer}.dpmx-btn-primary{background:var(--dpmx-primary);color:#fff}.dpmx-btn-primary:hover{background:var(--dpmx-primary-hover)}.dpmx-btn-danger{background:#dc2626;color:#fff}.dpmx-btn-danger:hover{background:#b91c1c}.dpmx-matrix-wrap{overflow:auto;border-radius:12px;border:1px solid var(--dpmx-border);max-height:70vh}.dpmx-matrix-table{width:max-content;min-width:100%}.dpmx-matrix-table th{position:sticky;top:0;background:#f1f5f9;font-weight:700}.dpmx-matrix-table td{text-align:center;padding:6px}.dpmx-sticky-1{position:sticky;left:0;width:var(--dpmx-sticky-1-w);background:#fff;z-index:10}.dpmx-sticky-2{position:sticky;left:var(--dpmx-sticky-1-w);width:var(--dpmx-sticky-2-w);background:#fff;z-index:10}.dpmx-plan-chip{background:#dbeafe;border-radius:8px;padding:4px;font-size:var(--fs-12);font-weight:600}.dpmx-order-cell{display:flex;flex-direction:column;gap:6px}.dpmx-order-top{display:flex;justify-content:space-between}.dpmx-order-actions{display:flex;gap:4px}.dpmx-plan-card,.dpmx-orders-card{height:80vh;display:flex;flex-direction:column}.dpmx-plan-card .dpmx-matrix-wrap,.dpmx-orders-card .dpmx-order-wrap{flex:1;overflow:auto}.dpmx-ai-card{border:1px solid rgba(99,102,241,.3);background:linear-gradient(180deg,#eef2ff,#fff);border-radius:16px;padding:16px}.dpmx-ai-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dpmx-ai-block{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}.dpmx-ai-block-wide{grid-column:1 / -1}.dpmx-ai-title{font-size:var(--fs-12);font-weight:700;color:#64748b;margin-bottom:6px}.dpmx-ai-text{font-size:var(--fs-14)}.dpmx-ai-actions{border:1px dashed #c7d2fe;background:#f8fafc}.dpmx-ai-actions-row{display:flex;justify-content:flex-end;gap:10px;margin-top:10px}@media(max-width:900px){.dpmx-ai-grid{grid-template-columns:1fr}}@media(max-width:760px){.dpmx-page{font-size:var(--fs-15)}.dpmx-sticky-2{width:300px}}.dpmx-ai-action-row{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff;gap:10px}.dpmx-ai-decision{display:grid;grid-template-columns:120px 120px 1fr;gap:10px;align-items:flex-start}.dpmx-ai-decision>div:nth-child(1){font-weight:800;white-space:nowrap}.dpmx-ai-decision>div:nth-child(2){font-weight:700;color:#0f172a}.dpmx-ai-decision>div:nth-child(3){color:#334155;line-height:1.55;white-space:normal;word-break:break-word;overflow-wrap:anywhere;max-height:120px;overflow-y:auto;padding-right:4px}.dpmx-ai-decision>div:nth-child(3)::-webkit-scrollbar{width:6px}.dpmx-ai-decision>div:nth-child(3)::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:6px}.dpmx-ai-text-pre{white-space:pre-line}.ep-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--border-strong: #9ca3af;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-soft: #e0f2fe;--primary-soft-2: #bae6fd;--danger: #991b1b;--danger-bg: #fee2e2;--danger-border: #fecaca;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--radius: 16px;--radius-sm: 12px;width:100%;height:100%;padding:16px 24px;overflow:hidden;display:flex;flex-direction:column;gap:12px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-16);font-weight:400}.ep-page *{box-sizing:border-box;font-family:inherit}.ep-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.ep-panel-top{flex:0 0 auto}.ep-panel-bottom{flex:1;min-height:0;overflow-x:auto;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.ep-panel-bottom::-webkit-scrollbar{width:8px;height:8px}.ep-panel-bottom::-webkit-scrollbar-track{background:transparent}.ep-panel-bottom::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.ep-panel-bottom::-webkit-scrollbar-thumb:hover{background:#94a3b8}.ep-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.ep-title h2{margin:0;font-size:var(--fs-16);font-weight:700;color:var(--text)}.ep-sub{margin-top:4px;font-size:var(--fs-16);font-weight:400;color:var(--muted)}.ep-filters{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.ep-filter{min-width:200px}.ep-filter-label{font-size:var(--fs-16);font-weight:700;margin-bottom:6px;color:var(--text)}.ep-input{width:100%;height:40px;padding:0 12px;border-radius:10px;border:1px solid var(--border-strong);background:#e8edf5;font-size:var(--fs-16);font-weight:400;color:var(--text);outline:none}.ep-input::placeholder{color:#94a3b8;font-weight:400}.ep-input:focus{background:var(--card);border-color:#7dd3fc;box-shadow:0 0 0 2px #bae6fd}.ep-table{min-width:1400px;width:max-content;border-collapse:separate;border-spacing:0;table-layout:fixed}.ep-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;border-bottom:1px solid var(--border);font-size:var(--fs-16);font-weight:700;padding:10px;text-align:left;white-space:nowrap;color:var(--text)}.ep-table tbody td{padding:10px;font-size:var(--fs-16);font-weight:400;white-space:nowrap;border-bottom:1px solid #f1f5f9}.ep-table tbody tr:hover{background:#f8fafc}.ep-col-no{width:56px}.ep-col-line-name{width:320px}.ep-col-order{width:200px}.ep-col-qty{width:120px}.ep-col-shift{width:190px}.ep-col-start{width:220px}.ep-col-work{width:110px}.ep-col-mold{width:160px}.ep-col-action{width:64px}.ep-icon-btn{border:none;background:transparent;cursor:pointer;color:#ef4444;font-size:var(--fs-16);font-weight:400}.ep-icon-btn:hover{opacity:.7}.ep-icon-btn.ep-delete:hover{background:#fee2e2}@media(max-width:768px){.ep-page,.ep-panel{padding:12px}.ep-filter{min-width:160px}}.kb-page{padding:16px 24px;height:100%;background:#f8fafc}.kb-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.kb-filters{display:flex;gap:8px}.kb-filters select{border:1px solid #e5e7eb;border-radius:6px;padding:6px 10px;font-size:var(--fs-16);font-weight:400;background:#e8edf5}.kb-board{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;height:calc(100vh - 140px)}.kb-column{width:100%;min-width:0;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb;display:flex;flex-direction:column;overflow:hidden}.kb-column-header{padding:10px 12px;font-size:var(--fs-16);font-weight:600;display:flex;justify-content:space-between;align-items:center}.kb-status-6{background:#e0f2fe;color:#0369a1}.kb-status-8{background:#dcfce7;color:#166534}.kb-status-11{background:#f3f4f6;color:#374151}.kb-column-body{padding:10px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.kb-column-body::-webkit-scrollbar{width:6px}.kb-column-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:6px}.kb-column-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.kb-card{background:#fff;border-radius:8px;padding:10px 12px;box-shadow:0 1px 2px #00000014}.kb-card .kb-wo{font-size:var(--fs-16);font-weight:700}.kb-card .kb-order,.kb-card .kb-qty,.kb-card .kb-linename{font-size:var(--fs-16);font-weight:400;color:#374151}@media(max-width:1200px){.kb-filters select{font-size:var(--fs-16);font-weight:400}}@media(max-width:992px){.kb-page{padding:12px 16px}.kb-header{flex-direction:column;align-items:flex-start;gap:12px}.kb-filters{width:100%}.kb-board{display:flex;gap:16px;overflow-x:auto;height:calc(100vh - 180px);scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.kb-board::-webkit-scrollbar{height:8px}.kb-board::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.kb-column{min-width:260px}}@media(max-width:768px){.kb-page{padding:10px 12px}.kb-header h2{font-size:var(--fs-16);font-weight:700}.kb-column{min-width:240px}.kb-card{padding:8px 10px}.kb-card .kb-order,.kb-card .kb-qty,.kb-card .kb-linename{font-size:var(--fs-16);font-weight:400}}@media(max-width:520px){.kb-filters{flex-direction:column;width:100%}.kb-filters select{width:100%;font-size:var(--fs-16);font-weight:400}.kb-column{min-width:85vw}.kb-column-header{font-size:var(--fs-16);font-weight:700;padding:8px 10px}.kb-card{padding:8px}}@media(max-width:360px){.kb-column{min-width:92vw}.kb-card{padding:6px 8px}.kb-card .kb-wo{font-size:var(--fs-16);font-weight:700}}.kb-filters select{color:#111827;font-weight:400}.kb-filters select option,.kb-btn{color:#111827}.kb-btn:disabled{color:#374151}.kb-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;margin-bottom:6px}.kb-badge{display:inline-flex;align-items:center;gap:6px;height:24px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;border:1px solid transparent;white-space:nowrap}.kb-badge-plant{border-color:color-mix(in srgb,var(--kb-plant, #cbd5e1) 35%,#e5e7eb);background:color-mix(in srgb,var(--kb-plant-soft, #f8fafc) 70%,#ffffff);color:#0f172a}.kb-badge-line{border-color:color-mix(in srgb,var(--kb-line, #cbd5e1) 35%,#e5e7eb);background:color-mix(in srgb,var(--kb-line-soft, #f8fafc) 70%,#ffffff);color:#0f172a}.kb-card{display:flex;flex-direction:column;gap:10px}.kb-header{display:flex;flex-direction:column;gap:6px}.kb-wo-code{font-size:var(--fs-15);font-weight:700;color:#111827}.kb-wo-old{margin-left:6px;font-size:var(--fs-12);color:#6b7280}.kb-badges{display:flex;gap:6px;flex-wrap:wrap}.kb-material{font-size:var(--fs-14);font-weight:600;color:#1f2937}.kb-material2{font-size:var(--fs-12);font-weight:400;color:#1f2937}.kb-order-ref{font-size:var(--fs-13);color:#6b7280}.kb-qty-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}.kb-qty-grid div{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:6px 8px;display:flex;justify-content:space-between;font-size:var(--fs-12)}.kb-qty-grid b{font-size:var(--fs-13)}.kb-qty-grid .good{color:#166534}.kb-qty-grid .bad{color:#991b1b}.kb-footer{display:flex;justify-content:space-between;font-size:var(--fs-11);color:#6b7280;border-top:1px dashed #e5e7eb;padding-top:6px}.kb-header{display:flex;align-items:center;width:100%}.kb-header-spacer{flex:1}.kb-filters{display:flex;gap:10px;margin-left:auto}.kb-child-box{margin-top:8px;border:1px solid #dbeafe;background:#eff6ff;border-radius:10px;overflow:hidden}.kb-child-head{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;font-size:var(--fs-11);font-weight:900;color:#1e3a8a;border-bottom:1px solid #bfdbfe}.kb-child-head span{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#fff;border:1px solid #bfdbfe;display:flex;align-items:center;justify-content:center}.kb-child-list{display:flex;flex-direction:column;gap:6px;padding:6px}.kb-child-row{background:#fff;border:1px solid #dbeafe;border-radius:8px;padding:6px 8px;display:flex;flex-direction:column;gap:3px}.kb-child-top{display:flex;justify-content:space-between;font-size:var(--fs-11);font-weight:900}.kb-child-desc{font-size:var(--fs-11);color:#64748b;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kb-child-meta{display:flex;justify-content:space-between;font-size:var(--fs-11);font-weight:800;color:#475569}.kb-child-meta strong{color:#0f172a}.mp-page{padding:16px 24px;height:100%;background:#f8fafc;overflow:hidden;color:#111827;font-size:var(--fs-16);font-weight:400}.mp-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.mp-title{display:flex;align-items:center;gap:10px;color:#111827}.mp-title h2{margin:0;font-size:var(--fs-16);font-weight:700;color:#111827}.mp-page>h2{margin:0 0 12px;font-size:var(--fs-16);font-weight:700;color:#111827}.mp-panel{background:#fff;border-radius:16px;padding:12px;display:flex;flex-direction:column;height:calc(100% - 56px);box-shadow:0 10px 26px #0000000f;border:1px solid #e5e7eb}.mp-summary{position:sticky;top:0;z-index:4;display:flex;gap:12px;flex-wrap:wrap;margin-bottom:12px;padding:8px 12px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000f}.mp-summary-item{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;font-size:var(--fs-16);font-weight:700}.mp-summary-item.plan{background:#dcfce7;color:#166534}.mp-summary-item.confirmed{background:#e0f2fe;color:#0369a1}.mp-search-group{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;margin-bottom:12px}.mp-search-group input{width:100%;height:40px;padding:0 14px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-16);font-weight:400;color:#111827}.mp-search-group input:focus{outline:none;background:#fff}.mp-btn-excel{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 14px;border-radius:10px;border:1px solid #86efac;background:#ecfdf5;color:#166534;font-weight:600;font-size:var(--fs-16);cursor:pointer;white-space:nowrap}.mp-btn-excel:hover{background:#d1fae5}.mp-btn-excel:disabled{opacity:.6;cursor:not-allowed}.mp-table-wrapper{flex:1;overflow:auto;border-radius:12px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.mp-table-wrapper::-webkit-scrollbar{width:8px;height:8px}.mp-table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.mp-table-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8}.mp-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.mp-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-16);font-weight:700;padding:10px;text-align:left;border-bottom:1px solid #e5e7eb;white-space:nowrap;color:#111827}.mp-table td{padding:10px;font-size:var(--fs-16);font-weight:400;white-space:nowrap;border-bottom:1px solid #f1f5f9;color:#111827}.mp-table tbody tr:hover{background:#f8fafc}.mp-col-no{width:60px}.mp-col-order,.mp-col-material{width:180px}.mp-col-desc{width:420px}.mp-col-qty{width:140px;text-align:left}.mp-col-start{width:220px}.mp-row-planned{background:#ecfdf5}.mp-row-planned:hover{background:#d1fae5}.mp-badge{display:inline-block;min-width:56px;padding:4px 10px;border-radius:999px;font-size:var(--fs-16);font-weight:700;text-align:right}.mp-badge-confirmed{background:#e0f2fe;color:#0369a1}.mp-badge-plan{background:#dcfce7;color:#166534}@media(max-width:1024px){.mp-col-desc{width:320px}}@media(max-width:768px){.mp-page{padding:12px}.mp-search-group{grid-template-columns:1fr}.mp-btn-excel{justify-self:flex-end;width:100%}.mp-table thead th,.mp-table td{font-size:var(--fs-16);font-weight:inherit}}.pa-column-header{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:var(--fs-16)}.pa-wo{font-size:var(--fs-18);font-weight:700;color:var(--text)}.pa-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-light: #e0f2fe;--primary-lighter: #bae6fd;--green: #166534;--green-bg: #ecfdf5;--green-border: #86efac;--green-soft: #d1fae5;--red: #991b1b;--red-light: #fee2e2;--red-soft: #fecaca;--gray-50: #f9fafb;--gray-100: #f1f5f9;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--radius-sm: 10px;height:100%;width:100%;padding:16px 24px;overflow:hidden;background:var(--bg);color:var(--text)}.pa-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.pa-filters{display:flex;gap:10px;align-items:center}.pa-filters select{height:40px;border-radius:10px;border:1px solid var(--gray-400);background:#e8edf5;color:var(--text);padding:0 12px;font-size:var(--fs-16);font-weight:400;outline:none;transition:all .2s}.pa-filters select:focus{border-color:var(--primary);background:var(--card);box-shadow:0 0 0 3px #0369a11a}.pa-btn{height:40px;padding:0 14px;border-radius:var(--radius-sm);border:1px solid var(--primary-lighter);background:var(--primary-light);color:var(--primary);font-weight:600;font-size:var(--fs-16);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 1px 3px #0000000d}.pa-btn:hover{background:var(--primary-lighter);border-color:#7dd3fc;box-shadow:0 2px 4px #0369a126}.pa-btn:active{background:#7dd3fc;transform:scale(.98)}.pa-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.pa-saving{margin-bottom:10px;font-weight:700;color:var(--primary)}.pa-board{display:grid;grid-template-columns:1fr 1fr;gap:12px;height:calc(100vh - 150px);overflow:hidden}.pa-column{display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow)}.pa-column-header{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:var(--fs-16)}.pa-status-2{background:#fff7ed;color:#9a3412}.pa-status-6{background:var(--primary-light);color:var(--primary)}.pa-count{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:#ffffffb3;font-weight:700;color:var(--text)}.pa-column-body{flex:1;padding:12px;overflow-y:auto;background:var(--bg);display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.pa-column-body::-webkit-scrollbar{width:8px}.pa-column-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.pa-column-body::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.pa-card{position:relative;padding:14px 16px 64px;background:var(--card);border-radius:var(--radius);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);transition:box-shadow .2s}.pa-card:hover{box-shadow:var(--shadow)}.pa-card-draggable{cursor:grab;-webkit-user-select:none;user-select:none}.pa-card-draggable:active{cursor:grabbing}.pa-seq{font-weight:700;color:var(--gray-700);margin-bottom:6px}.pa-wo{font-size:var(--fs-16);font-weight:700;color:var(--text)}.pa-order,.pa-mat,.pa-qty,.pa-line,.pa-time{margin-top:2px;font-size:var(--fs-16);font-weight:400;color:var(--muted)}.pa-mat{font-family:var(--pps-font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pa-actions{position:absolute;right:14px;bottom:14px;display:flex;justify-content:flex-end;gap:12px}.pa-icon-btn{width:40px;height:40px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000d}.pa-icon-btn svg{width:18px;height:18px;color:currentColor;stroke:currentColor;fill:none;stroke-width:2}.pa-icon-approve{border:1.5px solid var(--green-border);background:var(--green-bg);color:#16a34a}.pa-icon-approve:hover{background:var(--green-soft);border-color:#4ade80;box-shadow:0 2px 4px #22c55e26}.pa-icon-approve:active{background:#bbf7d0;transform:scale(.98)}.pa-icon-delete{border:1.5px solid #fecaca;background:var(--red-light);color:var(--red)}.pa-icon-delete:hover{background:#fecaca;border-color:#fca5a5;box-shadow:0 2px 4px #ef44441f}.pa-icon-delete:active{background:#fca5a5;transform:scale(.98)}.pa-icon-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.pa-empty{color:var(--muted);font-weight:400;padding:16px;background:var(--gray-50);border:1px dashed var(--border);border-radius:var(--radius-sm);text-align:center}@media(max-width:992px){.pa-page{padding:16px;overflow:auto}.pa-board{grid-template-columns:1fr;height:auto}}@media(max-width:480px){.pa-page{padding:12px}.pa-card{padding:12px 12px 62px}.pa-icon-btn{width:38px;height:38px}.pa-icon-btn svg{width:17px;height:17px}}.pa-actions{right:12px;bottom:12px;gap:10px}.pa-icon-approve{border:1.25px solid var(--green-border)}.pa-time-row{margin-top:2px;display:flex;align-items:center;justify-content:space-between;gap:12px}.pa-time-row .pa-time{min-width:0;flex:1}.pa-actions.pa-actions-inline{position:static;display:inline-flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:0}.pa-card{padding:14px 16px}.pa-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;margin-bottom:6px}.pa-badge{display:inline-flex;align-items:center;gap:6px;height:24px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;border:1px solid transparent;white-space:nowrap}.pa-badge-plant{border-color:color-mix(in srgb,var(--pa-plant, #cbd5e1) 35%,#e5e7eb);background:color-mix(in srgb,var(--pa-plant-soft, #f8fafc) 70%,#ffffff);color:#0f172a}.pa-badge-line{border-color:color-mix(in srgb,var(--pa-line, #cbd5e1) 35%,#e5e7eb);background:color-mix(in srgb,var(--pa-line-soft, #f8fafc) 70%,#ffffff);color:#0f172a}.pa-card{position:relative;display:flex;flex-direction:column;gap:10px;padding:14px 14px 12px;border-radius:14px}.pa-card-header{display:flex;flex-direction:column;gap:8px}.pa-wo-code{font-size:var(--fs-15);font-weight:800;color:#111827}.pa-wo-old{margin-left:6px;font-size:var(--fs-12);color:#6b7280;font-weight:600}.pa-badges{display:flex;gap:6px;flex-wrap:wrap}.pa-card-body{display:flex;flex-direction:column;gap:6px}.pa-material{font-size:var(--fs-14);font-weight:700;color:#1f2937}.pa-order-ref{font-size:var(--fs-13);color:#6b7280;font-weight:600}.pa-qty-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}.pa-qty-grid>div{background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;font-size:var(--fs-12);color:#475569}.pa-qty-grid b{font-size:var(--fs-13);color:#111827}.pa-qty-grid b.good{color:#166534}.pa-qty-grid b.bad{color:#991b1b}.pa-card-footer{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:center;border-top:1px dashed #e5e7eb;padding-top:8px;font-size:var(--fs-11);color:#6b7280;font-weight:600}.pa-actions{display:inline-flex;gap:8px;justify-content:flex-end}.pa-seq{position:absolute;top:10px;right:10px;font-size:var(--fs-11);font-weight:900;color:#0f172a;background:#f1f5f9;border:1px solid #e5e7eb;border-radius:999px;padding:4px 8px}.pa-qty-single{margin-top:6px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;font-size:var(--fs-13);color:#475569;font-weight:600}.pa-qty-single b{font-size:var(--fs-14);color:#111827}.pa-child-box{margin-top:8px;border:1px solid #dbeafe;background:#eff6ff;border-radius:12px;overflow:hidden}.pa-child-title{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;font-size:var(--fs-12);font-weight:800;color:#1e3a8a;border-bottom:1px solid #bfdbfe}.pa-child-title span{min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:#fff;border:1px solid #bfdbfe;color:#1e40af;display:inline-flex;align-items:center;justify-content:center}.pa-child-list{display:flex;flex-direction:column;gap:6px;padding:8px}.pa-child-row{background:#fff;border:1px solid #dbeafe;border-radius:10px;padding:8px 10px;display:flex;flex-direction:column;gap:4px}.pa-child-main{display:flex;justify-content:space-between;gap:8px;font-size:var(--fs-12);color:#0f172a}.pa-child-main b{font-weight:900;color:#111827}.pa-child-main span{font-weight:700;color:#334155;text-align:right}.pa-child-desc{font-size:var(--fs-12);font-weight:600;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pa-child-meta{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:var(--fs-12);color:#475569}.pa-child-meta strong{color:#0f172a;font-weight:900;white-space:nowrap}.kbv2-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--soft: #e0f2fe;--good: #16a34a;--bad: #b91c1c;--running: #7c3aed;--running-soft: #f3e8ff;min-height:100vh;min-height:100svh;min-height:100dvh;background:var(--bg);color:var(--text);padding:12px 14px;padding-left:calc(14px + env(safe-area-inset-left));padding-right:calc(14px + env(safe-area-inset-right));padding-bottom:calc(12px + env(safe-area-inset-bottom));font-family:var(--pps-font-main);color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.kbv2-page p,.kbv2-page span,.kbv2-page small,.kbv2-page b,.kbv2-page strong,.kbv2-page label,.kbv2-page a{color:inherit}.kbv2-page a{text-decoration:none}.kbv2-page a:hover{text-decoration:underline}.kbv2-page svg{display:inline-block;vertical-align:middle;overflow:visible}.kbv2-fullscreen{min-height:100vh;min-height:100svh;min-height:100dvh;height:auto;display:flex;flex-direction:column;gap:10px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;position:relative}.kbv2-top{flex:0 0 auto;display:grid;gap:10px}.kbv2-topbar{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:12px 14px;display:grid;gap:8px;box-shadow:0 6px 18px #0000000d}.kbv2-title{display:flex;align-items:center;gap:10px;font-weight:900;font-size:var(--fs-16)}.kbv2-sub{color:var(--muted);font-size:var(--fs-12)}.kbv2-pill{font-size:var(--fs-12);font-weight:900;border:1px solid #ddd6fe;background:#f5f3ff;color:#5b21b6;padding:4px 10px;border-radius:999px}.kbv2-filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.kbv2-page .kbv2-filters select{height:38px;border-radius:12px;border:1px solid #cbd5e1;background-color:#fff;padding:0 12px;font-size:var(--fs-14);color:var(--text);-webkit-text-fill-color:var(--text);background-clip:padding-box;text-shadow:none;-webkit-appearance:none;appearance:none}.kbv2-page .kbv2-filters select option{color:#0f172a;background:#fff}.kbv2-btn{height:38px;border-radius:12px;border:1px solid #bae6fd;background:var(--soft);color:#075985;font-weight:900;padding:0 14px;cursor:pointer}.kbv2-btn:hover{background:#bae6fd}.kbv2-page button,.kbv2-page .kbv2-btn{-webkit-text-fill-color:currentColor}.kbv2-page button svg,.kbv2-page .kbv2-btn svg{color:currentColor;opacity:1;visibility:visible}.kbv2-kpis{display:grid;gap:10px}.kbv2-kpis-compact{grid-template-columns:1fr}.kbv2-kpi{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:10px 12px;box-shadow:0 6px 18px #0000000a}.kbv2-kpi .k{font-size:var(--fs-12);color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.4px}.kbv2-kpi .v{margin-top:6px;font-size:var(--fs-38);font-weight:900}.kbv2-kpi.wide .v{font-size:var(--fs-16)}.kbv2-bar{margin-top:10px;height:10px;border-radius:999px;background:#eef2f7;overflow:hidden;border:1px solid #e5e7eb}.kbv2-bar-fill{height:100%;background:linear-gradient(90deg,#0284c7,#16a34a)}.kbv2-kpi-sub{margin-top:8px;font-size:var(--fs-12);color:var(--muted)}.kbv2-charts-row{margin-top:10px;display:grid;grid-template-columns:1fr;gap:10px}.kbv2-chart{min-width:0}.kbv2-chart-bar{position:relative;background:#eef2f7;border:1px solid #e5e7eb;overflow:hidden}.kbv2-seg{position:absolute;top:0;bottom:0}.kbv2-seg.seg-running{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.kbv2-seg.seg-scheduled{background:linear-gradient(90deg,#0284c7,#38bdf8)}.kbv2-seg.seg-completed,.kbv2-seg.seg-good{background:linear-gradient(90deg,#16a34a,#22c55e)}.kbv2-seg.seg-bad{background:linear-gradient(90deg,#ef4444,#b91c1c)}.kbv2-chart-legend{margin-top:8px;display:flex;gap:12px;flex-wrap:wrap;font-size:var(--fs-12);color:var(--muted)}.kbv2-leg{display:flex;align-items:center;gap:6px}.kbv2-leg .dot{width:10px;height:10px;border-radius:999px;background:#cbd5e1}.kbv2-leg .dot.seg-running{background:#7c3aed}.kbv2-leg .dot.seg-scheduled{background:#0284c7}.kbv2-leg .dot.seg-completed,.kbv2-leg .dot.seg-good{background:#16a34a}.kbv2-leg .dot.seg-bad{background:#b91c1c}.kbv2-material-summary{margin-top:6px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:14px 16px;box-shadow:0 6px 18px #0000000a;flex:0 0 auto}.kbv2-ms-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:10px;font-weight:900}.kbv2-ms-head .title{font-size:var(--fs-14)}.kbv2-ms-head .muted{font-size:var(--fs-12);color:var(--muted);font-weight:800}.kbv2-ms-table{display:flex;flex-direction:column;gap:10px;overflow:visible;max-height:none}.kbv2-ms-row{display:flex;justify-content:space-between;gap:16px;padding:10px 12px;border-radius:14px;background:#f8fafc;border:1px solid #eef2f7}.kbv2-ms-row .left{min-width:220px;max-width:420px}.kbv2-ms-row .mat-code{font-weight:900}.kbv2-ms-row .mat-desc{margin-top:2px;font-size:var(--fs-12);color:var(--muted);line-height:1.35}.kbv2-ms-row .right{flex:1;min-width:0}.kbv2-ms-row .nums{display:flex;gap:14px;flex-wrap:wrap;font-size:var(--fs-12);margin-bottom:6px;color:#334155}.kbv2-ms-row .bar{height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden;border:1px solid #e5e7eb}.kbv2-ms-row .bar .fill{height:100%;background:linear-gradient(90deg,#0284c7,#0369a1)}.kbv2-board{flex:0 0 auto;display:grid;grid-template-columns:1fr;gap:10px;align-items:stretch}.kbv2-panel{min-height:0;display:flex}.kbv2-card{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:0 10px 26px #0000000f;overflow:hidden;width:100%;min-height:0}.kbv2-card-full{display:flex;flex-direction:column;min-height:0}.kbv2-card-head{padding:12px 14px;border-bottom:1px solid #eef2f7;display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex:0 0 auto}.kbv2-card-title{font-weight:900;font-size:var(--fs-14);display:flex;align-items:center;gap:10px}.kbv2-running-badge{font-size:var(--fs-11);font-weight:900;padding:3px 8px;border-radius:999px;background:var(--running-soft);color:#5b21b6;border:1px solid #ddd6fe}.kbv2-muted{font-size:var(--fs-12);color:var(--muted)}.kbv2-empty{padding:18px;color:var(--muted)}.kbv2-card-running{border-color:#ddd6fe;box-shadow:0 16px 40px #7c3aed2e}.kbv2-running-list,.kbv2-mini-list{flex:1 1 auto;min-height:0;max-height:62vh;max-height:62dvh;overflow:auto;-webkit-overflow-scrolling:touch;padding:12px 14px}.kbv2-spotlight{border:1px solid #e9d5ff;background:linear-gradient(180deg,#faf5ff,#fff);border-radius:16px;padding:14px;margin-bottom:12px}.kbv2-spot-top{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:baseline}.kbv2-spot-wo .big{font-size:var(--fs-18)}.kbv2-spot-line{color:var(--muted);font-size:var(--fs-12);white-space:nowrap}.kbv2-spot-mat{margin-top:8px;font-size:var(--fs-13);color:#334155;line-height:1.35}.kbv2-spot-metrics{margin-top:10px;display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));gap:10px}.kbv2-spot-metrics span{display:block;font-size:var(--fs-12);color:var(--muted);font-weight:800}.kbv2-spot-metrics b{display:block;font-size:var(--fs-30);font-weight:900}.kbv2-spot-metrics small{margin-left:6px;color:var(--muted);font-weight:800}.kbv2-spot-bar{position:relative;margin-top:12px;height:18px;border-radius:999px;overflow:hidden}.kbv2-row{border:1px solid #eef2f7;background:#fff;border-radius:14px;padding:12px;margin-bottom:12px}.kbv2-row-compact{padding:10px 12px}.kbv2-row-top{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:baseline}.kbv2-wo{display:flex;gap:8px;align-items:baseline}.kbv2-dot{color:#cbd5e1}.kbv2-line{color:var(--muted);font-size:var(--fs-12);white-space:nowrap}.kbv2-mat{margin-top:6px;color:#334155;font-size:var(--fs-13);line-height:1.35}.kbv2-graph{margin-top:10px}.kbv2-graph-meta{display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));gap:8px;color:var(--muted);font-size:var(--fs-12)}.kbv2-graph-bar{position:relative;margin-top:8px;height:14px;border-radius:999px;overflow:hidden}.kbv2-graph-base{position:absolute;inset:0;background:#eef2f7;border:1px solid #e5e7eb;border-radius:999px}.kbv2-graph-good{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#16a34a,#22c55e)}.kbv2-graph-bad{position:absolute;top:0;bottom:0;background:linear-gradient(90deg,#ef4444,#b91c1c)}.kbv2-graph-marker{position:absolute;top:-3px;bottom:-3px;width:2px;background:#0f172a;opacity:.55}.kbv2-time,.kbv2-spot-time{margin-top:8px;font-size:var(--fs-12);color:var(--muted)}.kbv2-mini{border:1px solid #eef2f7;border-radius:14px;padding:10px 12px;margin-bottom:10px;background:#fff}.kbv2-mini-top{display:flex;justify-content:space-between;gap:10px;align-items:baseline;flex-wrap:wrap}.kbv2-mini-wo{font-size:var(--fs-13)}.kbv2-mini-line{font-size:var(--fs-12);color:var(--muted)}.kbv2-mini-mat{margin-top:6px;font-size:var(--fs-14);color:#334155;line-height:1.35}.kbv2-mini-bar{margin-top:8px;height:10px;border-radius:999px;background:#eef2f7;border:1px solid #e5e7eb;overflow:hidden}.kbv2-mini-bar .fill{height:100%;width:0%;background:linear-gradient(90deg,#0284c7,#16a34a)}.kbv2-mini-bar.completed .fill{background:linear-gradient(90deg,#16a34a,#22c55e)}.kbv2-mini-sub{margin-top:8px;font-size:var(--fs-16);color:var(--muted)}.kbv2-loading{padding:24px;font-weight:900;color:var(--muted)}.kbv2-errorbar{background:#fff1f2;border:1px solid #fecdd3;color:#9f1239;padding:10px 12px;border-radius:12px;font-weight:800}.kbv2-overlay{position:absolute;inset:0;background:#f8fafc8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;gap:10px;z-index:50;pointer-events:none}.kbv2-spinner{width:18px;height:18px;border-radius:999px;border:3px solid #cbd5e1;border-top-color:#0284c7;animation:kbv2spin .8s linear infinite}.kbv2-overlay-txt{font-weight:900;color:#0f172a}@keyframes kbv2spin{to{transform:rotate(360deg)}}.kbv2-page .good{color:var(--good)!important;-webkit-text-fill-color:var(--good)!important}.kbv2-page .bad{color:var(--bad)!important;-webkit-text-fill-color:var(--bad)!important}.kbv2-page .kbv2-sub,.kbv2-page .kbv2-kpi .k,.kbv2-page .kbv2-kpi-sub,.kbv2-page .kbv2-muted,.kbv2-page .kbv2-empty,.kbv2-page .kbv2-ms-head .muted,.kbv2-page .kbv2-ms-row .mat-desc,.kbv2-page .kbv2-line,.kbv2-page .kbv2-time,.kbv2-page .kbv2-spot-time,.kbv2-page .kbv2-graph-meta,.kbv2-page .kbv2-chart-legend{color:var(--muted);-webkit-text-fill-color:var(--muted)}@media(min-width:640px){.kbv2-graph-meta,.kbv2-spot-metrics{grid-template-columns:repeat(4,minmax(120px,1fr))}}@media(min-width:1024px){.kbv2-kpis-compact{grid-template-columns:480px 1fr}.kbv2-charts-row{grid-template-columns:1fr 1fr}.kbv2-board{grid-template-columns:.8fr 1.35fr .8fr}}@media(forced-colors:active){.kbv2-page{forced-color-adjust:auto}.kbv2-page .kbv2-topbar,.kbv2-page .kbv2-kpi,.kbv2-page .kbv2-material-summary,.kbv2-page .kbv2-card{border:1px solid ButtonText!important;background:Canvas!important;color:CanvasText!important}.kbv2-page .kbv2-filters select,.kbv2-page button,.kbv2-page .kbv2-btn{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}}.psq-view-btn{width:40px;height:40px;border-radius:10px;border:1px solid transparent;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.15s;color:#334155}.psq-view-btn svg{width:18px;height:18px;stroke-width:2;stroke:currentColor;fill:none}.psq-view-btn.active{color:var(--primary);background:var(--primary-soft);border-color:#7dd3fc;box-shadow:0 0 0 3px #0369a11a}.psq-wo{font-size:var(--fs-15);font-weight:900;color:#111827}.psq-mat{font-size:var(--fs-13);font-weight:900;color:#1f2937}.psq-desc{font-size:var(--fs-13);font-weight:800;color:#334155}.psq-mini-mid{font-size:var(--fs-11);font-weight:900;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.psq-mini-bot{display:flex;justify-content:space-between;gap:10px;font-size:var(--fs-11);font-weight:900;color:#64748b}.psq-more{margin-top:8px;text-align:center;font-weight:900;color:#64748b;background:#fff;border:1px dashed #cbd5e1;border-radius:12px;padding:10px 12px}.psq-icon{width:40px;height:40px;border-radius:999px;border:1.5px solid #cbd5e1;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.psq-view-btn{color:#0f172a!important;line-height:1!important;font-size:var(--fs-16)}.psq-view-btn.active{color:var(--primary)!important}.psq-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary-soft: #e0f2fe;--warn: #9a3412;--warn-soft: #fff7ed;--red: #991b1b;--red-soft: #fee2e2;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--r: 16px;--r2: 12px;height:100%;width:100%;padding:16px 24px;background:var(--bg);color:var(--text);overflow:auto}.psq-topbar{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:12px 14px;display:flex;justify-content:space-between;align-items:flex-end;gap:12px;box-shadow:var(--shadow-sm);margin-bottom:12px}.psq-title{font-weight:900;font-size:var(--fs-16);display:flex;align-items:center;gap:10px;flex-wrap:wrap}.psq-sub{display:block;width:100%;font-weight:700;font-size:var(--fs-12);color:var(--muted);margin-top:2px}.psq-tools{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.psq-select{height:40px;border-radius:10px;border:1px solid #94a3b8;background:#e8edf5;padding:0 12px;font-size:var(--fs-16)}.psq-select:focus{outline:none;background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #0369a11a}.psq-btn{height:40px;padding:0 14px;border-radius:10px;border:1px solid #bae6fd;background:var(--primary-soft);color:var(--primary);font-weight:800;font-size:var(--fs-16);cursor:pointer;display:inline-flex;align-items:center;gap:8px}.psq-btn:hover{background:#bae6fd;border-color:#7dd3fc}.psq-btn:disabled{opacity:.55;cursor:not-allowed}.psq-saving{margin:8px 0 10px;font-weight:900;color:var(--primary)}.psq-pill{height:24px;padding:0 10px;border-radius:999px;background:#ffffffbf;border:1px solid rgba(0,0,0,.08);color:var(--text);font-weight:900;display:inline-flex;align-items:center}.psq-view{display:flex;gap:8px;align-items:center;padding:4px;border:1px solid #e5e7eb;background:#fff;border-radius:12px}.psq-view-btn{width:40px;height:40px;border-radius:10px;border:1px solid transparent;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.15s;color:#0f172a!important;line-height:1!important}.psq-view-btn svg{display:block!important;width:18px!important;height:18px!important;stroke:currentColor!important;fill:none!important;opacity:1!important;visibility:visible!important}.psq-view-btn:hover{background:var(--primary-soft);border-color:#bae6fd}.psq-view-btn.active{background:var(--primary-soft);border-color:#7dd3fc;box-shadow:0 0 0 3px #0369a11a;color:var(--primary)!important}.psq-board3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;align-items:start}.psq-col{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.psq-col-head{position:sticky;top:0;z-index:2;padding:12px 14px;display:flex;justify-content:space-between;align-items:center;font-weight:900;background:var(--primary-soft);color:var(--primary);border-bottom:1px solid var(--border)}.psq-col-body{padding:12px;display:flex;flex-direction:column;gap:10px;background:var(--bg);overflow:visible}.psq-card{position:relative;background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:var(--shadow-sm);padding:12px}.psq-card-draggable{cursor:grab;-webkit-user-select:none;user-select:none}.psq-card-draggable:active{cursor:grabbing}.psq-seq{position:absolute;top:10px;right:10px;font-size:var(--fs-11);font-weight:900;color:#0f172a;background:#f1f5f9;border:1px solid #e5e7eb;border-radius:999px;padding:4px 8px}.psq-card-head2{display:flex;flex-direction:column;gap:6px}.psq-wo{font-size:var(--fs-16);font-weight:900;color:#111827}.psq-sub2{font-size:var(--fs-12);font-weight:800;color:#64748b}.psq-tags{display:flex;flex-wrap:wrap;gap:6px}.psq-tag{font-size:var(--fs-11);font-weight:900;padding:4px 8px;border-radius:999px;background:#f8fafc;border:1px solid #e5e7eb;color:#0f172a}.psq-card-body2{display:flex;flex-direction:column;gap:6px;margin-top:6px}.psq-mat{font-size:var(--fs-14);font-weight:900;color:#1f2937}.psq-desc{font-size:var(--fs-14);font-weight:800;color:#334155}.psq-density-medium .psq-desc{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.psq-qty{margin-top:6px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;font-size:var(--fs-12);font-weight:800;color:#475569}.psq-qty b{font-size:var(--fs-13);color:#111827}.psq-card-foot2{margin-top:8px;padding-top:8px;border-top:1px dashed #e5e7eb;display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:center;font-size:var(--fs-11);color:#64748b;font-weight:800}.psq-mini{display:flex;flex-direction:column;gap:6px}.psq-mini-top{display:flex;justify-content:space-between;gap:10px;align-items:center}.psq-mini-wo{font-size:var(--fs-16);font-weight:900;color:#111827}.psq-mini-line{font-size:var(--fs-14);font-weight:900;color:#0369a1;background:#e0f2fe;border:1px solid #bae6fd;padding:3px 8px;border-radius:999px;white-space:nowrap}.psq-mini-mid{font-size:var(--fs-14);font-weight:900;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.psq-mini-bot{display:flex;justify-content:space-between;gap:10px;font-size:var(--fs-14);font-weight:900;color:#64748b}.psq-icon{width:40px;height:40px;border-radius:999px;border:1.5px solid #cbd5e1;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:#334155}.psq-icon svg{width:18px;height:18px;stroke-width:2;stroke:currentColor;fill:none}.psq-icon:hover{background:#f1f5f9}.psq-icon.danger{border-color:#fecaca;background:var(--red-soft);color:var(--red)}.psq-icon.danger:hover{background:#fecaca}.psq-empty{border:1px dashed #cbd5e1;background:#fff;border-radius:12px;padding:14px;text-align:center;font-weight:900;color:#64748b}@media(max-width:1100px){.psq-page{padding:16px}.psq-board3{grid-template-columns:1fr}}.psq-page{color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.psq-page svg{display:inline-block;vertical-align:middle;overflow:visible}.psq-page .psq-view-btn{color:#0f172a!important;background:#fff;line-height:1!important;font-size:var(--fs-16)!important;-webkit-text-fill-color:currentColor!important}.psq-page .psq-view-btn svg{display:block!important;width:18px!important;height:18px!important;stroke:currentColor!important;fill:none!important;opacity:1!important;visibility:visible!important;pointer-events:none}.psq-page .psq-view-btn:hover{background:var(--primary-soft);border-color:#bae6fd}.psq-page .psq-view-btn.active{color:var(--primary)!important;background:var(--primary-soft);border-color:#7dd3fc;box-shadow:0 0 0 3px #0369a11a;-webkit-text-fill-color:currentColor!important}.psq-page .psq-icon{color:#334155!important;-webkit-text-fill-color:currentColor!important}.psq-page .psq-icon svg{stroke:currentColor!important;fill:none!important;opacity:1!important;visibility:visible!important;pointer-events:none}.psq-page .psq-icon.danger{color:var(--red)!important;-webkit-text-fill-color:currentColor!important}.psq-page .psq-sub,.psq-page .psq-sub2,.psq-page .psq-mini-bot,.psq-page .psq-empty{color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important}@media(forced-colors:active){.psq-page{forced-color-adjust:auto}.psq-page .psq-view,.psq-page .psq-topbar,.psq-page .psq-col,.psq-page .psq-card{border:1px solid ButtonText!important;background:Canvas!important;color:CanvasText!important}.psq-page .psq-view-btn,.psq-page .psq-icon{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}.psq-page .psq-view-btn svg,.psq-page .psq-icon svg{stroke:ButtonText!important}}.psq-child-box{margin-top:8px;border:1px solid #dbeafe;background:#eff6ff;border-radius:12px;overflow:hidden}.psq-child-head{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;font-size:var(--fs-11);font-weight:900;color:#1e3a8a;border-bottom:1px solid #bfdbfe}.psq-child-head span{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#fff;border:1px solid #bfdbfe;display:flex;align-items:center;justify-content:center}.psq-child-list{display:flex;flex-direction:column;gap:6px;padding:6px}.psq-child-row{background:#fff;border:1px solid #dbeafe;border-radius:10px;padding:6px 8px;display:flex;flex-direction:column;gap:3px}.psq-child-top{display:flex;justify-content:space-between;font-size:var(--fs-11);font-weight:900}.psq-child-desc{font-size:var(--fs-11);color:#64748b;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.psq-child-meta{display:flex;justify-content:space-between;font-size:var(--fs-11);font-weight:800;color:#475569}.psq-child-meta strong{color:#0f172a}.rpd-page{padding:18px;background:#f4f7fb;min-height:100%;color:#0f172a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.rpd-page *,.rpd-page *:before,.rpd-page *:after{box-sizing:border-box}.rpd-page button,.rpd-page input,.rpd-page select,.rpd-page textarea{font:inherit}.rpd-page button{-webkit-tap-highlight-color:transparent;appearance:none;-webkit-appearance:none;-moz-appearance:none}.rpd-page select,.rpd-page input,.rpd-page textarea{appearance:none;-webkit-appearance:none;-moz-appearance:none}.rpd-page button,.rpd-page .rpd-refresh-btn,.rpd-page .rpd-action-btn,.rpd-page .rpd-chip,.rpd-page select,.rpd-page input,.rpd-page textarea{-webkit-text-fill-color:currentColor}.rpd-page button,.rpd-page input,.rpd-page select,.rpd-page textarea{color:inherit}.rpd-page button svg,.rpd-page .rpd-refresh-btn svg,.rpd-page .rpd-action-btn svg{width:1em;height:1em;display:block;flex-shrink:0;overflow:visible;color:currentColor}.rpd-page button svg *,.rpd-page .rpd-refresh-btn svg *,.rpd-page .rpd-action-btn svg *{vector-effect:non-scaling-stroke}.rpd-page :focus-visible{outline:0;box-shadow:0 0 0 3px #0f766e24}.rpd-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.rpd-title{display:flex;align-items:center;gap:10px;font-size:var(--fs-28);font-weight:800}.rpd-subtitle{margin-top:6px;color:#475569;font-size:var(--fs-14)}.rpd-refresh-btn{border:0;border-radius:14px;background:#0f766e;color:#fff;font-weight:700;padding:12px 16px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;box-shadow:0 10px 24px #0f766e2e}.rpd-refresh-btn:hover{filter:brightness(1.03)}.rpd-refresh-btn:disabled{opacity:.65;cursor:not-allowed}.spin{animation:rpd-spin .9s linear infinite}@keyframes rpd-spin{to{transform:rotate(360deg)}}.rpd-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(220px,1fr));gap:14px;margin-bottom:16px}.rpd-summary-card{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dbe5f0;border-radius:20px;padding:18px;box-shadow:0 12px 30px #0f172a0f}.rpd-summary-card.warning{border-color:#fde68a;background:linear-gradient(180deg,#fffdf4,#fff8db)}.rpd-summary-card.success{border-color:#bbf7d0;background:linear-gradient(180deg,#f5fff7,#eaffef)}.rpd-summary-card.info{border-color:#bfdbfe;background:linear-gradient(180deg,#f4f9ff,#e8f3ff)}.rpd-summary-icon{width:42px;height:42px;border-radius:14px;background:#e2e8f0;display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-18);margin-bottom:12px}.rpd-summary-label{color:#475569;font-size:var(--fs-14);margin-bottom:8px}.rpd-summary-value{font-size:var(--fs-30);font-weight:800;line-height:1.1}.rpd-summary-sub{margin-top:6px;color:#334155;font-size:var(--fs-14);font-weight:600}.rpd-toolbar-card,.rpd-wo-card{background:#fff;border:1px solid #dbe5f0;border-radius:20px;box-shadow:0 12px 30px #0f172a0f}.rpd-toolbar-card{padding:14px;margin-bottom:16px}.rpd-toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.rpd-search{flex:1 1 380px;min-width:260px;display:flex;align-items:center;gap:10px;border:1px solid #cbd5e1;background:#fff;border-radius:14px;padding:0 14px;height:46px}.rpd-search input{flex:1;border:0;outline:0;background:transparent;font-size:var(--fs-14)}.rpd-search input::placeholder{color:#94a3b8;-webkit-text-fill-color:#94a3b8}.rpd-toolbar select{border:1px solid #cbd5e1;border-radius:14px;height:46px;padding:0 14px;background:#fff;min-width:150px;font-weight:600;color:#0f172a}.rpd-filter-group{display:flex;gap:8px;flex-wrap:wrap}.rpd-chip{border:1px solid #cbd5e1;background:#fff;color:#334155;border-radius:999px;height:40px;padding:0 14px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.rpd-chip.active{background:#0f172a;color:#fff;border-color:#0f172a}.rpd-chip.active.pending{background:#b45309;color:#fff;border-color:#b45309}.rpd-chip.active.ready{background:#15803d;color:#fff;border-color:#15803d}.rpd-wo-grid{display:grid;gap:16px}.rpd-wo-card{padding:16px}.rpd-wo-header{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:12px}.rpd-wo-code{font-size:var(--fs-22);font-weight:800}.rpd-wo-meta,.rpd-wo-mat,.rpd-time-row,.rpd-item-sub{color:#475569;font-size:var(--fs-14)}.rpd-wo-mat{margin-top:4px}.rpd-wo-stats{display:flex;gap:10px;flex-wrap:wrap}.rpd-stat-box{min-width:140px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:10px 12px}.rpd-stat-box.warning{background:#fff7ed;border-color:#fed7aa}.rpd-stat-box span{display:block;color:#64748b;font-size:var(--fs-12);margin-bottom:4px}.rpd-stat-box strong{font-size:var(--fs-18);color:#0f172a}.rpd-time-row{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:14px}.rpd-mix-panel{margin-bottom:14px;padding:14px;border:1px solid #e2e8f0;border-radius:18px;background:linear-gradient(180deg,#fbfdff,#f8fbff)}.rpd-mix-title{font-size:var(--fs-15);font-weight:800;margin-bottom:10px}.rpd-mix-chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}.rpd-mix-chip{min-width:180px;padding:10px 12px;border-radius:16px;border:1px solid;display:flex;flex-direction:column;gap:4px}.rpd-mix-chip.master{background:#ecfeff;border-color:#67e8f9}.rpd-mix-chip.color{background:#fff7ed;border-color:#fdba74}.rpd-mix-chip span{font-size:var(--fs-11);font-weight:800;color:#64748b}.rpd-mix-chip strong{font-size:var(--fs-14);color:#0f172a}.rpd-mix-chip em{font-style:normal;font-size:var(--fs-18);font-weight:800;color:#0f172a}.rpd-wo-actions{display:flex;justify-content:flex-end;gap:10px}.rpd-table-wrap{overflow:auto;border:1px solid #e2e8f0;border-radius:16px}.rpd-table{width:100%;border-collapse:collapse;min-width:1200px}.rpd-table thead th{position:sticky;top:0;z-index:1;background:#eff6ff;color:#0f172a;font-size:var(--fs-13);font-weight:800;padding:12px;text-align:left;border-bottom:1px solid #dbe5f0}.rpd-table tbody td{padding:12px;border-bottom:1px solid #eef2f7;vertical-align:middle}.rpd-table tbody tr:hover{background:#fafcff}.rpd-table tbody tr.is-ready{background:#f7fff8}.rpd-badge,.rpd-role{display:inline-flex;align-items:center;justify-content:center;min-width:92px;height:32px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:800}.rpd-badge.ready{background:#dcfce7;color:#166534}.rpd-badge.pending{background:#fef3c7;color:#92400e}.rpd-role.master{background:#cffafe;color:#155e75}.rpd-role.color{background:#ffedd5;color:#9a3412}.rpd-item-name{font-weight:700;color:#0f172a}.rpd-action-group{display:flex;gap:8px;flex-wrap:wrap}.rpd-action-btn{border:0;border-radius:12px;height:38px;padding:0 14px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:8px;justify-content:center}.rpd-action-btn.primary{background:#0f766e;color:#fff}.rpd-action-btn.success{background:#15803d;color:#fff}.rpd-action-btn.ghost{background:#fff;color:#475569;border:1px solid #cbd5e1}.rpd-action-btn.print{background:#1d4ed8;color:#fff}.rpd-action-btn:disabled{opacity:.65;cursor:not-allowed}.qty{font-weight:800;color:#0f172a}.rpd-empty{background:#fff;border:1px dashed #cbd5e1;border-radius:20px;padding:36px;text-align:center;color:#64748b;font-weight:600}@media(max-width:1200px){.rpd-summary-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media(max-width:768px){.rpd-page{padding:12px}.rpd-summary-grid{grid-template-columns:1fr}.rpd-title{font-size:var(--fs-22)}.rpd-topbar{flex-direction:column;align-items:stretch}.rpd-refresh-btn{width:100%;justify-content:center}.rpd-wo-actions{justify-content:stretch}.rpd-wo-actions .rpd-action-btn{width:100%;justify-content:center}}.rpd-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.rpd-print-area{display:none}.rpd-print-sheet{background:#fff;color:#000;padding:18px;page-break-after:always}.rpd-print-sheet:last-child{page-break-after:auto}.rpd-print-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.rpd-print-title{font-size:var(--fs-24);font-weight:800}.rpd-print-subtitle{font-size:var(--fs-12);color:#444}.rpd-print-meta-right{font-size:var(--fs-12);text-align:right}.rpd-print-info-grid{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:8px 16px;margin-bottom:14px;font-size:var(--fs-13)}.rpd-print-info-grid .full{grid-column:1 / -1}.rpd-print-table{width:100%;border-collapse:collapse;margin-bottom:14px;font-size:var(--fs-12)}.rpd-print-table th,.rpd-print-table td{border:1px solid #000;padding:6px 8px;vertical-align:top}.rpd-print-table th{background:#f3f4f6;font-weight:800;text-align:left}.rpd-print-sub{font-size:var(--fs-11);color:#444}.rpd-print-summary{display:flex;justify-content:space-between;gap:16px;margin:12px 0 22px;font-size:var(--fs-13)}.rpd-print-signatures{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:36px}.rpd-sign-box{text-align:center;font-size:var(--fs-13)}.rpd-sign-line{border-bottom:1px solid #000;height:40px;margin-bottom:8px}@media print{body.resin-printing *{visibility:hidden!important}body.resin-printing .rpd-print-area,body.resin-printing .rpd-print-area *{visibility:visible!important}body.resin-printing .rpd-print-area{display:block!important;position:absolute;inset:0;background:#fff}body.resin-printing .rpd-print-sheet{width:100%;min-height:auto;box-shadow:none;margin:0;padding:12mm}body.resin-printing .rpd-print-info-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}@page{size:A4 portrait;margin:8mm}}@media(forced-colors:active){.rpd-refresh-btn,.rpd-action-btn,.rpd-chip,.rpd-toolbar select{border:1px solid ButtonText;background:ButtonFace;color:ButtonText;-webkit-text-fill-color:ButtonText}.rpd-search,.rpd-search input{border-color:ButtonText;background:Field;color:FieldText;-webkit-text-fill-color:FieldText}.rpd-refresh-btn svg,.rpd-action-btn svg{color:ButtonText}}.rnc-page{display:grid;gap:16px;padding:16px;background:#f8fafc;min-height:100%;width:100%;max-width:100%;overflow-x:hidden;color:#0f172a;box-sizing:border-box}.rnc-page *,.rnc-page *:before,.rnc-page *:after{box-sizing:border-box;min-width:0}.rnc-loading,.rnc-empty{background:#fff;border:1px solid #dbe3ef;border-radius:20px;padding:32px 20px;text-align:center;font-size:var(--fs-18);font-weight:600;color:#475569;box-shadow:0 10px 30px #0f172a0f}.rnc-errorbar{background:#fff1f2;color:#be123c;border:1px solid #fecdd3;border-radius:16px;padding:12px 14px;font-weight:600}.rnc-topbar{display:grid;gap:14px;padding:18px;background:#fff;border:1px solid #dbe3ef;border-radius:22px;box-shadow:0 10px 30px #0f172a0f;min-width:0}.rnc-title-wrap{display:grid;gap:6px;min-width:0}.rnc-title{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0;font-size:var(--fs-28);font-weight:800;letter-spacing:-.02em}.rnc-subtitle,.rnc-updated{color:#475569;font-size:var(--fs-14);font-weight:500;min-width:0}.rnc-pill{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:var(--fs-12);font-weight:700;color:#0369a1;background:#e0f2fe;border:1px solid #bae6fd;flex:0 0 auto}.rnc-filters{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;min-width:0}.rnc-filters select,.rnc-btn{width:100%;max-width:100%;min-height:44px;border-radius:14px;border:1px solid #cbd5e1;background:#fff;padding:0 12px;font-size:var(--fs-14);font-weight:600;color:#0f172a;outline:none;appearance:none}.rnc-filters select:focus,.rnc-btn:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.rnc-btn{cursor:pointer;background:linear-gradient(135deg,#0f172a,#1e293b);border-color:#0f172a;color:#fff}.rnc-summary{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;min-width:0}.rnc-sum-card{background:#fff;border:1px solid #dbe3ef;border-radius:20px;padding:16px;display:grid;gap:6px;min-width:0;overflow:hidden;box-shadow:0 10px 30px #0f172a0d}.rnc-sum-card span{color:#64748b;font-size:var(--fs-13);font-weight:600}.rnc-sum-card strong{font-size:clamp(20px,2vw,24px);font-weight:800;line-height:1.1;color:#0f172a;overflow-wrap:anywhere}.rnc-sum-card-wide{grid-column:span 2}.rnc-progress{width:100%;height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.rnc-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#22c55e,#0ea5e9)}.rnc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:start;width:100%;min-width:0}.rnc-card{display:grid;gap:14px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dbe3ef;border-radius:24px;padding:18px;box-shadow:0 14px 34px #0f172a14;min-width:0;width:100%;max-width:100%;overflow:hidden}.rnc-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;min-width:0}.rnc-card-head>:first-child{min-width:0;flex:1 1 auto}.rnc-wo{font-size:var(--fs-22);font-weight:800;line-height:1.15;min-width:0;overflow-wrap:anywhere;word-break:break-word}.rnc-order{margin-top:6px;font-size:var(--fs-13);color:#475569;font-weight:600;min-width:0;overflow-wrap:anywhere;word-break:break-all}.rnc-live{white-space:nowrap;border-radius:999px;padding:6px 10px;background:#dcfce7;color:#166534;border:1px solid #86efac;font-size:var(--fs-12);font-weight:800;flex:0 0 auto}.rnc-line-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;border-radius:16px;background:#eff6ff;border:1px solid #bfdbfe;min-width:0}.rnc-line-row .label{color:#475569;font-size:var(--fs-12);font-weight:700;text-transform:uppercase;flex:0 0 auto}.rnc-line-row b{font-size:var(--fs-15);font-weight:800;text-align:right;min-width:0;flex:1 1 auto;overflow-wrap:anywhere;word-break:break-word}.rnc-material{display:grid;gap:4px;min-width:0}.rnc-material-no{font-size:var(--fs-13);color:#334155;font-weight:700;min-width:0;overflow-wrap:anywhere;word-break:break-all}.rnc-material-desc{font-size:var(--fs-14);font-weight:600;color:#0f172a;line-height:1.45;min-width:0;overflow-wrap:anywhere;word-break:break-word}.rnc-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;min-width:0}.rnc-stat{display:grid;gap:4px;padding:12px;border-radius:16px;background:#fff;border:1px solid #e2e8f0;min-width:0;overflow:hidden}.rnc-stat span{font-size:var(--fs-12);color:#64748b;font-weight:700}.rnc-stat strong{font-size:clamp(16px,1.5vw,18px);color:#0f172a;font-weight:800;line-height:1.1;overflow-wrap:anywhere}.good{color:#15803d!important}.bad{color:#dc2626!important}.rnc-bar-wrap{display:grid;gap:8px;min-width:0}.rnc-bar-meta{display:flex;justify-content:space-between;gap:10px;min-width:0;font-size:var(--fs-13);font-weight:700;color:#334155}.rnc-bar-meta span,.rnc-bar-meta b{min-width:0}.rnc-bar{position:relative;height:14px;border-radius:999px;overflow:hidden;background:#e2e8f0;width:100%}.rnc-bar-base,.rnc-bar-good,.rnc-bar-bad,.rnc-bar-marker{position:absolute;top:0;height:100%}.rnc-bar-base{left:0;width:100%;background:#e2e8f0}.rnc-bar-good{left:0;background:linear-gradient(90deg,#22c55e,#16a34a)}.rnc-bar-bad{background:linear-gradient(90deg,#fb7185,#ef4444)}.rnc-bar-marker{width:3px;background:#0f172a;box-shadow:0 0 0 1px #fffc}.rnc-time-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;min-width:0}.rnc-time-grid>div{display:grid;gap:4px;padding:12px;border-radius:16px;background:#f8fafc;border:1px solid #e2e8f0;min-width:0;overflow:hidden}.rnc-time-grid span{font-size:var(--fs-12);color:#64748b;font-weight:700}.rnc-time-grid b{font-size:var(--fs-14);color:#0f172a;font-weight:800;min-width:0;overflow-wrap:anywhere;word-break:break-word}@media(max-width:1280px){.rnc-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.rnc-sum-card-wide{grid-column:span 3}}@media(max-width:1100px){.rnc-grid{grid-template-columns:1fr}}@media(max-width:760px){.rnc-page{padding:12px;gap:12px}.rnc-topbar,.rnc-card,.rnc-sum-card{border-radius:18px}.rnc-title{font-size:var(--fs-22)}.rnc-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.rnc-sum-card-wide{grid-column:span 2}.rnc-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.rnc-time-grid,.rnc-filters,.rnc-grid{grid-template-columns:1fr}.rnc-card{padding:14px}.rnc-wo{font-size:var(--fs-20)}.rnc-line-row{flex-direction:column;align-items:flex-start}.rnc-line-row b{text-align:left;width:100%}}.rnc-child-box{margin-top:10px;border:1px solid #dbeafe;background:#eff6ff;border-radius:14px;overflow:hidden}.rnc-child-head{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;font-size:var(--fs-12);font-weight:900;color:#1e3a8a;border-bottom:1px solid #bfdbfe}.rnc-child-head span{min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:#fff;border:1px solid #bfdbfe;display:inline-flex;align-items:center;justify-content:center}.rnc-child-list{display:flex;flex-direction:column;gap:6px;padding:7px}.rnc-child-row{background:#fff;border:1px solid #dbeafe;border-radius:10px;padding:7px 9px;display:flex;flex-direction:column;gap:3px}.rnc-child-top,.rnc-child-meta{display:flex;justify-content:space-between;gap:10px}.rnc-child-top{font-size:var(--fs-11);font-weight:900}.rnc-child-desc{font-size:var(--fs-11);color:#64748b;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rnc-child-meta{font-size:var(--fs-11);color:#475569;font-weight:800}.rnc-child-meta strong{color:#0f172a}.rnc-oee-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.rnc-oee-grid>div{display:grid;gap:4px;padding:12px;border-radius:16px;background:#f8fafc;border:1px solid #e2e8f0}.rnc-oee-grid span,.rnc-oee-card span{font-size:var(--fs-12);font-weight:800;color:#64748b}.rnc-oee-grid b,.rnc-oee-card strong{font-size:var(--fs-18);font-weight:900;color:#0f172a}.rnc-oee-grid .primary,.rnc-oee-card.primary{background:#ecfeff;border-color:#67e8f9}.rnc-oee-grid .primary b,.rnc-oee-card.primary strong{color:#0369a1}.rnc-sum-card span,.rnc-sum-card strong,.rnc-oee-card.primary strong{font-size:var(--fs-8)}@keyframes blinkRed{0%{border-color:#ef4444;box-shadow:0 0 #ef444400}50%{border-color:#dc2626;box-shadow:0 0 12px #ef444499}to{border-color:#ef4444;box-shadow:0 0 #ef444400}}.rnc-sum-card.alert{border:2px solid #ef4444!important;animation:blinkRed 1s infinite;background:#fff1f2}.rnc-oee-grid>div.alert{border:2px solid #ef4444!important;animation:blinkRed 1s infinite;background:#fff1f2}.alert b,.alert strong{color:#dc2626!important}.rnc-summary .rnc-sum-card span{font-size:var(--fs-13);font-weight:800}.rnc-summary .rnc-sum-card strong{font-size:clamp(18px,1.45vw,22px);font-weight:900;line-height:1.05}.rnc-summary .rnc-oee-card strong{font-size:clamp(18px,1.45vw,21px)}.rnc-summary .rnc-oee-card.primary strong{font-size:clamp(19px,1.55vw,23px)}.rnc-oee-grid b{font-size:clamp(18px,1.25vw,22px)}.rnc-oee-grid span{font-size:var(--fs-13)}.rnc-stat strong{white-space:normal;word-break:break-word}.rnc-stat span{white-space:nowrap}.rnc-reason-badge{display:inline-flex;align-items:center;justify-content:center;min-width:74px;height:28px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:800;letter-spacing:.02em;border:1px solid transparent;white-space:nowrap}.rnc-reason-running{color:#047857;background:#d1fae5;border-color:#6ee7b7}.rnc-reason-stop{color:#b91c1c;background:#fee2e2;border-color:#fecaca}.rnc-reason-offline{color:#475569;background:#e2e8f0;border-color:#cbd5e1}.rnc-reason-notuse{color:#6b21a8;background:#f3e8ff;border-color:#d8b4fe}.rnc-reason-planned{color:#1d4ed8;background:#dbeafe;border-color:#93c5fd}.rnc-reason-setup{color:#b45309;background:#fef3c7;border-color:#fcd34d}.rnc-reason-unknown{color:#334155;background:#f1f5f9;border-color:#cbd5e1}.pmo-page{--pmo-bg: #f8fafc;--pmo-card: #ffffff;--pmo-border: #cbd5e1;--pmo-border-soft: #e5e7eb;--pmo-text: #111827;--pmo-muted: #6b7280;--pmo-primary: #0369a1;--pmo-primary-soft: #e0f2fe;--pmo-primary-border: #bae6fd;--pmo-green: #166534;--pmo-green-bg: #ecfdf5;--pmo-green-border: #86efac;--pmo-red: #991b1b;--pmo-red-bg: #fee2e2;--pmo-red-border: #fecaca;--pmo-radius: 16px;--pmo-shadow: 0 10px 26px rgba(15, 23, 42, .06);min-height:100dvh;padding:16px;background:var(--pmo-bg);color:var(--pmo-text);font-family:var(--pps-font-main);font-size:var(--fs-16);font-weight:400;line-height:1.5;overflow:hidden}.pmo-page,.pmo-page *{box-sizing:border-box;min-width:0}.pmo-card{background:var(--pmo-card);border:1px solid var(--pmo-border);border-radius:var(--pmo-radius);box-shadow:var(--pmo-shadow)}.pmo-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 16px;margin-bottom:12px}.pmo-title,.pmo-section-title{color:var(--pmo-text);font-size:var(--fs-16);font-weight:700;line-height:1.35}.pmo-subtitle,.pmo-section-sub,.pmo-muted{color:var(--pmo-muted);font-size:var(--fs-14);font-weight:400}.pmo-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.pmo-actions select,.pmo-search input,.pmo-add-row input{height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;color:var(--pmo-text);padding:0 12px;font-family:inherit;font-size:var(--fs-16);font-weight:400;outline:none}.pmo-actions select:focus,.pmo-search:focus-within,.pmo-add-row input:focus{border-color:var(--pmo-primary);background:#fff;box-shadow:0 0 0 3px #0369a11a}.pmo-btn{min-height:40px;border-radius:10px;border:1px solid var(--pmo-primary-border);background:var(--pmo-primary-soft);color:var(--pmo-primary);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;font-family:inherit;font-size:var(--fs-16);font-weight:600;cursor:pointer;transition:.18s ease;white-space:nowrap}.pmo-btn:hover{background:#bae6fd}.pmo-btn:disabled{opacity:.5;cursor:not-allowed}.pmo-btn-primary{border-color:var(--pmo-green-border);background:var(--pmo-green-bg);color:#16a34a}.pmo-layout{display:grid;grid-template-columns:minmax(300px,.95fr) minmax(360px,1.15fr) minmax(320px,1fr);gap:12px;height:calc(100dvh - 120px);overflow:hidden}.pmo-panel{display:flex;flex-direction:column;overflow:hidden;padding:12px}.pmo-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.pmo-count{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:26px;padding:0 10px;border-radius:999px;background:#f1f5f9;border:1px solid var(--pmo-border-soft);color:var(--pmo-text);font-size:var(--fs-13);font-weight:700}.pmo-search{min-height:40px;border:1px solid #9ca3af;border-radius:10px;display:flex;align-items:center;gap:8px;padding:0 10px;background:#e8edf5;color:var(--pmo-muted);margin-bottom:10px}.pmo-search input{flex:1;border:0;background:transparent;box-shadow:none!important;padding:0}.pmo-list,.pmo-child-list{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:10px;padding-right:4px}.pmo-wo-card,.pmo-order-card,.pmo-child-card{width:100%;border:1px solid var(--pmo-border-soft);border-radius:14px;background:#fff;padding:12px;box-shadow:0 6px 16px #0f172a0b}.pmo-wo-card{text-align:left;cursor:pointer;font-family:inherit;color:inherit}.pmo-wo-card:hover,.pmo-order-card:hover,.pmo-child-card:hover{border-color:#93c5fd;box-shadow:0 8px 22px #0f172a12}.pmo-wo-card.is-active{border-color:var(--pmo-primary);background:linear-gradient(180deg,#fff,#f0f9ff);box-shadow:inset 4px 0 0 var(--pmo-primary),0 8px 22px #0f172a12}.pmo-row-between{display:flex;justify-content:space-between;align-items:center;gap:10px}.pmo-row-between b{font-size:var(--fs-15);font-weight:800;color:var(--pmo-text)}.pmo-row-between span{color:var(--pmo-muted);font-size:var(--fs-12);font-weight:700;white-space:nowrap}.pmo-main-text{margin-top:4px;color:#1f2937;font-size:var(--fs-14);font-weight:700}.pmo-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pmo-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.pmo-meta span{display:inline-flex;min-height:22px;align-items:center;border-radius:999px;padding:0 8px;background:#f1f5f9;color:var(--pmo-muted);font-size:var(--fs-11);font-weight:700}.pmo-qty-box,.pmo-selected-summary>div{margin-top:8px;background:#f8fafc;border:1px solid var(--pmo-border-soft);border-radius:10px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;gap:10px}.pmo-qty-box span,.pmo-selected-summary span,.pmo-add-row label span{color:#475569;font-size:var(--fs-12);font-weight:700}.pmo-qty-box b,.pmo-selected-summary b{color:var(--pmo-text);font-size:var(--fs-14);font-weight:800}.pmo-add-row{display:grid;grid-template-columns:minmax(110px,1fr) auto;gap:8px;align-items:end;margin-top:10px}.pmo-add-row label{display:grid;gap:4px}.pmo-selected-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:10px}.pmo-selected-summary>div{margin-top:0;display:grid;justify-content:stretch}.pmo-child-card{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.pmo-icon-danger{width:40px;height:40px;border-radius:999px;border:1.5px solid var(--pmo-red-border);background:var(--pmo-red-bg);color:var(--pmo-red);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s ease}.pmo-icon-danger:hover{background:#fecaca}.pmo-icon-danger:disabled{opacity:.5;cursor:not-allowed}.pmo-empty{padding:18px;color:var(--pmo-muted);text-align:center;font-size:var(--fs-14);font-weight:700;background:#f9fafb;border:1px dashed var(--pmo-border);border-radius:12px}@media(max-width:1280px){.pmo-layout{grid-template-columns:1fr 1fr;height:auto;overflow:visible}.pmo-page{overflow:auto}.pmo-children-panel{grid-column:1 / -1;min-height:360px}}@media(max-width:860px){.pmo-topbar{flex-direction:column}.pmo-actions{width:100%}.pmo-actions select,.pmo-actions .pmo-btn{flex:1 1 auto}.pmo-layout,.pmo-selected-summary{grid-template-columns:1fr}}.pmo-icon-delete{border:1.5px solid #fecaca;background:var(--red-light);color:var(--red)}.pmo-icon-delete:hover{background:#fecaca;border-color:#fca5a5;box-shadow:0 2px 4px #ef44441f}.pmo-icon-delete:active{background:#fca5a5;transform:scale(.98)}.pmo-icon-btn{width:40px;height:40px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000d}.pmo-list,.pmo-child-list{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:6px;padding:2px 8px 6px 0;overscroll-behavior:contain}.pmo-wo-card{position:relative;width:100%;min-height:auto;border:1px solid var(--pmo-border-soft);border-radius:12px;background:#fff;padding:9px 12px;text-align:left;cursor:pointer;font-family:inherit;color:inherit;box-shadow:0 3px 10px #0f172a0a;display:grid;gap:3px}.pmo-wo-card .pmo-row-between{align-items:flex-start}.pmo-wo-card .pmo-row-between b{font-size:var(--fs-15);line-height:1.2}.pmo-wo-card .pmo-row-between span{flex:0 0 auto;font-size:var(--fs-11);line-height:1.2;padding-top:2px}.pmo-wo-card .pmo-main-text{margin-top:0;font-size:var(--fs-14);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pmo-wo-card .pmo-muted{font-size:var(--fs-12);line-height:1.25}.pmo-wo-card .pmo-meta{margin-top:4px;gap:4px}.pmo-wo-card .pmo-meta span{min-height:18px;padding:0 7px;font-size:var(--fs-11)}.pmo-wo-card .pmo-qty-box{margin-top:5px;padding:6px 8px;border-radius:8px}.pmo-wo-card .pmo-qty-box span{font-size:var(--fs-11)}.pmo-wo-card .pmo-qty-box b{font-size:var(--fs-13);white-space:nowrap}.pmo-wo-card.is-active{border-color:var(--pmo-primary);background:linear-gradient(180deg,#fff,#f0f9ff);box-shadow:inset 3px 0 0 var(--pmo-primary),0 5px 14px #0f172a0f}.pmo-panel{padding:11px}.wst-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-light: #e0f2fe;--primary-lighter: #bae6fd;--green: #166534;--green-bg: #ecfdf5;--green-border: #86efac;--green-soft: #d1fae5;--red: #991b1b;--red-light: #fee2e2;--red-medium: #ef4444;--gray-50: #f9fafb;--gray-100: #f1f5f9;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--shadow: 0 8px 24px rgba(0,0,0,.06);--shadow-sm: 0 4px 12px rgba(0,0,0,.04);--radius: 16px;--radius-sm: 8px;background:var(--bg);color:var(--text);font-size:var(--fs-16);font-weight:400;font-family:var(--pps-font-main);height:100%;width:100%;padding:24px;display:grid;grid-template-columns:320px 1fr 620px;gap:20px;overflow:hidden}.wst-page *{box-sizing:border-box;font-family:inherit}.wst-col{min-width:0;min-height:0}.wst-left{display:contents}.wst-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.wst-title{font-size:var(--fs-16);font-weight:700;color:var(--text);margin-bottom:4px}.wst-sub{margin-top:4px;font-size:var(--fs-16);font-weight:400;line-height:1.5;color:var(--muted)}.wst-label{font-size:var(--fs-16);font-weight:700;color:var(--muted);margin:0 0 6px;text-transform:uppercase;letter-spacing:.5px}.wst-error{margin-top:12px;font-size:var(--fs-16);font-weight:400;color:var(--red);background:var(--red-light);border:1px solid #fecaca;padding:10px 14px;border-radius:var(--radius-sm)}.wst-form{margin-top:16px;display:grid;gap:12px}.wst-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.wst-select,.wst-input{width:100%;height:40px;border-radius:var(--radius-sm);border:1px solid var(--gray-400);background:#e8edf5;color:var(--text);padding:0 12px;font-size:var(--fs-16);font-weight:400;outline:none;transition:all .2s}.wst-select:focus,.wst-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0369a11a;background:var(--card)}.wst-input::placeholder{color:var(--gray-400);font-weight:400}.wst-actions{display:flex;gap:12px;align-items:center;margin-top:16px}.wst-btn-primary{flex:1;height:40px;border-radius:var(--radius-sm);border:none;background:var(--primary-light);color:var(--primary);font-weight:600;font-size:var(--fs-16);cursor:pointer;transition:all .2s}.wst-btn-primary:hover{background:var(--primary-lighter)}.wst-btn-primary:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.wst-btn-ghost{width:40px;height:40px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;font-size:var(--fs-16);font-weight:400;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000f;display:inline-flex;align-items:center;justify-content:center}.wst-btn-ghost:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 2px 4px #00000014}.wst-btn-ghost:active{background:#f3f4f6;box-shadow:0 1px 2px #0000000d}.wst-col-search{min-width:0;min-height:0;overflow:hidden}.wst-wo-list{margin-top:10px;display:flex;flex-direction:column;gap:10px;padding-right:6px;flex:1;min-height:0;max-height:none;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.wst-wo-list::-webkit-scrollbar{width:8px}.wst-wo-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.wst-wo-list::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.wst-wo-item{text-align:left;width:100%;border-radius:14px;border:1px solid var(--gray-200);background:var(--card);padding:12px;cursor:pointer;box-shadow:var(--shadow-sm);transition:background .2s,box-shadow .2s,border-color .2s;min-width:0}.wst-wo-item:hover{background:var(--gray-50);box-shadow:var(--shadow)}.wst-wo-item:disabled{opacity:.65;cursor:not-allowed}.wst-wo-item.active{border-color:#7dd3fc;box-shadow:0 0 0 3px #38bdf82e;background:#f0f9ff}.wst-wo-top{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}.wst-wo-code2{font-size:var(--fs-16);font-weight:700;color:var(--text);min-width:0}.wst-wo-pill{font-size:var(--fs-12);font-weight:700;padding:4px 10px;border-radius:999px;background:var(--gray-100);border:1px solid var(--gray-200);color:var(--text);white-space:nowrap}.wst-wo-sub2{margin-top:6px;font-size:var(--fs-14);font-weight:600;color:var(--gray-700);line-height:1.35;overflow-wrap:anywhere}.wst-wo-meta{margin-top:8px;font-size:var(--fs-13);font-weight:600;color:var(--gray-600);display:flex;align-items:center;gap:8px;min-width:0}.wst-dot{color:var(--gray-400)}.wst-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.wst-wo-empty{padding:14px;text-align:center;color:var(--muted);font-weight:600;border:1px dashed var(--border);border-radius:12px;background:var(--gray-50)}.wst-col-summary{display:flex;flex-direction:column;gap:16px;overflow:auto;padding-right:4px;min-height:0;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.wst-col-summary::-webkit-scrollbar{width:8px}.wst-col-summary::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.wst-col-summary::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.wst-summary{background:#fef3c7;border:1px solid #fcd34d}.wst-summary-right{margin-top:12px;display:flex;justify-content:flex-end;align-items:baseline;gap:8px}.wst-total{font-size:var(--fs-16);font-weight:700;color:#92400e}.wst-unit{font-size:var(--fs-16);font-weight:400;color:#92400e}.wst-chip-wrap{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.wst-chip{height:36px;min-width:100px;padding:0 16px;border-radius:999px;border:1px solid var(--border);background:var(--card);font-size:var(--fs-16);font-weight:700;color:var(--gray-700);cursor:pointer;transition:all .2s}.wst-chip:hover{background:var(--gray-50)}.wst-chip.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.wst-wo-code{font-size:var(--fs-16);font-weight:700;margin-bottom:12px;color:var(--text)}.wst-wo-grid{display:grid;gap:8px}.wst-wo-row{display:flex;justify-content:space-between;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);background:var(--gray-50);border:1px solid var(--gray-200);width:280px}.wst-wo-row .k{font-size:var(--fs-16);font-weight:400;color:var(--gray-500)}.wst-wo-row .v{font-size:var(--fs-16);font-weight:700;color:var(--text);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wst-col-defects{min-height:0}.wst-right{height:100%;display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow);background:var(--card)}.wst-right-header{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--card)}.wst-right-body{flex:1;padding:16px;overflow-y:auto;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--border) transparent}.wst-right-body::-webkit-scrollbar{width:8px}.wst-right-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.wst-right-body::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.wst-empty{color:var(--muted);font-weight:400;padding:16px;background:var(--gray-50);border:1px dashed var(--border);border-radius:var(--radius-sm);text-align:center}.wst-defect-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--gray-200);padding:16px;display:grid;grid-template-columns:1.35fr 180px 250px;gap:16px;margin-bottom:12px;align-items:center;box-shadow:var(--shadow-sm);transition:box-shadow .2s}.wst-defect-card:hover{box-shadow:var(--shadow)}.wst-defect-name{font-size:var(--fs-16);font-weight:700;color:var(--text)}.wst-defect-code{font-size:var(--fs-16);color:var(--muted);margin-top:4px;font-weight:400;font-family:var(--pps-font-mono)}.wst-defect-mid{display:grid;grid-template-columns:40px 1fr 40px;gap:8px;align-items:center}.wst-btn-circle{width:40px;height:40px;border-radius:999px;border:1.5px solid #e5e7eb;background:#fff;font-size:var(--fs-16);font-weight:400;cursor:pointer;color:#6b7280;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;box-shadow:0 1px 3px #0000000d}.wst-btn-circle:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 2px 4px #00000014}.wst-btn-circle:active{background:#f3f4f6;box-shadow:0 1px 2px #0000000d;transform:scale(.98)}.wst-btn-plus{background:#ecfdf5;border-color:#86efac;color:#16a34a}.wst-btn-plus:hover{background:#d1fae5;border-color:#4ade80;box-shadow:0 2px 4px #22c55e26}.wst-btn-plus:active{background:#bbf7d0;transform:scale(.98)}.wst-counter{height:40px;border-radius:var(--radius-sm);border:1px solid var(--gray-200);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--fs-16);background:var(--card)}.wst-defect-right{display:grid;grid-template-columns:1fr 96px 88px;gap:8px;align-items:center}.wst-bulk-label{font-size:var(--fs-16);color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.wst-small-input{width:100%;height:40px;border-radius:var(--radius-sm);border:1px solid var(--gray-400);background:#e8edf5;color:var(--text);padding:0 12px;font-size:var(--fs-16);font-weight:400;outline:none;text-align:center;transition:all .2s}.wst-small-input:focus{border-color:var(--primary);background:var(--card);box-shadow:0 0 0 3px #0369a11a}.wst-add-btn{height:40px;border-radius:var(--radius-sm);border:none;background:var(--primary-light);color:var(--primary);font-weight:600;font-size:var(--fs-16);cursor:pointer;transition:all .2s}.wst-add-btn:hover{background:var(--primary-lighter)}.wst-footer{padding:16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;background:var(--card)}.wst-send{width:100%;max-width:240px;height:40px;border-radius:var(--radius-sm);border:none;background:var(--primary);color:var(--card);font-weight:600;font-size:var(--fs-16);cursor:pointer;transition:all .2s}.wst-send:hover{background:var(--primary-hover)}.wst-send:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}@media(max-width:1300px){.wst-page{grid-template-columns:1fr;padding:16px;overflow:auto}.wst-col-summary{overflow:visible;padding-right:0}.wst-right{height:auto;min-height:520px}}@media(max-width:1150px){.wst-row2{grid-template-columns:1fr}.wst-defect-card{grid-template-columns:1fr;gap:12px}.wst-defect-right{grid-template-columns:1fr 110px 110px}}.wst-page{height:100dvh;min-height:100vh;overflow:hidden}.wst-col,.wst-col-search,.wst-col-summary,.wst-col-defects{min-height:0;min-width:0}.wst-col-search{overflow:hidden}.wst-col-search .wst-card{height:100%;min-height:0;display:flex;flex-direction:column;overflow:hidden}.wst-col-search .wst-form{flex:1;min-height:0;display:flex;flex-direction:column;gap:12px;overflow:hidden}.wst-wo-section{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.wst-wo-list{flex:1;min-height:0;max-height:none;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.wst-wo-item.bad0{border-color:#fecaca;background:#fef2f2}.wst-wo-item.bad0:hover{background:#fee2e2;border-color:#fca5a5}.wst-wo-item.active.bad0{border-color:#fb7185;box-shadow:0 0 0 3px #f43f5e2e;background:#fff1f2}.wst-page{color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.wst-page,.wst-page *{color:inherit}.wst-page{color:var(--text)}.wst-page input,.wst-page select,.wst-page textarea,.wst-page .wst-input,.wst-page .wst-select,.wst-page .wst-small-input{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;text-shadow:none!important;background-color:#e8edf5!important;background-clip:padding-box;-webkit-appearance:none;appearance:none}.wst-page .wst-input:focus,.wst-page .wst-select:focus,.wst-page .wst-small-input:focus{background:var(--card)!important}.wst-page input::placeholder,.wst-page textarea::placeholder{color:var(--gray-400)!important;-webkit-text-fill-color:var(--gray-400)!important}.wst-page input::-webkit-input-placeholder,.wst-page textarea::-webkit-input-placeholder{color:var(--gray-400)!important;-webkit-text-fill-color:var(--gray-400)!important}.wst-page select option{color:#111827!important;background:#fff!important}.wst-page input:-webkit-autofill,.wst-page textarea:-webkit-autofill,.wst-page select:-webkit-autofill{-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}.wst-page svg{display:inline-block;vertical-align:middle;overflow:visible}.wst-page button,.wst-page .wst-btn-primary,.wst-page .wst-btn-ghost,.wst-page .wst-btn-circle,.wst-page .wst-add-btn,.wst-page .wst-send{-webkit-text-fill-color:currentColor!important}.wst-page button svg,.wst-page .wst-btn-primary svg,.wst-page .wst-btn-ghost svg,.wst-page .wst-btn-circle svg{color:currentColor!important;opacity:1!important;visibility:visible!important;pointer-events:none}.wst-page .wst-send{color:#fff!important;-webkit-text-fill-color:#ffffff!important}.wst-page .wst-sub,.wst-page .wst-label,.wst-page .wst-wo-sub2,.wst-page .wst-wo-meta,.wst-page .wst-empty,.wst-page .wst-wo-empty{color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important}@media(forced-colors:active){.wst-page{forced-color-adjust:auto}.wst-page .wst-card,.wst-page .wst-right{border:1px solid ButtonText!important;background:Canvas!important;color:CanvasText!important}.wst-page input,.wst-page select,.wst-page textarea{border:1px solid ButtonText!important;background:Field!important;color:FieldText!important;-webkit-text-fill-color:FieldText!important}.wst-page button{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}}.wst2-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--soft2: #bae6fd;--danger: #b91c1c;--shadow: 0 10px 26px rgba(0,0,0,.06);--radius: 16px;min-height:100vh;background:var(--bg);color:var(--text);padding:12px 14px;font-family:var(--pps-font-main);overflow:hidden}.wst2-gridCard{height:calc(100vh - 24px);background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}.wst2-toolbar{flex:0 0 auto;padding:14px;border-bottom:1px solid var(--border);display:flex;align-items:flex-end;justify-content:space-between;gap:12px;background:#fff}.wst2-title{font-size:var(--fs-16);font-weight:1000;letter-spacing:.2px}.wst2-sub{margin-top:4px;font-size:var(--fs-12);color:var(--muted)}.wst2-subErr{color:var(--danger);font-weight:800}.wst2-toolbarRight{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.wst2-pill{font-size:var(--fs-12);color:var(--muted);border:1px solid var(--border);background:#f8fafc;padding:6px 10px;border-radius:999px;white-space:nowrap}.wst2-filter{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border);background:#f8fafc;border-radius:999px}.wst2-filter.required{border-color:#93c5fd;background:#eff6ff}.wst2-filterLabel{font-size:var(--fs-12);color:var(--muted);font-weight:800;white-space:nowrap}.wst2-filterSelect{height:28px;border-radius:999px;border:1px solid #cbd5e1;background:#fff;padding:0 10px;font-weight:800;outline:none}.wst2-filterInput{height:28px;width:210px;border-radius:999px;border:1px solid #cbd5e1;background:#fff;padding:0 12px;font-weight:800;outline:none}@media(max-width:1100px){.wst2-filterInput{width:160px}}.wst2-btn{height:36px;border-radius:12px;border:1px solid var(--border);background:#fff;padding:0 12px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.wst2-btn:disabled{opacity:.55;cursor:not-allowed}.wst2-btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.wst2-btn.primary:hover{background:var(--primary2);border-color:var(--primary2)}.wst2-btn.soft{background:var(--soft);border-color:var(--soft2);color:#075985}.wst2-btn.ghost{background:#fff}.wst2-gridWrap{flex:1 1 auto;min-height:0;overflow:auto;position:relative}.wst2-table{border-collapse:separate;border-spacing:0;width:max-content;min-width:100%;font-size:var(--fs-13)}.wst2-table thead th{position:sticky;top:0;z-index:3;background:#f8fafc;border-bottom:1px solid var(--border);padding:10px;text-align:left;white-space:nowrap}.wst2-table .cell{border-bottom:1px solid #f1f5f9;padding:10px;white-space:nowrap;vertical-align:middle}.wst2-table tr:hover td{background:#fbfdff}.wst2-woStart td{border-top:2px solid #e2e8f0}.wst2-th-code{font-weight:1000;line-height:1.1;white-space:nowrap}.wst2-th-text{margin-top:3px;font-size:var(--fs-11);color:var(--muted);font-weight:800;line-height:1.15;max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wst2-woMain{font-size:var(--fs-14);font-weight:1000;line-height:1.15}.wst2-woSub{margin-top:4px;font-size:var(--fs-12);color:var(--muted);font-weight:900;line-height:1.1}.strong{font-weight:1000}.muted{color:var(--muted)}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:380px}.num{width:86px;height:34px;border-radius:12px;border:1px solid #cbd5e1;background:#f1f5f9;padding:0 10px;outline:none;font-weight:1000;color:var(--text)}.num:focus{border-color:var(--soft2);box-shadow:0 0 0 3px #0284c726;background:#fff}.num.changed{border:2px solid #38bdf8;background:var(--soft)}.wst2-empty{padding:14px;color:var(--muted)}.wst2-emptyWarn{border:1px dashed #93c5fd;background:#eff6ff;color:#0f172a;border-radius:12px;margin:12px}.wst2-loading{position:sticky;left:0;top:0;padding:14px;display:flex;align-items:center;gap:12px;color:var(--muted)}.wst2-loading .t{font-weight:1000;color:var(--text)}.wst2-loading .s{font-size:var(--fs-12)}.spin{width:18px;height:18px;border-radius:999px;border:2px solid #cbd5e1;border-top-color:var(--primary2);animation:wst2spin .85s linear infinite}@keyframes wst2spin{to{transform:rotate(360deg)}}.wst2-btn.danger{background:#b91c1c;color:#fff;border:1px solid #991b1b}.wst2-btn.danger:hover{filter:brightness(.98)}.wst2-btn.danger:disabled{opacity:.55;cursor:not-allowed}.wst2-bad{display:inline-flex;align-items:center;justify-content:center;min-width:42px;padding:2px 10px;border-radius:999px;font-weight:800;font-size:var(--fs-12);border:1px solid var(--border);background:#fff}.wst2-bad.ok{background:#ecfdf5;border-color:#86efac;color:#166534}.wst2-bad.bad{background:#fef2f2;border-color:#fecaca;color:#991b1b}.wst2-woTop{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.wst2-woActions{flex:0 0 auto;display:flex;gap:8px}.wst2-woBtnClose{display:inline-flex;align-items:center;justify-content:center;height:28px;padding:0 10px;border-radius:10px;border:1px solid #991b1b;background:#b91c1c;color:#fff;font-weight:800;font-size:var(--fs-12);cursor:pointer}.wst2-woBtnClose:hover{filter:brightness(.98)}.wst2-woBtnClose:disabled{opacity:.55;cursor:not-allowed}.wst2-woMeta{margin-top:6px;display:flex;flex-direction:column;gap:2px}.wst2-woLine{margin-top:4px}.wst2-page{color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;color:var(--text)}.wst2-page input,.wst2-page select,.wst2-page textarea,.wst2-page .wst2-filterSelect,.wst2-page .wst2-filterInput,.wst2-page .num{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;text-shadow:none!important;background-clip:padding-box;-webkit-appearance:none;appearance:none}.wst2-page .wst2-filterSelect,.wst2-page .wst2-filterInput{background:#fff!important}.wst2-page .num{background:#f1f5f9!important}.wst2-page .num:focus{background:#fff!important}.wst2-page input::placeholder,.wst2-page textarea::placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.wst2-page input::-webkit-input-placeholder,.wst2-page textarea::-webkit-input-placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.wst2-page select option{color:#0f172a!important;background:#fff!important}.wst2-page input:-webkit-autofill,.wst2-page textarea:-webkit-autofill,.wst2-page select:-webkit-autofill{-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}.wst2-page .wst2-btn{-webkit-text-fill-color:currentColor!important}.wst2-page .wst2-btn.primary,.wst2-page .wst2-btn.danger{color:#fff!important;-webkit-text-fill-color:#ffffff!important}.wst2-page svg{display:inline-block;vertical-align:middle;overflow:visible}.wst2-page button svg,.wst2-page .wst2-toolbar svg,.wst2-page .wst2-search svg{color:currentColor!important;stroke:currentColor!important;fill:none!important;opacity:1!important;visibility:visible!important}.wst2-page .wst2-sub,.wst2-page .wst2-filterLabel,.wst2-page .wst2-pill,.wst2-page .wst2-th-text,.wst2-page .wst2-woSub,.wst2-page .wst2-loading,.wst2-page .wst2-loading .s,.wst2-page .wst2-empty,.wst2-page .muted{color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important}@media(forced-colors:active){.wst2-page{forced-color-adjust:auto}.wst2-page .wst2-gridCard{border:1px solid ButtonText!important;background:Canvas!important;color:CanvasText!important}.wst2-page input,.wst2-page select,.wst2-page textarea{border:1px solid ButtonText!important;background:Field!important;color:FieldText!important;-webkit-text-fill-color:FieldText!important}.wst2-page button{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}}.qm-page{width:100%;height:100%;background:#f8fafc;padding:16px 24px;overflow:hidden;color:#111827;font-size:var(--fs-16);font-weight:400}.qm-page h2{margin:0 0 12px;font-size:var(--fs-16);font-weight:700;color:#111827}.qm-panel{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;display:flex;flex-direction:column;height:calc(100% - 52px);box-shadow:0 10px 26px #0000000f}.qm-summary{position:sticky;top:0;z-index:4;display:flex;gap:12px;margin-bottom:12px;padding:8px 12px;background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 4px 12px #0000000f}.qm-summary-item{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;font-size:var(--fs-16);font-weight:700}.qm-summary-item.pending{background:#fff7ed;color:#9a3412}.qm-summary-item.msg{background:#fee2e2;color:#991b1b}.qm-summary-num{display:inline-block;min-width:24px;text-align:right}.qm-search-group{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;margin-bottom:12px}.qm-search-input{position:relative;width:100%}.qm-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:var(--fs-16);color:#0f172a;opacity:.55}.qm-search-group input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;font-size:var(--fs-16);font-weight:400;background:#e8edf5;color:#111827}.qm-search-group input::placeholder{color:#94a3b8;font-weight:400}.qm-search-group input:focus{outline:none;background:#fff;border-color:#7dd3fc;box-shadow:0 0 0 2px #7dd3fc73}.qm-btn-refresh{display:inline-flex;align-items:center;justify-content:center;height:40px;padding:0 14px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;color:#111827;font-weight:700;font-size:var(--fs-16);cursor:pointer;white-space:nowrap;box-shadow:0 1px #0f172a0a}.qm-btn-refresh:hover{background:#e0f2fe;border-color:#7dd3fc}.qm-table-wrapper{flex:1;overflow:auto;border-radius:12px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.qm-table-wrapper::-webkit-scrollbar{width:8px;height:8px}.qm-table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.qm-table-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8}.qm-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.qm-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-16);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.qm-table td{padding:10px;font-size:var(--fs-16);font-weight:400;white-space:nowrap;border-bottom:1px solid #f1f5f9;color:#111827}.qm-table tr:hover{background:#f8fafc}.qm-col-no{width:60px}.qm-col-dt{width:220px}.qm-col-wo{width:160px}.qm-col-ref{width:220px}.qm-col-device{width:160px}.qm-col-ot,.qm-col-fegrp{width:140px}.qm-col-fenum{width:120px}.qm-col-fecod{width:140px}.qm-col-fetxt{width:360px}.qm-col-qty{width:140px;text-align:left}.qm-col-status{width:140px}.qm-col-msg{width:360px}.qm-badge{display:inline-block;min-width:84px;padding:4px 10px;border-radius:999px;font-size:var(--fs-16);font-weight:700;text-align:center}.qm-badge-pending{background:#fff7ed;color:#9a3412}.qm-mono{font-family:var(--pps-font-mono)}.qm-msg{overflow:hidden;text-overflow:ellipsis}.qm-info{padding:12px;text-align:center;color:#6b7280;font-weight:400;font-size:var(--fs-16)}@media(max-width:1024px){.qm-col-fetxt,.qm-col-msg{width:320px}}@media(max-width:768px){.qm-page{padding:12px}.qm-search-group{grid-template-columns:1fr}.qm-btn-refresh{justify-self:flex-end}}.Good-loading{padding:40px;font-size:var(--fs-16);color:#57606f}.Good-container{padding:24px 32px;background:#f5f6fa;min-height:100vh}.Good-header{margin-bottom:24px}.Good-header h1{margin:0;font-size:var(--fs-28);font-weight:700;color:#2f3542}.Good-subtitle{font-size:var(--fs-14);color:#747d8c}.Good-maintenance{display:flex;justify-content:center;align-items:center;height:calc(100vh - 180px)}.Good-maintenance-card{background:#fff;padding:48px 64px;border-radius:12px;text-align:center;box-shadow:0 8px 24px #00000014}.Good-maintenance-card h2{margin-bottom:12px;font-size:var(--fs-24);color:#e84118}.Good-maintenance-card p{font-size:var(--fs-15);color:#57606f;line-height:1.6}.wq-page{padding:12px;height:100%;background:#f8fafc;color:#111827}.wq-header{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.wq-title{font-size:var(--fs-16);font-weight:600;line-height:1.2}.wq-sub{margin-top:4px;font-size:var(--fs-12);color:#6b7280;font-weight:400}.wq-actions{display:flex;flex-direction:column;gap:10px}.wq-scope{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.wq-badge{font-size:var(--fs-12);font-weight:600;padding:6px 10px;border-radius:999px;background:#fff;border:1px solid #e5e7eb}.wq-pill{font-size:var(--fs-12);font-weight:600;padding:6px 10px;border-radius:999px;border:1px solid #e5e7eb;background:#f1f5f9;color:#0f172a}.wq-pill.strong{border-color:#bbf7d0;background:#dcfce7;color:#166534}.wq-filter-row{display:grid;grid-template-columns:1fr;gap:8px}@media(min-width:920px){.wq-filter-row{grid-template-columns:180px 180px 1fr 120px;align-items:center}}.wq-select{width:100%;height:42px;border-radius:12px;border:1px solid #9ca3af;background:#e8edf5;padding:0 10px;font-size:var(--fs-14);font-weight:600;outline:none}.wq-select:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf826}.wq-search{position:relative}.wq-search input{width:100%;height:42px;border-radius:12px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px 0 36px;font-size:var(--fs-14);font-weight:600}.wq-search input:focus{outline:none;background:#fff;border-color:#38bdf8}.wq-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#6b7280}.wq-grid{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:980px){.wq-grid{grid-template-columns:380px 1fr;align-items:start}}.wq-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px;box-shadow:0 6px 16px #0000000d;min-width:0}.wq-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.wq-card-title{font-size:var(--fs-14);font-weight:600}.wq-card-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.wq-muted{font-size:var(--fs-12);font-weight:600;color:#6b7280}.wq-btn,.wq-btn-primary{height:40px;padding:0 12px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-13)}.wq-btn:hover{background:#f8fafc}.wq-btn:disabled,.wq-btn-primary:disabled{opacity:.6;cursor:not-allowed}.wq-btn-primary{border:1px solid #bae6fd;background:#e0f2fe}.wq-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.wq-field label{display:block;font-size:var(--fs-12);font-weight:600;margin-bottom:6px;color:#111827}.wq-list{margin-top:10px;max-height:460px;overflow:auto;display:flex;flex-direction:column;gap:8px;padding-right:6px}.wq-wo-item{text-align:left;width:100%;border-radius:14px;border:1px solid #e5e7eb;background:#fff;padding:10px;cursor:pointer;box-shadow:0 1px #0f172a0a}.wq-wo-item:hover{background:#f8fafc}.wq-wo-item.active{border-color:#7dd3fc;box-shadow:0 0 0 3px #38bdf82e}.wq-wo-top{display:flex;justify-content:space-between;align-items:center;gap:10px}.wq-wo-code{font-weight:600;font-size:var(--fs-13)}.wq-wo-pill{font-size:var(--fs-11);font-weight:600;padding:4px 8px;border-radius:999px;background:#f1f5f9;border:1px solid #e5e7eb}.wq-wo-sub{margin-top:6px;font-size:var(--fs-12);color:#475569;font-weight:400}.wq-summary{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:10px}.wq-kv{border:1px solid #eef2f7;background:#f8fafc;border-radius:12px;padding:10px}.wq-k{font-size:var(--fs-11);font-weight:600;color:#64748b}.wq-v{margin-top:4px;font-size:var(--fs-13);font-weight:600;color:#0f172a;line-height:1.25}.wq-hint{margin-left:8px;font-size:var(--fs-11);font-weight:600;color:#64748b}.wq-section{margin-top:12px}.wq-section-title{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:var(--fs-13);font-weight:600;margin-bottom:8px}.wq-count{font-size:var(--fs-11);font-weight:600;color:#64748b;border:1px solid #e5e7eb;background:#f8fafc;padding:4px 8px;border-radius:999px}.wq-table-wrap{overflow:auto;border:1px solid #e5e7eb;border-radius:12px}.wq-table{width:100%;border-collapse:separate;border-spacing:0;min-width:720px}.wq-table th,.wq-table td{padding:10px;border-bottom:1px solid #eef2f7;font-size:var(--fs-12);vertical-align:top}.wq-table th{position:sticky;top:0;background:#f8fafc;z-index:1;text-align:left;font-weight:600;color:#0f172a}.wq-table tr:last-child td{border-bottom:0}.right{text-align:right}.wq-fetxt{white-space:nowrap}.wq-empty,.wq-loading{padding:12px;text-align:center;font-size:var(--fs-13);font-weight:600;color:#6b7280}.wq-empty-td{padding:14px;text-align:center;color:#6b7280;font-weight:600}.wq-note{margin-top:8px;font-size:var(--fs-12);font-weight:600;color:#64748b}.wq-modal-backdrop{position:fixed;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;padding:16px;z-index:60}.wq-modal{width:100%;max-width:860px;background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 18px 55px #00000040;overflow:hidden}.wq-modal-head{padding:12px 14px;border-bottom:1px solid #eef2f7;display:flex;align-items:center;justify-content:space-between;background:#f8fafc}.wq-modal-title{font-size:var(--fs-14);font-weight:600;color:#111827;display:inline-flex;align-items:center;gap:8px}.wq-x{border:0;background:transparent;font-size:var(--fs-18);cursor:pointer;color:#334155}.wq-modal-body{max-height:65vh;overflow:auto;padding:12px}.wq-pre{margin:0;font-size:var(--fs-12);font-weight:600;color:#0f172a;background:#0b1220;color:#e5e7eb;padding:12px;border-radius:12px;overflow:auto}.wq-modal-actions{padding:12px 14px;border-top:1px solid #eef2f7;display:flex;justify-content:flex-end;gap:10px}.wq-page{font-size:var(--fs-16);line-height:1.45;color:#0f172a}.wq-title{font-size:var(--fs-20);font-weight:600;letter-spacing:.2px;color:#0f172a}.wq-sub{font-size:var(--fs-16);font-weight:600;color:#475569;margin-top:6px}.wq-badge{font-size:var(--fs-14);font-weight:600;color:#0f172a;border-color:#cbd5e1}.wq-pill{font-size:var(--fs-14);font-weight:600;color:#0f172a;background:#f1f5f9;border-color:#cbd5e1}.wq-pill.strong{font-size:var(--fs-14);font-weight:600;border-color:#86efac;background:#ecfdf5;color:#166534}.wq-select{height:44px;font-size:var(--fs-16);font-weight:400;color:#0f172a;border-color:#94a3b8}.wq-search input{height:44px;font-size:var(--fs-16);font-weight:600;color:#0f172a;border-color:#94a3b8}.wq-search input::placeholder{color:#64748b;font-weight:600}.wq-btn,.wq-btn-primary{height:44px;font-size:var(--fs-14);font-weight:600;color:#0f172a}.wq-btn-primary{font-weight:600}.wq-card-title{font-size:var(--fs-16);font-weight:600;color:#0f172a}.wq-muted{font-size:var(--fs-14);font-weight:400;color:#475569}.wq-wo-code{font-size:var(--fs-15);font-weight:600;color:#0f172a}.wq-wo-sub{font-size:var(--fs-14);font-weight:600;color:#334155}.wq-wo-pill{font-size:var(--fs-12);font-weight:600;color:#0f172a;border-color:#cbd5e1}.wq-k{font-size:var(--fs-14);font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.3px}.wq-v{font-size:var(--fs-16);font-weight:600;color:#0f172a}.wq-hint{font-size:var(--fs-14);font-weight:600;color:#475569}.wq-section-title{font-size:var(--fs-16);font-weight:600;color:#0f172a}.wq-count{font-size:var(--fs-13);font-weight:600;color:#334155;border-color:#cbd5e1}.wq-table th{font-size:var(--fs-14);font-weight:600;color:#0f172a;border-bottom:1px solid #e2e8f0}.wq-table td{font-size:var(--fs-14);font-weight:600;color:#0f172a}.wq-note{font-size:var(--fs-14);font-weight:400;color:#475569}.wq-empty,.wq-loading{font-size:var(--fs-16);font-weight:400;color:#475569}.wq-modal-title{font-size:var(--fs-16);font-weight:600;color:#0f172a}.wq-pre{font-size:var(--fs-13);font-weight:400}.wq-page{color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.wq-page,.wq-page *{color:inherit}.wq-page{color:#0f172a}.wq-page input,.wq-page select,.wq-page textarea,.wq-page .wq-select,.wq-page .wq-search input{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;caret-color:#0f172a!important;background-color:#fff!important;background-clip:padding-box;text-shadow:none!important;-webkit-appearance:none;appearance:none}.wq-page .wq-select:not(:focus),.wq-page .wq-search input:not(:focus){background:#e8edf5!important}.wq-page input::placeholder,.wq-page textarea::placeholder{color:#64748b!important;-webkit-text-fill-color:#64748b!important}.wq-page input::-webkit-input-placeholder,.wq-page textarea::-webkit-input-placeholder{color:#64748b!important;-webkit-text-fill-color:#64748b!important}.wq-page select option{color:#0f172a!important;background:#fff!important}.wq-page input:-webkit-autofill,.wq-page textarea:-webkit-autofill,.wq-page select:-webkit-autofill{-webkit-text-fill-color:#0f172a!important;caret-color:#0f172a!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}.wq-page svg{display:inline-block;vertical-align:middle;overflow:visible}.wq-page button svg,.wq-page .wq-btn svg,.wq-page .wq-btn-primary svg{color:currentColor!important;opacity:1!important;visibility:visible!important}.wq-page .wq-sub,.wq-page .wq-muted,.wq-page .wq-search-icon,.wq-page .wq-k,.wq-page .wq-hint,.wq-page .wq-count,.wq-page .wq-note,.wq-page .wq-empty,.wq-page .wq-loading,.wq-page .wq-empty-td{color:#475569!important;-webkit-text-fill-color:#475569!important}.wq-page .wq-pill.strong{color:#166534!important;-webkit-text-fill-color:#166534!important}@media(forced-colors:active){.wq-page{forced-color-adjust:auto}.wq-page .wq-card,.wq-page .wq-modal,.wq-page .wq-table-wrap{border:1px solid ButtonText!important;background:Canvas!important;color:CanvasText!important}.wq-page input,.wq-page select,.wq-page textarea,.wq-page button{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}}.mwe-page{padding:16px 18px;height:100%;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px;min-height:0}.mwe-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:12px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.mwe-h1{font-size:var(--fs-18);font-weight:800}.mwe-sub{margin-top:2px;font-size:var(--fs-12);color:#64748b}.mwe-actions{display:flex;gap:8px}.mwe-filters{display:flex;gap:10px;padding:12px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;flex-wrap:wrap}.mwe-field{display:flex;flex-direction:column;gap:6px;min-width:180px}.mwe-field-grow{flex:1;min-width:260px}.mwe-field label{font-size:var(--fs-12);color:#475569;font-weight:700}.mwe-field input,.mwe-field select,.mwe-field textarea{border:1px solid #e2e8f0;background:#fff;border-radius:12px;padding:10px;outline:none;font-size:var(--fs-13);color:#0f172a}.mwe-field input:focus,.mwe-field select:focus,.mwe-field textarea:focus{border-color:#0284c7;box-shadow:0 0 0 3px #0284c71f}.mwe-field textarea{min-height:76px;resize:vertical}.mwe-search{display:flex;gap:8px;align-items:center}.mwe-btn{border:1px solid #e2e8f0;background:#fff;color:#0f172a;border-radius:12px;padding:10px 12px;font-size:var(--fs-13);font-weight:800;cursor:pointer;white-space:nowrap}.mwe-btn:hover{background:#f1f5f9}.mwe-btn:disabled{opacity:.55;cursor:not-allowed}.mwe-btn.primary{border-color:#0284c7;background:#0284c7;color:#fff}.mwe-btn.primary:hover{filter:brightness(.98)}.mwe-error{padding:10px 12px;border-radius:14px;border:1px solid #fecaca;background:#fff1f2;color:#991b1b;font-weight:700;font-size:var(--fs-13)}.mwe-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.mwe-card-hd{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid #eef2f7}.mwe-card-title{font-weight:900;font-size:var(--fs-13)}.mwe-chip{font-size:var(--fs-12);font-weight:900;color:#0f172a;background:#f1f5f9;border:1px solid #e2e8f0;padding:6px 10px;border-radius:999px}.mwe-chip.is-muted{color:#64748b}.mwe-divider{height:1px;background:#eef2f7}.mwe-grid3{display:grid;grid-template-columns:.4fr .4fr 1.5fr;gap:12px;min-height:0;flex:1;align-items:stretch}@media(max-width:1200px){.mwe-grid3{grid-template-columns:1fr}}.mwe-list{padding:10px;overflow:auto;min-height:0}.mwe-list-tall{max-height:calc(100vh - 260px);overflow:auto}.mwe-row{width:100%;text-align:left;display:flex;justify-content:space-between;gap:10px;padding:12px;border-radius:14px;border:1px solid #eef2f7;background:#fff;cursor:pointer;margin-bottom:10px}.mwe-row:hover{background:#f8fafc}.mwe-row.is-active{border-color:#0284c7;box-shadow:0 8px 18px #0284c726}.mwe-row-title{font-weight:900;font-size:var(--fs-13)}.mwe-row-sub{font-size:var(--fs-12);color:#64748b;margin-top:2px}.mwe-row-meta{display:flex;gap:6px;align-items:flex-start}.mwe-badge{font-size:var(--fs-11);font-weight:900;color:#0f172a;background:#f1f5f9;border:1px solid #e2e8f0;padding:5px 8px;border-radius:999px}.mwe-form{padding:12px 14px;display:flex;flex-direction:column;gap:12px}.mwe-form-grid{display:flex;gap:10px;flex-wrap:wrap}.mwe-note{margin-top:6px;color:#64748b;font-size:var(--fs-12);font-weight:700}.mwe-defect-toolbar{padding:10px 12px 0;display:flex;flex-direction:column;gap:10px}.mwe-input{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:12px;outline:none;background:#fff;font-size:var(--fs-13)}.mwe-input:focus{border-color:#0284c7;box-shadow:0 0 0 3px #0284c71f}.mwe-defect-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.mwe-defects{max-height:calc(100vh - 360px);overflow:auto;padding:0 10px 10px;min-height:0}.mwe-qtycell{width:90px;padding:8px 10px;border:1px solid #e2e8f0;border-radius:10px;outline:none;font-size:var(--fs-13)}.mwe-qtycell:focus{border-color:#0284c7;box-shadow:0 0 0 3px #0284c71f}.mwe-defect-footer{padding:10px 12px;border-top:1px solid #eef2f7;background:#fff}.mwe-muted{color:#64748b;font-size:var(--fs-12);font-weight:800}.mwe-history-bottom{margin-top:12px}.mwe-history-wide{max-height:320px;overflow:auto;padding:10px 12px 14px}.mwe-table{width:100%;border-collapse:collapse;font-size:var(--fs-12)}.mwe-table th{text-align:left;padding:10px 8px;border-bottom:1px solid #eef2f7;color:#475569;font-weight:900;position:sticky;top:0;background:#fff;z-index:1}.mwe-table td{padding:10px 8px;border-bottom:1px solid #f1f5f9;vertical-align:top}.mwe-table td.num{text-align:right;font-weight:900}.mwe-table td.text{max-width:520px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mwe-pill{font-size:var(--fs-11);font-weight:900;padding:5px 8px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;color:#0f172a}.mwe-pill.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.mwe-pill.wait{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.mwe-empty{padding:18px 14px;color:#64748b;font-weight:800}.mwe-page{height:100vh;overflow:auto;min-height:0}.mwe-grid3{flex:0 0 auto;min-height:calc(100vh - 190px);align-items:stretch}.mwe-list-tall{max-height:520px;overflow:auto}.mwe-defects{max-height:none!important;overflow:visible!important;padding:0 10px 10px}.mwe-card{overflow:visible}.mwe-card .mwe-list,.mwe-card .mwe-history-wide{overflow:auto}.mwe-history-wide{max-height:none!important;overflow:visible!important}.mwe-hgroups{display:flex;flex-direction:column;gap:10px}.mwe-hgroup{border:1px solid #e5e7eb;border-radius:12px;background:#fff;overflow:hidden}.mwe-hgroup-hd{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;background:#f8fafc;border:0;cursor:pointer;text-align:left}.mwe-hgroup-hd:hover{background:#f1f5f9}.mwe-hgroup-hd.is-open{background:#eef2ff}.mwe-hgroup-left{display:flex;flex-direction:column;gap:2px}.mwe-hgroup-qm{color:#0f172a;font-size:var(--fs-14)}.mwe-hgroup-sub{color:#64748b;font-size:var(--fs-12)}.mwe-hgroup-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.mwe-hgroup-caret{font-size:var(--fs-16);color:#334155;margin-left:2px}.mwe-hgroup-body{padding:10px 12px 14px;background:#fff}.mwe-page{color:#0f172a}.mwe-page input,.mwe-page select,.mwe-page textarea{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;caret-color:#0f172a!important;text-shadow:none!important}.mwe-page .mwe-btn{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important}.mwe-page .mwe-btn svg{color:currentColor!important}.mwe-page .mwe-qtycell,.mwe-page .mwe-input{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;caret-color:#0f172a!important}.mwe-page .mwe-table th,.mwe-page .mwe-table td{color:#0f172a}.mwe-page .mwe-sub,.mwe-page .mwe-row-sub,.mwe-page .mwe-note,.mwe-page .mwe-muted,.mwe-page .mwe-empty,.mwe-page .mwe-hgroup-sub{color:#64748b!important;-webkit-text-fill-color:#64748b!important}@media(forced-colors:active){.mwe-page{forced-color-adjust:auto}.mwe-page .mwe-topbar,.mwe-page .mwe-filters,.mwe-page .mwe-card,.mwe-page .mwe-hgroup{border:1px solid ButtonText;background:Canvas;color:CanvasText}.mwe-page .mwe-btn{border:1px solid ButtonText;background:ButtonFace;color:ButtonText;-webkit-text-fill-color:ButtonText}.mwe-page input,.mwe-page select,.mwe-page textarea,.mwe-page .mwe-qtycell,.mwe-page .mwe-input{border:1px solid ButtonText;background:Field;color:FieldText!important;-webkit-text-fill-color:FieldText!important}.mwe-page .mwe-pill,.mwe-page .mwe-chip,.mwe-page .mwe-badge{border:1px solid ButtonText;background:ButtonFace;color:ButtonText}}.mwe-page{color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.mwe-page,.mwe-page *{color:inherit}.mwe-page input,.mwe-page select,.mwe-page textarea,.mwe-page .mwe-input,.mwe-page .mwe-qtycell{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;caret-color:#0f172a!important;background-color:#fff;background-clip:padding-box;text-shadow:none!important}.mwe-page input::placeholder,.mwe-page textarea::placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.mwe-page input::-webkit-input-placeholder,.mwe-page textarea::-webkit-input-placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.mwe-page input,.mwe-page select,.mwe-page textarea{-webkit-appearance:none;appearance:none}.mwe-page select{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;background-color:#fff!important}.mwe-page select option{color:#0f172a!important;background:#fff!important}.mwe-page input:-webkit-autofill,.mwe-page textarea:-webkit-autofill,.mwe-page select:-webkit-autofill{-webkit-text-fill-color:#0f172a!important;caret-color:#0f172a!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}.mwe-page .mwe-btn,.mwe-page .mwe-btn-ghost,.mwe-page button{-webkit-text-fill-color:currentColor!important}.mwe-page .mwe-btn svg,.mwe-page button svg{color:currentColor!important}.mwe-page .mwe-btn.primary{color:#fff!important;-webkit-text-fill-color:#ffffff!important}@media(forced-colors:active){.mwe-page{forced-color-adjust:auto}.mwe-page input,.mwe-page select,.mwe-page textarea,.mwe-page .mwe-qtycell,.mwe-page .mwe-input{color:FieldText!important;-webkit-text-fill-color:FieldText!important;background:Field!important;border:1px solid ButtonText!important}}.qm14-page{padding:16px 18px;height:100%;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px;min-height:0}.qm14-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:12px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.qm14-h1{font-size:var(--fs-18);font-weight:800}.qm14-sub{margin-top:2px;font-size:var(--fs-12);color:#64748b}.qm14-actions{display:flex;gap:8px}.qm14-btn{padding:9px 12px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;cursor:pointer;font-weight:700}.qm14-btn:disabled{opacity:.6;cursor:not-allowed}.qm14-btn:hover{background:#f1f5f9}.qm14-filters{display:flex;gap:10px;flex-wrap:wrap;padding:12px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.qm14-field{display:flex;flex-direction:column;gap:6px;min-width:150px}.qm14-field-grow{flex:1;min-width:260px}.qm14-field label{font-size:var(--fs-12);color:#64748b;font-weight:700}.qm14-field select,.qm14-field input{height:36px;border-radius:10px;border:1px solid #e2e8f0;padding:0 10px;outline:none;background:#fff}.qm14-search{display:flex;gap:8px}.qm14-search input{flex:1}.qm14-error{padding:10px 12px;background:#fee2e2;color:#7f1d1d;border:1px solid #fecaca;border-radius:12px;font-weight:700}.qm14-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.qm14-kpi{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:12px 14px}.qm14-kpi .t{font-size:var(--fs-12);color:#64748b;font-weight:800}.qm14-kpi .v{font-size:var(--fs-20);font-weight:900;margin-top:2px}.qm14-grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;min-height:0}.qm14-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:12px 14px;min-height:0}.qm14-card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:10px}.qm14-card-title{font-weight:900}.qm14-chip{padding:4px 8px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;font-size:var(--fs-12);font-weight:800;color:#334155}.qm14-chart{height:280px;border:1px dashed #e2e8f0;border-radius:12px;padding:6px}.qm14-mini{margin-top:10px;display:flex;flex-direction:column;gap:6px}.qm14-mini-row{display:flex;justify-content:space-between;gap:10px;font-size:var(--fs-12);color:#334155}.qm14-mini-row .k{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qm14-mini-row .v{font-weight:900}.qm14-bottom{flex:1;display:flex;flex-direction:column}.qm14-tablewrap{flex:1;min-height:0;overflow:auto;border:1px solid #e2e8f0;border-radius:12px}.qm14-empty{padding:18px;color:#64748b;font-weight:800}.qm14-table{width:100%;border-collapse:collapse;font-size:var(--fs-12)}.qm14-table thead th{position:sticky;top:0;background:#f8fafc;border-bottom:1px solid #e2e8f0;text-align:left;padding:10px;color:#334155;font-weight:900;z-index:1}.qm14-table tbody td{border-bottom:1px solid #f1f5f9;padding:9px 10px;vertical-align:top}.qm14-table tbody tr:hover{background:#f8fafc}.qm14-table .num{text-align:right;font-variant-numeric:tabular-nums}.qm14-table .text{max-width:420px}@media(max-width:1100px){.qm14-grid2{grid-template-columns:1fr}.qm14-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}.qm14-page{padding:16px 18px;height:auto;min-height:100vh;overflow-y:auto;overflow-x:hidden;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px}.qm14-bottom{flex:0 0 auto;display:flex;flex-direction:column}.qm14-tablewrap{flex:0 0 auto;max-height:520px;overflow:auto;border:1px solid #e2e8f0;border-radius:12px;background:#fff}.qm14-card-components{border-color:#dbe3ee}.qm14-chart-tall{height:420px;padding:0;overflow:hidden}.qm14-card-components .recharts-cartesian-axis-tick-value{fill:#334155}.qm14-card-components .recharts-cartesian-grid-horizontal line,.qm14-card-components .recharts-cartesian-grid-vertical line{stroke:#e7eef7}.qm14-card-components .recharts-default-tooltip{border-radius:12px!important;border:1px solid #e2e8f0!important;box-shadow:0 10px 26px #00000014!important}.qm14-card-defects .recharts-cartesian-grid-horizontal line,.qm14-card-defects .recharts-cartesian-grid-vertical line{stroke:#e7eef7}.qm14-card-defects .recharts-cartesian-axis-tick-value{fill:#334155}.qm14-mini-row .k{display:flex;align-items:center;gap:8px}.qm14-mini-dot{width:10px;height:10px;border-radius:999px;flex:0 0 auto}.qm14-card-trend .recharts-cartesian-axis-tick-value{fill:#334155}.qm14-card-trend .recharts-default-legend{font-size:var(--fs-12);font-weight:700;color:#334155}.qm14-kpi{position:relative;background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:16px 18px;transition:transform .2s,box-shadow .2s}.qm14-kpi:hover{transform:translateY(-2px);box-shadow:0 12px 28px #00000014}.qm14-kpi:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;border-top-left-radius:16px;border-top-right-radius:16px}.qm14-kpi .t{font-size:var(--fs-13);font-weight:700;color:#64748b}.qm14-kpi .v{font-size:var(--fs-28);font-weight:900;margin-top:6px}.kpi-blue:before{background:#2563eb}.kpi-blue .v{color:#2563eb}.kpi-sky:before{background:#0ea5e9}.kpi-sky .v{color:#0ea5e9}.kpi-amber:before{background:#f59e0b}.kpi-amber .v{color:#f59e0b}.kpi-green:before{background:#22c55e}.kpi-green .v{color:#22c55e}.kpi-purple:before{background:#8b5cf6}.kpi-purple .v{color:#8b5cf6}.qm14-btn-ai{display:inline-flex;align-items:center;gap:6px}.qm14-modal-backdrop{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:16px;z-index:60}.qm14-modal{width:min(980px,96vw);max-height:86vh;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 16px 40px #0f172a2e;display:flex;flex-direction:column;overflow:hidden}.qm14-modal-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #e2e8f0}.qm14-modal-title{font-weight:800;color:#0f172a}.qm14-icon-btn{border:0;background:transparent;cursor:pointer;font-size:var(--fs-18);padding:6px;border-radius:10px}.qm14-icon-btn:hover{background:#f1f5f9}.qm14-modal-bd{padding:12px 14px;overflow:auto}.qm14-muted{color:#64748b}.qm14-ai-meta{font-size:var(--fs-12);color:#64748b;margin-bottom:10px}.qm14-ai-h{font-weight:800;margin:12px 0 6px;color:#0f172a}.qm14-ai-p{color:#0f172a;line-height:1.45}.qm14-ai-ul{margin:0 0 8px 18px;color:#0f172a}.qm14-ai-table{margin-top:8px}.qm14-table-ai th,.qm14-table-ai td{font-size:var(--fs-12)}.qm14-modal-hd .qm14-btn{height:34px;padding:0 12px;border-radius:10px}.qm14-modal-hd{position:relative}.qm14-modal-actions{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:10px;z-index:3}.qm14-modal-title{padding-right:190px;min-width:0}.qm14-modal-hd .qm14-icon-btn{position:static!important}.qm14-kpi-multi{display:flex;flex-direction:column;gap:4px;margin-top:4px}.qm14-kpi-line{display:flex;justify-content:space-between;font-size:var(--fs-14);font-weight:600}.qm14-kpi-line .unit{color:#334155}.qm14-kpi-line .qty{color:#0f172a}.qm14-comp-groups{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:1024px){.qm14-comp-groups{grid-template-columns:1fr 1fr}}.qm14-comp-group{border:1px solid #e2e8f0;border-radius:14px;background:#fff;padding:12px}.qm14-comp-hd{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.qm14-comp-meta{display:flex;gap:8px;flex-wrap:wrap}.dbc-page{padding:16px 24px;height:100%;background:#f8fafc;color:#111827;font-size:var(--fs-16)}.dbc-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:12px}.dbc-h1{font-size:var(--fs-16);font-weight:800}.dbc-sub{margin-top:2px;font-size:var(--fs-16);font-weight:400;color:#64748b}.dbc-search{position:relative;width:100%;max-width:720px}.dbc-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65;font-size:var(--fs-16)}.dbc-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-16);color:#111827}.dbc-search-input:focus{outline:none;background:#fff}.dbc-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 210px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.dbc-card::-webkit-scrollbar{width:8px;height:8px}.dbc-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.dbc-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dbc-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.dbc-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-16);font-weight:800;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left}.dbc-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;font-size:var(--fs-16)}.dbc-table tr:hover{background:#f8fafc}.dbc-mono{font-family:var(--pps-font-mono)}.dbc-center{text-align:center}.dbc-loading,.dbc-empty{padding:10px;text-align:center;font-size:var(--fs-16);font-weight:800;color:#6b7280}.dbc-toggle{height:36px;min-width:160px;padding:0 12px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:var(--fs-16);font-weight:800;color:#0f172a;box-shadow:0 1px #0f172a0a}.dbc-toggle:hover{background:#e0f2fe;border-color:#7dd3fc}.dbc-toggle:disabled{opacity:.65;cursor:not-allowed}.dbc-toggle .dbc-dot{width:12px;height:12px;border-radius:999px;background:#cbd5e1;box-shadow:inset 0 0 0 2px #0f172a0f}.dbc-toggle.on{border-color:#7dd3fc;background:#e0f2fe}.dbc-toggle.on .dbc-dot{background:#22c55e}.dbc-deny{padding:16px;border:1px solid #fecaca;background:#fff1f2;border-radius:12px;color:#991b1b;font-size:var(--fs-16);font-weight:800}.oee-page{--bg: #f8fafc;--card: #ffffff;--card-soft: #f8fbff;--border: #dbe4ee;--border-strong: #cbd5e1;--text: #0f172a;--muted: #64748b;--muted-strong: #475569;--primary: #0369a1;--primary-soft: #e0f2fe;--primary-line: #bae6fd;--cyan: #0f766e;--cyan-soft: #ccfbf1;--cyan-line: #99f6e4;--green: #166534;--green-soft: #ecfdf5;--green-line: #bbf7d0;--violet: #6d28d9;--violet-soft: #ede9fe;--violet-line: #ddd6fe;--slate: #334155;--slate-soft: #f1f5f9;--slate-line: #cbd5e1;--red: #b91c1c;--red-soft: #fee2e2;--red-line: #fecaca;--amber: #b45309;--amber-soft: #fffbeb;--amber-line: #fde68a;--shadow: 0 10px 26px rgba(15, 23, 42, .06);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--radius: 18px;--radius-sm: 12px;min-height:100%;height:100%;padding:16px;background:var(--bg);color:var(--text);display:grid;gap:16px;overflow:auto;align-content:start;box-sizing:border-box;grid-auto-rows:max-content}.oee-toolbar,.oee-filter-card,.oee-panel,.oee-metric-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);box-sizing:border-box}.oee-toolbar,.oee-filter-card,.oee-panel{padding:16px 18px}.oee-page,.oee-chart-wrap,.oee-gauge-card,.oee-highlight-card,.oee-rank-item,.oee-detail-card,.oee-raw-panel,.oee-raw-table-wrap{position:relative;z-index:0}.oee-panel{position:relative;z-index:0;min-width:0;min-height:fit-content;overflow:hidden;display:grid;gap:14px;align-content:start}.oee-panel>*{min-width:0}.oee-panel-grid,.oee-chart-grid,.oee-summary-grid,.oee-exec-grid,.oee-hero-grid,.oee-highlight-grid{width:100%;min-width:0;align-items:start}.oee-panel-grid>.oee-panel,.oee-chart-grid>.oee-panel,.oee-exec-grid>.oee-panel{align-self:start;height:auto;min-height:0;max-height:none}.oee-panel-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:16px;min-height:0;grid-auto-rows:max-content}.oee-chart-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr 1fr;gap:16px}.oee-exec-grid{position:relative;z-index:1;display:grid;gap:16px}.oee-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.oee-title{font-size:var(--fs-24);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text)}.oee-subtitle{margin-top:4px;color:var(--muted);font-size:var(--fs-14);line-height:1.55;max-width:880px}.oee-toolbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.oee-refresh-btn,.oee-load-btn,.oee-export-btn{height:42px;border-radius:12px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-14);font-weight:700;cursor:pointer;white-space:nowrap;transition:background .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .08s ease,opacity .18s ease}.oee-refresh-btn,.oee-export-btn{background:var(--primary-soft);border:1px solid var(--primary-line);color:var(--primary)}.oee-load-btn{width:100%;background:var(--primary);border:1px solid var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.oee-refresh-btn:hover:not(:disabled),.oee-load-btn:hover:not(:disabled),.oee-export-btn:hover:not(:disabled){transform:translateY(-1px)}.oee-refresh-btn:hover:not(:disabled),.oee-export-btn:hover:not(:disabled){background:#bae6fd}.oee-load-btn:hover:not(:disabled){background:#075985;border-color:#075985}.oee-refresh-btn:disabled,.oee-load-btn:disabled,.oee-export-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.oee-filter-grid-4{grid-template-columns:220px 180px minmax(260px,1fr) 160px}.oee-field input::placeholder{color:#94a3b8}.oee-summary-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.oee-metric-card{min-height:124px;padding:16px;display:grid;gap:8px;align-content:start}.oee-metric-head{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800}.oee-metric-value{font-size:var(--fs-28);line-height:1.05;font-weight:800;letter-spacing:-.03em}.oee-metric-sub{color:var(--muted);font-size:var(--fs-13);line-height:1.45}.accent-cyan{background:linear-gradient(180deg,#fff,#f5fffd);border-color:#c7f9f1}.accent-cyan .oee-metric-head,.accent-cyan .oee-metric-value{color:var(--cyan)}.accent-blue{background:linear-gradient(180deg,#fff,#f7fcff);border-color:#d8eefb}.accent-blue .oee-metric-head,.accent-blue .oee-metric-value{color:var(--primary)}.accent-violet{background:linear-gradient(180deg,#fff,#faf8ff);border-color:#e7ddff}.accent-violet .oee-metric-head,.accent-violet .oee-metric-value{color:var(--violet)}.accent-green{background:linear-gradient(180deg,#fff,#f7fef9);border-color:#d8f7e4}.accent-green .oee-metric-head,.accent-green .oee-metric-value{color:var(--green)}.accent-slate{background:linear-gradient(180deg,#fff,#fafcff);border-color:#e2e8f0}.accent-slate .oee-metric-head,.accent-slate .oee-metric-value{color:var(--slate)}.oee-hero-panel{overflow:hidden}.oee-hero-grid{display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px;align-items:stretch}.oee-gauge-card{border:1px solid var(--border);border-radius:16px;background:radial-gradient(circle at top,#f0f9ff,#fff 62%);padding:12px;display:grid;align-items:center;overflow:hidden}.oee-gauge-chart{position:relative;width:100%;height:250px}.oee-gauge-center{position:absolute;inset:0;display:grid;place-content:center;text-align:center;pointer-events:none}.oee-gauge-value{font-size:var(--fs-32);font-weight:800;line-height:1;color:var(--primary);letter-spacing:-.03em}.oee-gauge-label{margin-top:6px;font-size:var(--fs-12);font-weight:700;color:var(--muted);letter-spacing:.02em;text-transform:uppercase}.oee-highlight-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.oee-highlight-card{min-height:122px;border-radius:16px;border:1px solid var(--border);padding:16px;display:grid;gap:8px;align-content:start;box-shadow:var(--shadow-sm);overflow:hidden}.oee-highlight-card.positive{background:linear-gradient(180deg,#fff,#f4fff8);border-color:#d4f6df}.oee-highlight-card.negative{background:linear-gradient(180deg,#fff,#fff7f7);border-color:#fde2e2}.oee-highlight-card.neutral{background:linear-gradient(180deg,#fff,#f7fbff);border-color:#dbeafe}.oee-highlight-head{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;color:var(--muted-strong)}.oee-highlight-name{font-size:var(--fs-16);font-weight:700;line-height:1.35;color:var(--text);word-break:break-word}.oee-highlight-value{font-size:var(--fs-28);font-weight:800;line-height:1.05;letter-spacing:-.03em;color:var(--text)}.oee-highlight-card.positive .oee-highlight-value{color:var(--green)}.oee-highlight-card.negative .oee-highlight-value{color:var(--red)}.oee-highlight-card.neutral .oee-highlight-value{color:var(--primary)}.oee-highlight-sub{font-size:var(--fs-12);line-height:1.45;color:var(--muted);word-break:break-word}.oee-chart-wrap{width:100%;min-height:0;border-radius:16px;border:1px solid var(--border);background:linear-gradient(180deg,#fff,#fbfdff);overflow:hidden;padding:10px 10px 2px;box-sizing:border-box}.oee-chart-wrap.lg{height:340px}.oee-chart-wrap.md{height:300px}.oee-chart-tooltip{min-width:180px;max-width:280px;border-radius:14px;background:#fffffffa;border:1px solid var(--border);box-shadow:0 12px 30px #0f172a1f;padding:10px 12px}.oee-chart-tooltip-title{font-size:var(--fs-12);font-weight:800;color:var(--text);margin-bottom:8px}.oee-chart-tooltip-list{display:grid;gap:6px}.oee-chart-tooltip-row{display:grid;grid-template-columns:10px 1fr auto;gap:8px;align-items:center}.oee-chart-tooltip-dot{width:10px;height:10px;border-radius:999px}.oee-chart-tooltip-name{font-size:var(--fs-12);color:var(--muted-strong)}.oee-chart-tooltip-value{font-size:var(--fs-12);font-weight:800;color:var(--text)}.oee-panel-head{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.oee-panel-title{font-size:var(--fs-18);font-weight:800;line-height:1.2;color:var(--text)}.oee-panel-sub{margin-top:2px;color:var(--muted);font-size:var(--fs-13);line-height:1.45}.oee-chip{padding:6px 10px;border-radius:999px;background:#eff6ff;border:1px solid #dbeafe;color:#1d4ed8;font-size:var(--fs-12);font-weight:700;white-space:nowrap;flex:0 0 auto}.oee-rank-list{display:grid;gap:10px;min-width:0}.oee-rank-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border-radius:14px;background:var(--card-soft);border:1px solid var(--border);transition:background .18s ease,border-color .18s ease,transform .12s ease,box-shadow .18s ease;overflow:hidden}.oee-rank-item:hover{background:#f3f8fd;border-color:#cfe0f3;transform:translateY(-1px)}.oee-rank-item.danger{background:#fff8f8;border-color:#fde2e2}.oee-rank-item.danger:hover{background:#fff4f4;border-color:#f9caca}.oee-rank-left{min-width:0;flex:1;display:flex;align-items:center;gap:12px}.oee-rank-index{width:34px;height:34px;flex:0 0 auto;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#e0f2fe;color:var(--primary);font-size:var(--fs-13);font-weight:800}.oee-rank-item.danger .oee-rank-index{background:#fee2e2;color:var(--red)}.oee-rank-right{width:132px;flex:0 0 auto;display:grid;gap:6px}.oee-rank-name,.oee-cell-strong{font-size:var(--fs-14);font-weight:700;line-height:1.35;color:var(--text);word-break:break-word}.oee-rank-sub,.oee-cell-sub{font-size:var(--fs-12);line-height:1.45;color:var(--muted);word-break:break-word}.oee-rank-score,.oee-score-cell{font-size:var(--fs-14);font-weight:800;color:var(--slate)}.oee-score-bar{width:100%;height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}.oee-score-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#0ea5e9,#0284c7)}.oee-detail-bar{height:12px}.oee-raw-panel{grid-column:1 / -1}.oee-raw-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.oee-table-wrap,.oee-raw-table-wrap{min-height:0;overflow:auto;border:1px solid var(--border);border-radius:14px;background:#fff}.oee-table,.oee-raw-table{width:100%;min-width:1600px;border-collapse:separate;border-spacing:0}.oee-table th,.oee-raw-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--slate);font-size:var(--fs-12);font-weight:800;text-align:left;padding:12px;border-bottom:1px solid var(--border);white-space:nowrap}.oee-table td,.oee-raw-table td{padding:12px;border-bottom:1px solid #edf2f7;font-size:var(--fs-13);vertical-align:middle}.oee-table tbody tr:last-child td,.oee-raw-table tbody tr:last-child td{border-bottom:0}.oee-table tbody tr:hover td,.oee-raw-table tbody tr:hover td{background:#f8fbff}.oee-raw-table td{white-space:nowrap}.oee-raw-table td:nth-child(4),.oee-raw-table td:nth-child(6){white-space:normal;min-width:220px}.oee-raw-code{font-weight:700;color:var(--primary)}.oee-raw-badge{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:800;border:1px solid transparent}.oee-raw-badge.good{color:var(--green);background:var(--green-soft);border-color:var(--green-line)}.oee-raw-badge.watch{color:var(--amber);background:var(--amber-soft);border-color:var(--amber-line)}.oee-raw-badge.bad{color:var(--red);background:var(--red-soft);border-color:var(--red-line)}.oee-detail-panel{grid-column:1 / -1;width:100%;display:block;overflow:visible;position:relative;z-index:5;clear:both;margin-top:0}.oee-detail-panel .oee-panel-head{position:relative;z-index:8}.oee-detail-stack{position:relative;z-index:6;display:flex;flex-direction:column;gap:16px;width:100%;isolation:isolate;min-width:0}.oee-detail-card{position:relative;z-index:7;width:100%;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,#fff,#fbfdff);padding:18px;box-shadow:var(--shadow-sm);display:grid;gap:16px;box-sizing:border-box;overflow:hidden}.oee-detail-card:hover{z-index:8}.oee-detail-top{display:grid;grid-template-columns:64px minmax(0,1fr);gap:16px;align-items:start}.oee-detail-rank{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;background:#eff6ff;color:var(--primary);font-size:var(--fs-18);font-weight:800;border:1px solid #dbeafe;box-sizing:border-box}.oee-detail-main{min-width:0;display:grid;gap:12px}.oee-detail-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.oee-detail-title{font-size:var(--fs-16);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.oee-detail-sub{margin-top:4px;font-size:var(--fs-13);color:var(--muted);line-height:1.5;word-break:break-word}.oee-detail-oee-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.oee-detail-oee-label{font-size:var(--fs-12);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.oee-detail-oee-value{font-size:var(--fs-24);font-weight:800;color:var(--primary);line-height:1;white-space:nowrap}.oee-detail-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.oee-detail-metric{border:1px solid var(--border);background:var(--card-soft);border-radius:16px;padding:14px 16px;display:grid;gap:6px;min-width:0;box-sizing:border-box}.oee-detail-metric-label{font-size:var(--fs-12);font-weight:700;color:var(--muted)}.oee-detail-metric-value{font-size:var(--fs-20);font-weight:800;color:var(--text);line-height:1.1;white-space:nowrap}.oee-band{min-height:32px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-12);font-weight:800;border:1px solid transparent;white-space:nowrap;flex:0 0 auto}.oee-band.excellent{color:var(--green);background:var(--green-soft);border-color:var(--green-line)}.oee-band.good{color:var(--primary);background:var(--primary-soft);border-color:var(--primary-line)}.oee-band.watch{color:var(--amber);background:var(--amber-soft);border-color:var(--amber-line)}.oee-band.critical{color:var(--red);background:var(--red-soft);border-color:var(--red-line)}.oee-empty{text-align:center;color:var(--muted);padding:24px 12px}@media(max-width:1480px){.oee-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.oee-chart-grid{grid-template-columns:1fr}}@media(max-width:1400px){.oee-filter-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.oee-hero-grid{grid-template-columns:1fr}.oee-gauge-card{min-height:280px}}@media(max-width:1080px){.oee-panel-grid{grid-template-columns:1fr}.oee-highlight-grid{grid-template-columns:1fr 1fr}.oee-detail-panel,.oee-raw-panel{grid-column:auto}}@media(max-width:760px){.oee-page{padding:12px;gap:12px}.oee-toolbar,.oee-panel-head{flex-direction:column;align-items:stretch}.oee-toolbar,.oee-filter-card,.oee-panel{padding:14px}.oee-title{font-size:var(--fs-20)}.oee-summary-grid{grid-template-columns:1fr 1fr}.oee-filter-grid-4,.oee-highlight-grid{grid-template-columns:1fr}.oee-rank-item,.oee-rank-left{align-items:flex-start}.oee-rank-item{flex-direction:column}.oee-rank-right{width:100%}.oee-chart-wrap.lg,.oee-chart-wrap.md{height:300px}.oee-gauge-chart{height:230px}.oee-detail-card{padding:14px}.oee-detail-top{grid-template-columns:1fr;gap:12px}.oee-detail-rank{width:52px;height:52px;font-size:var(--fs-16);border-radius:16px}.oee-detail-title-row,.oee-detail-oee-row{flex-direction:column;align-items:flex-start}.oee-detail-metrics{grid-template-columns:1fr}.oee-table th,.oee-table td,.oee-raw-table th,.oee-raw-table td{padding:10px}}@media(max-width:520px){.oee-summary-grid{grid-template-columns:1fr}.oee-metric-card{min-height:auto}.oee-gauge-value{font-size:var(--fs-28)}.oee-highlight-value{font-size:var(--fs-24)}}.oee-field input,.oee-field select{width:100%;min-height:40px;padding:0 12px;border:1px solid var(--border, #cbd5e1);border-radius:10px;background:#fff;color:var(--text, #0f172a);outline:none}.oee-field input:focus,.oee-field select:focus{border-color:#0284c7;box-shadow:0 0 0 3px #0284c71f}.oee-filter-grid{display:grid;gap:12px}.oee-filter-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.oee-filter-grid-6{grid-template-columns:180px 220px minmax(240px,1fr) 140px 140px 220px}.oee-filter-grid-line-name{grid-template-columns:1fr}.oee-field{display:grid;gap:6px;min-width:0}.oee-field label{display:inline-flex;align-items:center;gap:6px;min-height:18px;font-size:var(--fs-13);font-weight:700;color:var(--muted)}.oee-field input,.oee-field select{width:100%;height:42px;border-radius:12px;border:1px solid var(--border-strong);background:#eef3f9;color:var(--text);padding:0 12px;font-size:var(--fs-14);outline:none;box-sizing:border-box;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}.oee-field input:focus,.oee-field select:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #0369a11f}.oee-field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#64748b 50%),linear-gradient(135deg,#64748b 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:32px}.oee-multi-select{min-height:140px!important;height:140px!important;padding:8px 10px!important;background-image:none!important;appearance:auto!important;overflow:auto}.oee-multi-select option{padding:6px 8px}.oee-field-help{font-size:var(--fs-12);color:var(--muted);line-height:1.4}@media(max-width:1480px){.oee-filter-grid-6{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:980px){.oee-filter-grid-6,.oee-filter-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.oee-filter-grid-6,.oee-filter-grid-4,.oee-filter-grid-line-name{grid-template-columns:1fr}.oee-multi-select{min-height:120px!important;height:120px!important}}.pgm-page{--pgm-bg: #f8fafc;--pgm-card: #ffffff;--pgm-border: #dbe3ef;--pgm-border-strong: #cbd5e1;--pgm-text: #111827;--pgm-muted: #6b7280;--pgm-muted-2: #64748b;--pgm-primary: #2563eb;--pgm-primary-hover: #1d4ed8;--pgm-primary-soft: #eff6ff;--pgm-ok: #15803d;--pgm-ok-soft: #dcfce7;--pgm-bad: #dc2626;--pgm-bad-soft: #fee2e2;--pgm-warn: #b45309;--pgm-warn-soft: #fffbeb;min-height:100dvh;padding:14px;background:var(--pgm-bg);color:var(--pgm-text);font-family:var(--pps-font-main);font-size:var(--fs-16);font-weight:400;line-height:1.5;letter-spacing:0;font-feature-settings:"tnum" 1;display:flex;flex-direction:column;gap:12px;overflow-x:hidden}.pgm-page,.pgm-page *{box-sizing:border-box;min-width:0}.pgm-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;padding:12px;border:1px solid var(--pgm-border);border-radius:18px;background:radial-gradient(circle at top left,rgba(37,99,235,.08),transparent 32%),var(--pgm-card);color:var(--pgm-text);box-shadow:0 8px 24px #0f172a0e}.pgm-eyebrow{margin:0 0 4px;color:var(--pgm-primary-hover);font-size:var(--fs-12);font-weight:700;letter-spacing:.5px;text-transform:uppercase}.pgm-hero h1{margin:0;color:var(--pgm-text);font-size:var(--fs-20);font-weight:700;line-height:1.35;letter-spacing:0}.pgm-subtitle{margin:6px 0 0;max-width:880px;color:var(--pgm-muted);font-size:var(--fs-15);font-weight:400;line-height:1.5}.pgm-hero-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.pgm-btn,.pgm-confirm-btn{min-height:40px;border-radius:10px;border:1px solid var(--pgm-border-strong);background:#fff;color:var(--pgm-text);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;font-family:inherit;font-size:var(--fs-16);font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .12s ease,box-shadow .15s ease}.pgm-btn:hover,.pgm-confirm-btn:hover{background:#f8fafc}.pgm-btn:active,.pgm-confirm-btn:active{transform:translateY(1px)}.pgm-btn:disabled,.pgm-confirm-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.pgm-btn.primary{border-color:#93c5fd;background:var(--pgm-primary);color:#fff}.pgm-btn.primary:hover:not(:disabled){background:var(--pgm-primary-hover)}.pgm-btn.ghost{border-color:#bfdbfe;background:var(--pgm-primary-soft);color:var(--pgm-primary-hover)}.pgm-btn.ghost:hover:not(:disabled){background:#dbeafe}.pgm-confirm-btn{min-height:32px;width:100%;max-width:112px;padding:0 10px;border-color:#86efac;background:#ecfdf5;color:#15803d;font-size:var(--fs-13);font-weight:800}.pgm-confirm-btn:hover:not(:disabled){background:#dcfce7;border-color:#4ade80}.pgm-viewonly{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:0 10px;border-radius:999px;background:#f1f5f9;color:#64748b;font-size:var(--fs-12);font-weight:700;white-space:nowrap}.pgm-filters{display:grid;grid-template-columns:minmax(140px,.8fr) minmax(180px,1fr) minmax(320px,2.2fr);gap:10px;align-items:end;padding:12px;border:1px solid var(--pgm-border);border-radius:18px;background:var(--pgm-card);box-shadow:0 8px 24px #0f172a0e}.pgm-filters label{display:grid;gap:5px;min-width:0}.pgm-filters span{color:var(--pgm-muted-2);font-size:var(--fs-12);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.pgm-filters input,.pgm-filters select{width:100%;min-height:40px;border-radius:10px;border:1px solid #d1d5db;background:#e8edf5;color:var(--pgm-text);padding:0 10px;font-family:inherit;font-size:var(--fs-16);font-weight:500;outline:none;letter-spacing:0}.pgm-filters input:focus,.pgm-filters select:focus,.pgm-search:focus-within>div{background:#fff;border-color:#0369a1;box-shadow:0 0 0 3px #0369a11a}.pgm-filters input::placeholder,.pgm-search input::placeholder{color:#94a3b8;font-weight:500}.pgm-search>div{min-height:40px;border:1px solid #d1d5db;border-radius:10px;display:flex;align-items:center;gap:8px;padding:0 10px;background:#e8edf5;color:var(--pgm-muted-2);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.pgm-search input{min-height:auto;height:auto;border:0;border-radius:0;padding:0;background:transparent;box-shadow:none!important}.pgm-alert{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid #fde68a;background:var(--pgm-warn-soft);color:var(--pgm-warn);font-size:var(--fs-14);font-weight:700;line-height:1.45}.pgm-summary{display:grid;grid-template-columns:repeat(5,minmax(140px,1fr));gap:12px}.pgm-card{padding:12px;display:flex;flex-direction:column;justify-content:center;gap:4px;min-height:92px;border:1px solid var(--pgm-border);border-radius:18px;background:var(--pgm-card);box-shadow:0 8px 24px #0f172a0e}.pgm-card span{display:block;color:var(--pgm-muted);font-size:var(--fs-12);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.pgm-card strong{display:block;color:var(--pgm-text);font-size:var(--fs-22);font-weight:700;line-height:1.1}.pgm-card.good{border-color:#bbf7d0;background:linear-gradient(180deg,#fff,#f0fdf4)}.pgm-card.good strong,.good-text{color:var(--pgm-ok)}.pgm-card.waste{border-color:#fecaca;background:linear-gradient(180deg,#fff,#fef2f2)}.pgm-card.waste strong,.waste-text{color:var(--pgm-bad)}.pgm-table-card{background:var(--pgm-card);border:1px solid var(--pgm-border);border-radius:18px;box-shadow:0 8px 24px #0f172a0e;overflow:hidden}.pgm-table-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;padding:12px;border-bottom:1px solid var(--pgm-border);background:#fff}.pgm-table-head h2{margin:0;color:var(--pgm-text);font-size:var(--fs-16);font-weight:700;line-height:1.35}.pgm-table-head p{margin:4px 0 0;color:var(--pgm-muted);font-size:var(--fs-14);font-weight:400;line-height:1.45}.pgm-loading{display:inline-flex;align-items:center;min-height:26px;padding:0 10px;border-radius:999px;background:var(--pgm-primary-soft);color:var(--pgm-primary-hover);font-size:var(--fs-12);font-weight:700;white-space:nowrap}.pgm-table-wrap{width:100%;max-height:calc(100dvh - 340px);overflow:auto;-webkit-overflow-scrolling:touch}.pgm-table{width:100%;min-width:980px;table-layout:fixed;border-collapse:separate;border-spacing:0;font-size:var(--fs-16)}.pgm-table th,.pgm-table td{border-bottom:1px solid #eef2f7;padding:7px 8px;text-align:left;vertical-align:middle}.pgm-table th{position:sticky;top:0;z-index:20;height:38px;background:#f1f5f9;color:var(--pgm-text);font-size:var(--fs-12);font-weight:700;line-height:1.2;letter-spacing:0;text-transform:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pgm-table th.num{text-align:right}.pgm-table td{background:#fff;color:var(--pgm-text);font-size:var(--fs-16);font-weight:400;line-height:1.35}.pgm-table tbody tr:hover td{background:#fcfdff}.pgm-table .num{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.pgm-table th:nth-child(1),.pgm-table td:nth-child(1){width:11%}.pgm-table th:nth-child(2),.pgm-table td:nth-child(2){width:5%}.pgm-table th:nth-child(3),.pgm-table td:nth-child(3){width:8%}.pgm-table th:nth-child(4),.pgm-table td:nth-child(4){width:14%}.pgm-table th:nth-child(5),.pgm-table td:nth-child(5){width:23%}.pgm-table th:nth-child(6),.pgm-table td:nth-child(6),.pgm-table th:nth-child(7),.pgm-table td:nth-child(7){width:6%}.pgm-table th:nth-child(8),.pgm-table td:nth-child(8){width:7%}.pgm-table th:nth-child(9),.pgm-table td:nth-child(9){width:6%}.pgm-table th:nth-child(10),.pgm-table td:nth-child(10){width:5%}.pgm-table th:nth-child(11),.pgm-table td:nth-child(11){width:9%}.pgm-table td:nth-child(1){font-size:var(--fs-13);color:#334155;white-space:normal}.pgm-table td:nth-child(2),.pgm-table td:nth-child(3){overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pgm-table td:nth-child(6),.pgm-table td:nth-child(7),.pgm-table td:nth-child(8),.pgm-table td:nth-child(9),.pgm-table td:nth-child(10){font-size:var(--fs-14)}.pgm-main-text{max-width:100%;color:var(--pgm-text);font-size:var(--fs-16);font-weight:700;line-height:1.35;white-space:normal;word-break:break-word;overflow-wrap:anywhere}.pgm-sub-text{margin-top:4px;max-width:100%;color:var(--pgm-muted);font-size:var(--fs-14);font-weight:400;line-height:1.45;white-space:normal;word-break:break-word;overflow-wrap:anywhere}.pgm-empty{padding:18px!important;color:var(--pgm-muted)!important;text-align:center!important;font-size:var(--fs-16)!important;font-weight:500!important}@media(min-width:1280px){.pgm-table{min-width:0}}@media(max-width:1180px){.pgm-filters{grid-template-columns:repeat(2,minmax(160px,1fr))}.pgm-search{grid-column:1 / -1}.pgm-summary{grid-template-columns:repeat(2,minmax(160px,1fr))}}@media(max-width:760px){.pgm-page{padding:10px;font-size:var(--fs-15)}.pgm-hero,.pgm-filters,.pgm-table-head{border-radius:16px}.pgm-hero h1{font-size:var(--fs-18)}.pgm-subtitle{font-size:var(--fs-14)}.pgm-hero-actions,.pgm-btn{width:100%}.pgm-btn{justify-content:center;font-size:var(--fs-15)}.pgm-filters,.pgm-summary{grid-template-columns:1fr}.pgm-search{grid-column:auto}.pgm-card strong{font-size:var(--fs-20)}.pgm-table-wrap{max-height:calc(100dvh - 400px)}.pgm-table{min-width:960px}.pgm-table th{font-size:var(--fs-11);padding:6px}.pgm-table td{padding:6px}.pgm-table-head h2,.pgm-main-text,.pgm-table td,.pgm-empty{font-size:var(--fs-15)!important}}.pgm-table-wrap{overflow:auto;max-height:calc(100dvh - 340px)}.pgm-table{width:100%;min-width:1380px!important;table-layout:fixed}.pgm-table th:nth-child(1),.pgm-table td:nth-child(1){width:125px;min-width:125px}.pgm-table th:nth-child(2),.pgm-table td:nth-child(2){width:70px;min-width:70px}.pgm-table th:nth-child(3),.pgm-table td:nth-child(3){width:175px;min-width:175px}.pgm-table th:nth-child(4),.pgm-table td:nth-child(4){width:210px;min-width:210px}.pgm-table th:nth-child(5),.pgm-table td:nth-child(5){width:360px;min-width:360px}.pgm-table th:nth-child(6),.pgm-table td:nth-child(6),.pgm-table th:nth-child(7),.pgm-table td:nth-child(7),.pgm-table th:nth-child(9),.pgm-table td:nth-child(9),.pgm-table th:nth-child(10),.pgm-table td:nth-child(10){width:90px;min-width:90px}.pgm-table th:nth-child(8),.pgm-table td:nth-child(8){width:115px;min-width:115px}.pgm-table th:nth-child(11),.pgm-table td:nth-child(11){width:145px;min-width:145px;text-align:center}.pgm-table th,.pgm-table td{overflow:visible;text-overflow:clip}.pgm-table td:nth-child(2),.pgm-table td:nth-child(3),.pgm-table td:nth-child(4),.pgm-table td:nth-child(5){white-space:normal!important;word-break:break-word;overflow-wrap:anywhere}.pgm-table td:nth-child(6),.pgm-table td:nth-child(7),.pgm-table td:nth-child(8),.pgm-table td:nth-child(9),.pgm-table td:nth-child(10){white-space:nowrap;font-size:var(--fs-15)}.pgm-main-text,.pgm-sub-text{max-width:none;white-space:normal;word-break:break-word;overflow-wrap:anywhere}.pgm-main-text{font-size:var(--fs-16);line-height:1.3}.pgm-sub-text{font-size:var(--fs-14);line-height:1.35}.pgm-confirm-btn{width:100%;max-width:none;min-width:112px}.pgm-table td{height:auto;min-height:48px;vertical-align:middle}@media(min-width:1280px){.pgm-table{min-width:1380px!important}}@media(max-width:760px){.pgm-table{min-width:1320px!important}.pgm-table th:nth-child(5),.pgm-table td:nth-child(5){width:320px;min-width:320px}}.pgm-action-row{width:100%;display:grid;grid-template-columns:1fr;gap:6px;align-items:stretch;justify-items:stretch}.pgm-view-btn,.pgm-action-row .pgm-confirm-btn{width:100%;min-width:0;max-width:none;min-height:32px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 10px;font-family:inherit;font-size:var(--fs-13);font-weight:800;line-height:1;white-space:nowrap;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .12s ease,box-shadow .15s ease}.pgm-view-btn{border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8}.pgm-view-btn:hover:not(:disabled){background:#dbeafe;border-color:#93c5fd;box-shadow:0 6px 16px #2563eb1f}.pgm-view-btn:active:not(:disabled),.pgm-action-row .pgm-confirm-btn:active:not(:disabled){transform:translateY(1px)}.pgm-view-btn:disabled,.pgm-action-row .pgm-confirm-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.pgm-view-btn svg,.pgm-action-row .pgm-confirm-btn svg{flex:0 0 auto;width:14px;height:14px}.pgm-action-row .pgm-viewonly{width:100%;min-height:32px;border-radius:10px}.pgm-table th:nth-child(11),.pgm-table td:nth-child(11){width:165px;min-width:165px;text-align:center}@media(max-width:760px){.pgm-view-btn,.pgm-action-row .pgm-confirm-btn{min-height:34px;font-size:var(--fs-12);padding:0 8px}.pgm-table th:nth-child(11),.pgm-table td:nth-child(11){width:155px;min-width:155px}}.pgd-page{--pgd-bg: #f8fafc;--pgd-card: #ffffff;--pgd-border: #dbe3ef;--pgd-border-strong: #cbd5e1;--pgd-text: #111827;--pgd-muted: #6b7280;--pgd-primary: #2563eb;--pgd-primary-hover: #1d4ed8;--pgd-ok: #15803d;--pgd-ok-soft: #dcfce7;--pgd-warn: #b45309;--pgd-warn-soft: #fffbeb;min-height:100dvh;padding:14px;background:var(--pgd-bg);color:var(--pgd-text);font-family:var(--pps-font-main);font-size:var(--fs-15);line-height:1.45;display:flex;flex-direction:column;gap:12px}.pgd-page,.pgd-page *{box-sizing:border-box;min-width:0}.pgd-topbar{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:start;padding:12px;border:1px solid var(--pgd-border);border-radius:18px;background:var(--pgd-card);box-shadow:0 8px 24px #0f172a0e}.pgd-title-wrap h1{margin:0;font-size:var(--fs-20);font-weight:800;letter-spacing:-.02em}.pgd-title-wrap p{margin:4px 0 0;color:var(--pgd-muted);font-size:var(--fs-14)}.pgd-eyebrow{margin:0 0 4px!important;color:var(--pgd-primary-hover)!important;font-size:var(--fs-12)!important;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.pgd-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.pgd-btn{min-height:38px;border-radius:10px;border:1px solid var(--pgd-border-strong);background:#fff;color:var(--pgd-text);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;font-family:inherit;font-size:var(--fs-14);font-weight:800;cursor:pointer;white-space:nowrap}.pgd-btn:hover:not(:disabled){background:#f8fafc}.pgd-btn:disabled{opacity:.55;cursor:not-allowed}.pgd-btn-confirm{border-color:#86efac;background:#dcfce7;color:#15803d}.pgd-btn-confirm:hover:not(:disabled){background:#bbf7d0}.pgd-alert,.pgd-loading{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid #fde68a;background:var(--pgd-warn-soft);color:var(--pgd-warn);font-weight:800}.pgd-loading{border-color:#bfdbfe;background:#eff6ff;color:var(--pgd-primary-hover)}.sap-screen{border:1px solid #9aa97b;border-radius:12px;overflow:hidden;background:#e6efd1;box-shadow:0 18px 44px #0f172a1f}.sap-window-title{padding:9px 14px;background:linear-gradient(180deg,#8ab13d,#6d9a1e);color:#17320b;font-size:var(--fs-18);font-style:italic;font-weight:900;border-bottom:1px solid rgba(0,0,0,.18)}.sap-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:9px 12px;background:linear-gradient(180deg,#d8e7bd,#cddfae);border-bottom:1px solid #aeba8d}.sap-toolbar button{min-height:30px;border:1px solid #9aa97b;border-radius:4px;background:#edf4da;color:#1e2d12;font-family:inherit;font-weight:800;cursor:default}.sap-status{margin-left:auto;min-height:26px;border-radius:999px;display:inline-flex;align-items:center;padding:0 10px;font-size:var(--fs-12);font-weight:900}.sap-status.wait{background:#fef3c7;color:#92400e}.sap-status.done{background:#dcfce7;color:#166534}.sap-content{min-height:650px;padding:14px;background:#eef7dc;color:#233114}.sap-header-grid{max-width:980px;display:grid;grid-template-columns:300px 300px minmax(300px,1fr);gap:8px 16px;align-items:center}.sap-field{display:grid;grid-template-columns:105px minmax(0,1fr);gap:6px;align-items:center}.sap-field label,.sap-row label{color:#2e3b1b;font-size:var(--fs-14);font-weight:800;white-space:nowrap}.sap-field input,.sap-field select,.sap-row input{min-height:28px;border:1px solid #8e9a77;border-radius:2px;background:#f8fbef;color:#111827;padding:2px 6px;font-family:inherit;font-size:var(--fs-15);font-weight:700;box-shadow:inset 1px 1px 2px #0000001f}.sap-field input[readonly],.sap-row input[readonly]{cursor:default}.sap-field select:disabled,.sap-check input:disabled{opacity:1;cursor:default}.sap-wide,.sap-material{grid-column:span 1}.sap-material{grid-template-columns:70px 190px minmax(240px,1fr)}.sap-material span,.sap-operation-text span{color:#111827;font-weight:900;overflow-wrap:anywhere}.sap-operation-text{display:block;padding-left:4px}.sap-confirm-row{margin-top:24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.sap-confirm-type{width:340px;grid-template-columns:120px minmax(0,1fr)}.sap-check{display:inline-flex;align-items:center;gap:8px;color:#2e3b1b;font-weight:800}.sap-check input{width:22px;height:22px}.sap-section-title{width:290px;margin-top:12px;min-height:31px;border:1px solid #c2a90e;border-radius:4px 4px 0 0;display:flex;align-items:center;padding:0 12px;background:linear-gradient(180deg,#f5df43,#dfc600);color:#2d2b00;font-weight:900}.sap-table-box{width:520px;padding:7px;background:#eef7dcc7}.sap-row{display:grid;gap:4px;align-items:center;margin-bottom:4px}.sap-row-head{color:#2e3b1b;font-weight:800;margin-bottom:2px}.sap-qty-table .sap-row{grid-template-columns:150px 190px 44px}.sap-act-table .sap-row{grid-template-columns:150px 190px 44px 28px}.sap-input-yellow{background:#fff26a!important;border-color:#c2a90e!important}.sap-personnel-grid{max-width:850px;display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:8px 16px;padding:8px 0 0}@media(max-width:980px){.pgd-topbar{grid-template-columns:1fr}.pgd-actions{justify-content:stretch}.pgd-btn{flex:1 1 auto}.sap-content{overflow-x:auto}.sap-header-grid{min-width:880px}.sap-table-box{min-width:520px}}.btm-page,.btm-page *{box-sizing:border-box}.btm-page{color:#111827;width:100%;height:100%;background:#f8fafc;padding:16px 24px;overflow:hidden;display:flex;flex-direction:column;gap:12px;font-size:var(--fs-16);font-weight:400}.btm-page h2{margin:0;font-size:var(--fs-16);font-weight:700;color:#111827}.btm-panel{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;box-shadow:0 10px 26px #0000000f;display:flex;flex-direction:column;gap:12px;flex:1;min-height:0}.btm-filterbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}.btm-filter{min-width:200px}.btm-filter-label{font-size:var(--fs-16);font-weight:700;margin-bottom:6px;color:#111827}.btm-count{margin-left:auto;font-size:var(--fs-16);font-weight:400;color:#6b7280;white-space:nowrap}.btm-select{width:100%;height:42px;padding:0 12px;border-radius:12px;border:1px solid #e5e7eb;font-size:var(--fs-16);font-weight:400;background:#e8edf5;color:#111827;outline:none}.btm-select:focus{background:#fff;border-color:#93c5fd;box-shadow:0 0 0 3px #0369a11f}.btm-table-wrapper{flex:1;min-height:0;overflow:auto;border-radius:12px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.btm-table-wrapper::-webkit-scrollbar{width:10px;height:10px}.btm-table-wrapper::-webkit-scrollbar-track{background:transparent}.btm-table-wrapper::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:999px;border:2px solid transparent;background-clip:content-box}.btm-table-wrapper::-webkit-scrollbar-thumb:hover{background-color:#94a3b8}.btm-table-wrapper::-webkit-scrollbar:horizontal{height:8px}.btm-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.btm-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;border-bottom:1px solid #e5e7eb;font-size:var(--fs-16);font-weight:700;padding:10px;text-align:left;white-space:nowrap;color:#111827}.btm-table td{padding:10px;font-size:var(--fs-16);font-weight:400;white-space:nowrap;border-bottom:1px solid #f3f4f6;color:#111827}.btm-table tbody tr:hover{background:#f8fafc}.btm-table td .btm-select{height:42px;font-size:var(--fs-16);font-weight:400}.btm-col-no{width:60px}.btm-col-plant,.btm-col-mrp{width:90px}.btm-col-desc{width:220px}.btm-col-shorttext{width:320px}.btm-col-lunch{width:260px}@media(max-width:768px){.btm-page{padding:12px}.btm-filter{min-width:160px}.btm-count{margin-left:0}.btm-table thead th,.btm-table td{font-size:var(--fs-16);font-weight:inherit}}.lmm-page{--bg: #f8fafc;--card: #ffffff;--card-2: #f9fbfd;--surface: #f1f5f9;--border: #cbd5e1;--border-soft: #e2e8f0;--border-strong: #94a3b8;--text: #0f172a;--text-soft: #334155;--text-muted: #64748b;--primary: #0369a1;--primary-hover: #0284c7;--primary-soft: #e0f2fe;--primary-soft-2: #bae6fd;--primary-border: #7dd3fc;--green: #166534;--green-soft: #dcfce7;--green-border: #86efac;--red: #991b1b;--red-soft: #fee2e2;--red-soft-2: #fecaca;--red-border: #fca5a5;--amber: #92400e;--amber-soft: #fef3c7;--amber-border: #fcd34d;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 10px 30px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 46px rgba(2, 6, 23, .12);--radius-xs: 10px;--radius-sm: 12px;--radius: 16px;--radius-lg: 18px;--radius-xl: 22px;min-height:100%;padding:16px 24px 24px;background:var(--bg);color:var(--text);font-size:var(--fs-16);font-weight:400;line-height:1.45;box-sizing:border-box}.lmm-page *,.lmm-page *:before,.lmm-page *:after{box-sizing:border-box}.lmm-header-card,.lmm-section-card,.lmm-card{background:var(--card);border:1px solid rgba(203,213,225,.7);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.lmm-section-card,.lmm-card{padding:14px;margin-bottom:14px}.lmm-section-title{font-size:var(--fs-17);font-weight:800;color:var(--text);margin-bottom:12px;letter-spacing:.01em}.lmm-header-card{padding:18px;margin-bottom:14px;background:radial-gradient(circle at top right,rgba(186,230,253,.45),transparent 28%),linear-gradient(180deg,#fff,#fbfdff)}.lmm-header-main{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.lmm-page-title{font-size:var(--fs-28);line-height:1.1;font-weight:900;color:var(--text);letter-spacing:-.02em}.lmm-page-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-15);line-height:1.5;max-width:920px}.lmm-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.lmm-summary-card{min-width:0;border:1px solid var(--border-soft);border-radius:16px;padding:14px;background:linear-gradient(180deg,#fff,#f8fbff);display:flex;align-items:center;gap:12px}.lmm-summary-icon{width:48px;height:48px;min-width:48px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:var(--primary-soft);color:var(--primary);border:1px solid #bae6fd;font-size:var(--fs-20)}.lmm-summary-icon.success{background:var(--green-soft);color:var(--green);border-color:var(--green-border)}.lmm-summary-value{font-size:var(--fs-24);line-height:1;font-weight:900;color:var(--text);letter-spacing:-.02em}.lmm-summary-label{margin-top:4px;color:var(--text-muted);font-size:var(--fs-13);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.lmm-filter-grid{display:grid;grid-template-columns:170px 170px minmax(200px,1fr) minmax(220px,1fr) 170px;gap:12px;align-items:center}.lmm-create-grid{display:grid;grid-template-columns:minmax(280px,.95fr) minmax(320px,1.05fr);gap:14px;margin-bottom:14px}.lmm-line-select,.lmm-search-input,.lmm-table-search,.lmm-ms-search-input{width:100%;height:42px;border-radius:12px;border:1px solid var(--border);background:#f8fafc;padding:0 12px;font-size:var(--fs-15);font-weight:500;color:var(--text);outline:none;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease,transform .1s ease}.lmm-line-select:hover,.lmm-search-input:hover,.lmm-table-search:hover,.lmm-ms-search-input:hover{border-color:var(--border-strong);background:#fff}.lmm-line-select:focus,.lmm-search-input:focus,.lmm-table-search:focus,.lmm-ms-search-input:focus{background:#fff;border-color:var(--primary-hover);box-shadow:0 0 0 4px #0284c71a}.lmm-line-select::placeholder,.lmm-search-input::placeholder,.lmm-table-search::placeholder,.lmm-ms-search-input::placeholder{color:#94a3b8}.lmm-input-with-icon{position:relative;display:flex;align-items:center;min-width:0}.lmm-input-with-icon svg{position:absolute;left:12px;z-index:2;color:#64748b;pointer-events:none;font-size:var(--fs-16)}.lmm-input-with-icon .lmm-search-input,.lmm-input-with-icon .lmm-table-search{padding-left:38px}.lmm-input-with-icon.grow{flex:1 1 auto}.lmm-quick-lines{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.lmm-quick-line-chip{height:34px;padding:0 12px;border-radius:999px;border:1px solid #dbeafe;background:#eff6ff;color:#1d4ed8;font-size:var(--fs-14);font-weight:700;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .1s ease}.lmm-quick-line-chip:hover{background:#dbeafe;border-color:#93c5fd;transform:translateY(-1px)}.lmm-line-info-card{border:1px solid var(--border-soft);border-radius:16px;background:linear-gradient(180deg,#fff,#f8fbff);padding:14px}.lmm-line-info-title{font-size:var(--fs-18);font-weight:800;color:var(--text);margin-bottom:6px}.lmm-line-info-meta{display:flex;flex-wrap:wrap;gap:8px 14px;color:var(--text-muted);font-size:var(--fs-14);font-weight:600}.lmm-empty-panel{min-height:110px;border:1px dashed var(--border);border-radius:16px;background:#fbfdff;color:var(--text-muted);display:flex;align-items:center;justify-content:center;padding:16px;text-align:center;font-size:var(--fs-15);font-weight:700}.lmm-search{position:relative;width:100%;min-width:0}.lmm-material-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:40;background:#fff;border:1px solid var(--border-soft);border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;max-height:300px;overflow-y:auto}.lmm-material-item{padding:11px 12px;cursor:pointer;border-bottom:1px solid #f1f5f9;color:var(--text);transition:background .12s ease}.lmm-material-item:last-child{border-bottom:none}.lmm-material-item:hover{background:#f8fafc}.lmm-material-item-title{font-size:var(--fs-14);font-weight:800;color:var(--text)}.lmm-material-item-desc{margin-top:3px;font-size:var(--fs-13);color:var(--text-muted);line-height:1.4}.lmm-chip-header{margin-top:12px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;color:var(--text-soft);font-size:var(--fs-14);font-weight:800}.lmm-link-btn{border:none;background:transparent;color:var(--primary);font-size:var(--fs-14);font-weight:800;cursor:pointer;padding:0}.lmm-link-btn:hover{color:var(--primary-hover);text-decoration:underline}.lmm-selected-materials{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.lmm-selected-chip{display:inline-flex;align-items:center;gap:8px;max-width:100%;border-radius:999px;padding:7px 10px;border:1px solid #dbeafe;background:#eff6ff;color:#1e3a8a;font-weight:800;font-size:var(--fs-14);font-family:var(--pps-font-mono)}.lmm-selected-chip-text{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lmm-chip-remove{cursor:pointer;font-style:normal;height:20px;width:20px;min-width:20px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:#64748b;font-size:var(--fs-14);font-weight:700;transition:background .15s ease,color .15s ease}.lmm-chip-remove:hover{background:#0284c71f;color:var(--text)}.lmm-create-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.lmm-create-hint{color:var(--text-muted);font-size:var(--fs-14);font-weight:600}.lmm-create-meta{display:flex;flex-wrap:wrap;gap:10px 16px;color:var(--text-soft);font-size:var(--fs-14);font-weight:700}.lmm-btn-primary,.lmm-btn-secondary,.lmm-btn-excel,.lmm-ms-btn{height:42px;padding:0 16px;border-radius:12px;cursor:pointer;font-weight:800;font-size:var(--fs-14);display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .1s ease,box-shadow .15s ease,color .15s ease}.lmm-btn-primary:hover,.lmm-btn-secondary:hover,.lmm-btn-excel:hover,.lmm-ms-btn:hover{transform:translateY(-1px)}.lmm-btn-primary:active,.lmm-btn-secondary:active,.lmm-btn-excel:active,.lmm-ms-btn:active{transform:translateY(0)}.lmm-btn-primary{border:1px solid var(--primary-border);background:var(--primary);color:#fff;box-shadow:0 8px 20px #0369a129}.lmm-btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.lmm-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.lmm-btn-secondary{border:1px solid var(--border-soft);background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}.lmm-btn-secondary:hover{background:#f8fafc;border-color:var(--border)}.lmm-btn-secondary:disabled{opacity:.6;cursor:not-allowed;transform:none}.lmm-btn-excel{border:1px solid var(--border-soft);background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}.lmm-btn-excel:hover{background:var(--primary-soft);border-color:var(--primary-border)}.lmm-btn-excel:disabled{opacity:.55;cursor:not-allowed;transform:none}.lmm-toolbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.lmm-table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.lmm-card{padding:12px;margin-bottom:0}.lmm-table-wrap{width:100%;overflow:auto;border-radius:14px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.lmm-table-wrap::-webkit-scrollbar{width:8px;height:8px}.lmm-table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.lmm-table-wrap::-webkit-scrollbar-thumb:hover{background:#94a3b8}.lmm-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.lmm-table thead th{position:sticky;top:0;z-index:3;background:#f8fafc;font-size:var(--fs-14);font-weight:800;padding:12px;border-bottom:1px solid var(--border-soft);white-space:nowrap;text-align:left;color:var(--text-soft);letter-spacing:.01em}.lmm-table thead th:first-child{border-top-left-radius:12px}.lmm-table thead th:last-child{border-top-right-radius:12px}.lmm-table tbody td{padding:12px;font-size:var(--fs-14);font-weight:500;border-bottom:1px solid #f1f5f9;vertical-align:middle;color:var(--text);background:#fff}.lmm-table tbody tr:hover td{background:#fbfdff}.lmm-table tbody tr:last-child td:first-child{border-bottom-left-radius:12px}.lmm-table tbody tr:last-child td:last-child{border-bottom-right-radius:12px}.lmm-empty-table{padding:28px 16px;text-align:center;color:var(--text-muted);font-weight:800;font-size:var(--fs-15)}.lmm-mono{font-family:var(--pps-font-mono);font-weight:800;letter-spacing:.01em}.lmm-line-cell{min-width:0}.lmm-line-cell-title{font-size:var(--fs-14);font-weight:800;color:var(--text);line-height:1.35}.lmm-line-cell-sub{margin-top:3px;font-size:var(--fs-12);color:var(--text-muted);font-weight:700;white-space:normal}.lmm-desc-cell{max-width:420px;white-space:normal;line-height:1.45;color:var(--text-soft)}.lmm-cells{max-width:320px}.lmm-machine-tags{display:flex;flex-wrap:wrap;gap:6px}.lmm-machine-tag{display:inline-flex;align-items:center;height:28px;padding:0 10px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;color:var(--text-soft);font-size:var(--fs-12);font-weight:800;font-family:var(--pps-font-mono)}.lmm-machine-more{display:inline-flex;align-items:center;height:28px;padding:0 10px;border-radius:999px;background:#eff6ff;border:1px solid #dbeafe;color:#1d4ed8;font-size:var(--fs-12);font-weight:800}.lmm-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.lmm-badge{height:28px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:800;display:inline-flex;align-items:center;justify-content:center;letter-spacing:.02em}.lmm-active{background:var(--green-soft);color:var(--green);border:1px solid var(--green-border)}.lmm-inactive{background:var(--red-soft);color:var(--red);border:1px solid var(--red-border)}.lmm-icon-btn{height:36px;width:36px;min-width:36px;padding:0;border-radius:10px;border:1px solid var(--border-soft);background:#fff;color:var(--text-soft);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:background .15s ease,border-color .15s ease,transform .1s ease,color .15s ease}.lmm-icon-btn:hover{background:#f8fafc;border-color:var(--border);transform:translateY(-1px);color:var(--text)}.lmm-icon-btn:active{transform:translateY(0)}.lmm-icon-btn.danger:hover{background:var(--red-soft);border-color:var(--red-border);color:var(--red)}.lmm-icon-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.lmm-loading{padding:14px 10px 6px;text-align:center;color:var(--text-muted);font-weight:800;font-size:var(--fs-14)}.lmm-modal-backdrop{position:fixed;inset:0;background:#0f172a61;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.lmm-modal{width:min(900px,100%);max-height:min(88vh,900px);display:flex;flex-direction:column;background:#fff;border-radius:20px;border:1px solid var(--border-soft);box-shadow:0 24px 70px #0206173d;overflow:hidden}.lmm-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:#f8fafc;border-bottom:1px solid var(--border-soft)}.lmm-modal-title{font-size:var(--fs-18);font-weight:900;color:var(--text);line-height:1.3}.lmm-modal-subtitle{font-size:var(--fs-14);font-weight:700;color:var(--text-muted)}.lmm-modal-body{padding:16px;overflow:auto}.lmm-modal-footer{padding:14px 16px;border-top:1px solid var(--border-soft);display:flex;justify-content:flex-end;gap:10px;background:#fff}.lmm-ms-top{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.lmm-ms-help{font-size:var(--fs-14);color:var(--text-muted);font-weight:700}.lmm-ms-search{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.lmm-ms-search-input{flex:1;min-width:240px}.lmm-ms-count{font-size:var(--fs-13);color:var(--text-soft);opacity:.95;white-space:nowrap;font-weight:700}.lmm-ms-actions{display:flex;gap:8px;flex-wrap:wrap}.lmm-ms-btn{height:38px;padding:0 12px;border-radius:12px;border:1px solid var(--border-soft);background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}.lmm-ms-btn:hover{background:#f8fafc;border-color:var(--border)}.lmm-ms-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.lmm-ms-btn.danger{background:var(--red-soft);border-color:var(--red-soft-2);color:var(--red)}.lmm-ms-btn.danger:hover{background:var(--red-soft-2);border-color:var(--red-border)}.lmm-ms-list{border:1px solid var(--border-soft);border-radius:16px;background:#fff;max-height:360px;overflow:auto;padding:8px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.lmm-ms-list::-webkit-scrollbar{width:8px}.lmm-ms-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.lmm-ms-item{display:flex;align-items:center;gap:10px;padding:11px 10px;border-radius:12px;cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid transparent;transition:background .12s ease,border-color .12s ease}.lmm-ms-item:hover{background:#f8fafc;border-color:#eef2f7}.lmm-ms-item.on{background:var(--primary-soft);border-color:#bae6fd}.lmm-ms-item input{width:18px;height:18px;accent-color:var(--primary-hover)}.lmm-ms-code{font-family:var(--pps-font-mono);font-size:var(--fs-14);font-weight:800;color:var(--text)}.lmm-ms-empty{padding:18px 14px;color:var(--text-muted);font-weight:800;text-align:center;font-size:var(--fs-14)}.lmm-toolbar{display:grid;grid-template-columns:150px 150px 440px 1fr 170px;gap:12px;align-items:end;margin-bottom:12px;background:var(--card);border:1px solid rgba(203,213,225,.7);border-radius:var(--radius-lg);padding:12px;box-shadow:var(--shadow)}.lmm-table-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;background:var(--card);border:1px solid rgba(203,213,225,.7);border-radius:var(--radius-lg);padding:12px;box-shadow:var(--shadow)}@media(max-width:1280px){.lmm-summary-grid,.lmm-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:980px){.lmm-page{padding:14px 16px 20px}.lmm-header-main{flex-direction:column;align-items:stretch}.lmm-create-grid{grid-template-columns:1fr}.lmm-filter-grid{grid-template-columns:1fr 1fr}.lmm-table-toolbar{flex-direction:column;align-items:stretch}.lmm-toolbar-actions{width:100%}.lmm-toolbar-actions>*{flex:1 1 auto}.lmm-create-actions{flex-direction:column;align-items:stretch}.lmm-toolbar{grid-template-columns:1fr 1fr;align-items:stretch}.lmm-table-actions{flex-direction:column;align-items:stretch}}@media(max-width:640px){.lmm-page{padding:12px}.lmm-page-title{font-size:var(--fs-24)}.lmm-page-subtitle{font-size:var(--fs-14)}.lmm-summary-grid,.lmm-filter-grid{grid-template-columns:1fr}.lmm-line-info-meta,.lmm-create-meta{flex-direction:column;gap:6px}.lmm-selected-chip-text{max-width:180px}.lmm-ms-list{max-height:44vh}.lmm-ms-search{flex-direction:column;align-items:stretch}.lmm-ms-search-input{min-width:0;width:100%}.lmm-modal{width:100%;max-height:92vh;border-radius:16px}.lmm-modal-header,.lmm-modal-body,.lmm-modal-footer{padding-left:12px;padding-right:12px}.lmm-toolbar{grid-template-columns:1fr}}.lmd-page{padding:24px;background:#f8fafc}.lmd-toolbar{display:grid;grid-template-columns:360px 1fr auto;align-items:center;gap:16px;margin-bottom:20px}.lmd-line-select{height:40px;padding:0 12px;border-radius:8px;border:1px solid #9ca3af;font-size:var(--fs-16);font-weight:500;background:#e8edf5;color:#111827;min-width:0}.lmd-search{position:relative;width:100%;max-width:620px}.lmd-search-input{width:100%;height:40px;padding:0 14px;border-radius:8px;border:1px solid #9ca3af;font-size:var(--fs-16);background:#e8edf5;color:#111827}.lmd-search-input::placeholder{color:#6b7280}.lmd-mold-dropdown{position:absolute;top:44px;width:100%;max-height:260px;overflow-y:auto;z-index:10;background:#fff;border:1px solid #cbd5e1;border-radius:8px;box-shadow:0 10px 20px #00000014}.lmd-mold-item{padding:8px 12px;font-size:var(--fs-16);cursor:pointer}.lmd-mold-item:hover{background:#e8edf5}.lmd-btn-primary{height:40px;padding:0 48px;font-size:var(--fs-15);font-weight:600;border-radius:8px;border:none;cursor:pointer;background:#e0f2fe;color:#0369a1;white-space:nowrap}.lmd-btn-primary:hover{background:#bae6fd}.lmd-btn-primary:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}.lmd-selected-molds{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 12px}.lmd-selected-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#eef2f7;font-size:var(--fs-14)}.lmd-chip-remove{cursor:pointer;font-weight:700}.lmd-table-actions{display:grid;grid-template-columns:1fr auto;align-items:center;gap:16px;margin:12px 0 16px}.lmd-table-search{height:36px;padding:0 12px;border-radius:8px;border:1px solid #9ca3af;background:#f1f5f9;font-size:var(--fs-14);width:100%;max-width:480px;min-width:0}.lmd-btn-excel{display:inline-flex;align-items:center;gap:8px;height:36px;width:200px;padding:0 14px;border-radius:8px;border:1px solid #86efac;background:#ecfdf5;color:#166534;font-weight:600;font-size:var(--fs-14);cursor:pointer}.lmd-btn-excel:hover{background:#d1fae5}.lmd-card{background:#fff;border-radius:16px;padding:16px;max-height:calc(100vh - 260px);overflow:auto;box-shadow:0 8px 24px #0000000f;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.lmd-card::-webkit-scrollbar{width:8px;height:8px}.lmd-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.lmd-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.lmd-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.lmd-table th{position:sticky;top:0;z-index:2;text-align:left;font-size:var(--fs-15);font-weight:600;padding:12px 10px;background:#f8fafc;white-space:nowrap}.lmd-table td{padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap}.lmd-table tr:hover{background:#f8fafc}.lmd-table td:last-child{text-align:center;width:56px}.lmd-mono{font-family:var(--pps-font-mono)}.lmd-badge{padding:4px 12px;border-radius:999px;font-size:var(--fs-14);font-weight:600}.lmd-active{background:#dcfce7;color:#166534}.lmd-inactive{background:#fee2e2;color:#991b1b}.lmd-icon-btn{border:none;background:transparent;cursor:pointer;color:#ef4444;font-size:var(--fs-16)}.lmd-icon-btn:hover{opacity:.7}.lmd-loading{text-align:center;padding:12px}.mg-page{width:100%;height:100%;padding:24px;box-sizing:border-box;background:#fff;overflow:hidden}.mg-page h2{font-size:var(--fs-24);font-weight:600;margin-bottom:16px}.mg-panel{background:#fff;border-radius:16px;padding:16px;display:flex;flex-direction:column;height:100%;min-height:0;box-shadow:0 10px 30px #00000014}.mg-search-group{margin-bottom:16px}.mg-search-group input{width:100%;height:36px;padding:0 16px;border-radius:8px;border:1px solid #9ca3af;font-size:var(--fs-16);background:#e8edf5}.mg-search-group input:focus{outline:none;background:#fff}.mg-table-wrapper{flex:1;overflow:auto;border-radius:12px}.mg-table-wrapper::-webkit-scrollbar{width:8px;height:8px}.mg-table-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.mg-table-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b8}.mg-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.mg-table thead th{position:sticky;top:0;background:#e8edf5;font-size:var(--fs-15);font-weight:600;padding:12px 10px;text-align:left;border:none;z-index:1}.mg-table td{padding:10px;font-size:var(--fs-15);white-space:nowrap;border:none}.mg-table tbody tr{border-bottom:1px solid #e5e7eb}.mg-table tbody tr:last-child{border-bottom:none}.mg-table tbody tr:hover{background:#f8fafc}.mg-col-site{width:100px}.mg-col-area,.mg-col-line,.mg-col-cell{width:120px}.mg-col-plant{width:80px}.mg-col-mrp{width:100px}.mg-col-oee{width:140px}.mg-col-line-name{width:360px}@media(max-width:768px){.mg-page{padding:12px}.mg-page h2{font-size:var(--fs-20)}.mg-table thead th,.mg-table td{font-size:var(--fs-14)}}:root{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-soft: #e0f2fe;--primary-soft-2: #bae6fd;--red: #991b1b;--red-bg: #fee2e2;--red-border: #fecaca;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--shadow: 0 8px 24px rgba(0, 0, 0, .06);--radius: 16px;--radius-sm: 8px}*{box-sizing:border-box;font-family:var(--pps-font-main);font-size:var(--fs-16);font-weight:400}.mt-page{padding:24px;background:var(--bg);height:100%;color:var(--text);font-size:var(--fs-16);font-weight:400}.mt-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px}.mt-sub{font-size:var(--fs-16);font-weight:700;color:var(--muted);display:flex;gap:8px;align-items:center;flex-wrap:wrap}.mt-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:var(--fs-16);font-weight:700}.mt-badge.ro{background:var(--gray-100);color:#334155;border:1px solid var(--gray-200)}.mt-toolbar{display:grid;grid-template-columns:260px 260px 1fr auto;align-items:center;gap:16px;margin-bottom:20px}.mt-select{height:40px;padding:0 12px;border-radius:var(--radius-sm);border:1px solid var(--gray-400);font-size:var(--fs-16);font-weight:400;background:#e8edf5;color:var(--text);min-width:0;outline:none}.mt-select:focus{background:var(--card);border-color:var(--primary)}.mt-search{position:relative;width:100%;max-width:620px;display:flex;align-items:center;gap:10px}.mt-search svg{opacity:.7}.mt-input{width:100%;height:40px;padding:0 14px;border-radius:var(--radius-sm);border:1px solid var(--gray-400);font-size:var(--fs-16);font-weight:400;background:#e8edf5;color:var(--text);outline:none}.mt-input::placeholder{color:var(--muted);font-size:var(--fs-16);font-weight:400}.mt-input:focus{background:var(--card);border-color:var(--primary)}.mt-table-actions{display:grid;grid-template-columns:1fr auto;align-items:center;gap:16px;margin:12px 0 16px}.mt-table-search{height:36px;padding:0 12px;border-radius:var(--radius-sm);border:1px solid var(--gray-400);background:var(--gray-100);font-size:var(--fs-16);font-weight:400;width:100%;max-width:480px;min-width:0}.mt-btn-excel{display:inline-flex;align-items:center;gap:8px;height:36px;padding:0 14px;border-radius:var(--radius-sm);border:1px solid #86efac;background:#ecfdf5;color:#166534;font-weight:700;font-size:var(--fs-16);cursor:pointer;white-space:nowrap}.mt-btn-excel:hover{background:#d1fae5}.mt-btn-excel:disabled{opacity:.6;cursor:not-allowed}.mt-error{margin:12px 0 16px;padding:10px 14px;border:1px solid var(--red-border);background:#fff1f2;color:var(--red);border-radius:12px;font-weight:700;font-size:var(--fs-16)}.mt-card{background:var(--card);border-radius:var(--radius);padding:16px;max-height:calc(100vh - 260px);overflow:auto;box-shadow:var(--shadow);border:1px solid var(--gray-200);scrollbar-width:thin;scrollbar-color:var(--border) transparent}.mt-card::-webkit-scrollbar{width:8px;height:8px}.mt-card::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.mt-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.mt-card::-webkit-scrollbar-corner{background:transparent}.mt-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.mt-table th{position:sticky;top:0;z-index:2;text-align:left;font-size:var(--fs-16);font-weight:700;padding:12px 10px;background:var(--gray-50);white-space:nowrap;border-bottom:1px solid var(--gray-200)}.mt-table td{padding:10px;font-size:var(--fs-16);font-weight:400;border-bottom:1px solid #e5e7eb;white-space:nowrap}.mt-table tr:hover{background:var(--gray-50)}.mt-table td:last-child{text-align:right;width:110px}.mt-icon-btn{height:36px;padding:0 12px;border-radius:10px;border:1px solid var(--gray-200);background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:var(--fs-16);color:var(--text);white-space:nowrap}.mt-icon-btn:hover{background:var(--primary-soft);border-color:#7dd3fc}.mt-icon-btn:disabled{opacity:.6;cursor:not-allowed}.mt-loading,.mt-empty{text-align:center;padding:12px;color:var(--muted);font-weight:700;font-size:var(--fs-16)}.mt-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:18px;z-index:999}.mt-modal{width:min(980px,100%);background:var(--card);border-radius:18px;border:1px solid var(--gray-200);box-shadow:0 20px 60px #0003;overflow:hidden}.mt-modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.mt-modal-title{font-size:var(--fs-16);font-weight:700;color:var(--text)}.mt-modal-sub{color:var(--muted);font-size:var(--fs-16);font-weight:700;margin-top:4px}.mt-close{height:36px;width:36px;border-radius:12px;border:1px solid var(--gray-200);background:var(--card);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-16);font-weight:700}.mt-close:hover{background:var(--gray-50);border-color:#7dd3fc}.mt-form{padding:14px;font-size:var(--fs-16);font-weight:400}.mt-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.mt-field{display:grid;gap:6px}.mt-label{font-size:var(--fs-16);font-weight:700;color:var(--text)}.mt-form .mt-input{height:40px;border-radius:var(--radius-sm);border:1px solid var(--gray-400);background:#e8edf5;padding:0 12px;font-size:var(--fs-16);font-weight:400}.mt-form .mt-input:focus{background:var(--card);border-color:var(--primary)}.mt-actions{margin-top:14px;display:flex;justify-content:flex-end;gap:10px}.mt-hint{margin-top:10px;font-size:var(--fs-16);font-weight:700;color:var(--muted)}@media(max-width:980px){.mt-grid{grid-template-columns:1fr}}@media(max-width:980px){.mt-toolbar{grid-template-columns:1fr}.mt-search{max-width:100%}.mt-grid{grid-template-columns:1fr}.mt-table-actions{grid-template-columns:1fr;justify-items:start}.mt-btn-excel{width:100%}}.mt-actions{margin-top:18px;padding-top:14px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px}.mt-actions button{height:40px;min-width:160px;padding:0 24px;border-radius:10px;font-size:var(--fs-16);font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.mt-actions .mt-btn.primary{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;font-size:var(--fs-16);font-weight:700}.mt-actions .mt-btn.primary:hover{background:#bae6fd;border-color:#7dd3fc}.mt-actions .mt-btn.ghost{border:1px solid #e5e7eb;background:#fee2e2;color:#991b1b;font-size:var(--fs-16);font-weight:700}.mt-actions .mt-btn.ghost:hover{background:#fecaca;border-color:#fca5a5}.mt-actions .mt-btn:disabled{opacity:.6;cursor:not-allowed}.dtm-page{padding:16px 24px;height:100%;background:#f8fafc;display:flex;flex-direction:column;color:#111827}.dtm-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;min-width:0}.dtm-title{display:flex;align-items:baseline;gap:8px;font-size:var(--fs-16);font-weight:600;color:#111827;min-width:0}.dtm-scope-label{font-size:var(--fs-12);font-weight:600;color:#6b7280;white-space:nowrap}.dtm-header-right{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end;flex-wrap:nowrap;min-width:0}.dtm-scope{display:flex;align-items:center;gap:8px;flex:0 0 auto}.dtm-select{height:32px;padding:0 10px;border-radius:10px;border:1px solid #d1d5db;font-size:var(--fs-13);font-weight:600;background:#fff;color:#111827;outline:none}.dtm-select:focus{border-color:#0284c7;box-shadow:0 0 0 2px #0369a126}.dtm-search{height:44px;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:6px 10px;flex:1 1 520px;min-width:360px;max-width:760px;box-shadow:0 10px 26px #0000000f}.dtm-search input{width:100%;height:34px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-15);font-weight:500;color:#111827;outline:none}.dtm-search input:focus{background:#fff;border-color:#0284c7;box-shadow:0 0 0 3px #0369a11a}.dtm-search input:disabled{opacity:.6;cursor:not-allowed}.dtm-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;flex:0 0 auto;height:44px;width:160px;min-width:140px;padding:0 18px;border-radius:12px;border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;font-size:var(--fs-15);font-weight:600;white-space:nowrap;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .1s ease;box-shadow:0 1px #0f172a0a}.dtm-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc;transform:translateY(-1px)}.dtm-btn-primary:active{transform:translateY(0)}.dtm-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.dtm-layout{flex:1;display:grid;grid-template-columns:360px 1fr;gap:12px;min-height:0}.dtm-materials{background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 10px 26px #0000000f;padding:12px;display:flex;flex-direction:column;min-height:0}.dtm-section-title{font-size:var(--fs-16);font-weight:600;color:#111827;margin-bottom:8px}.dtm-material-list{flex:1;overflow-y:auto;border-top:1px solid #f1f5f9;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.dtm-material-list::-webkit-scrollbar{width:8px}.dtm-material-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.dtm-material-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dtm-material-item{padding:10px 12px;border-bottom:1px solid #f1f5f9;cursor:pointer}.dtm-material-item:hover{background:#f8fafc}.dtm-material-item.active{background:#e0f2fe;border-left:4px solid #0284c7}.dtm-mat-no{font-size:var(--fs-15);font-weight:600;color:#111827}.dtm-mat-desc{font-size:var(--fs-13);font-weight:500;color:#6b7280;margin-top:2px}.dtm-reasons{background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 10px 26px #0000000f;padding:12px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.dtm-reasons-inner{flex:1;min-height:0;overflow-y:auto;padding-right:2px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.dtm-reasons-inner::-webkit-scrollbar{width:8px}.dtm-reasons-inner::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.dtm-reasons-inner::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dtm-category{margin-bottom:16px}.dtm-category-title{font-size:var(--fs-15);font-weight:600;color:#111827;margin-bottom:8px}.dtm-reason-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px}.dtm-reason-item{display:flex;align-items:center;gap:8px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:8px 10px;font-size:var(--fs-14);font-weight:500;color:#111827;cursor:pointer;transition:background .15s ease,border-color .15s ease}.dtm-reason-item input{cursor:pointer}.dtm-reason-item:hover{background:#f8fafc;border-color:#cbd5e1}.dtm-empty{padding:16px;text-align:center;color:#6b7280;font-size:var(--fs-13);font-weight:500}.dtm-loading{position:fixed;bottom:16px;right:16px;background:#e0f2fe;color:#0f172a;padding:10px 14px;border-radius:12px;font-size:var(--fs-13);font-weight:600;border:1px solid #bae6fd;box-shadow:0 10px 26px #0000001f}@media(max-width:1100px){.dtm-layout{grid-template-columns:320px 1fr}}@media(max-width:860px){.dtm-layout{grid-template-columns:1fr}.dtm-materials{max-height:280px}.dtm-header-right{flex-wrap:wrap;justify-content:flex-start}.dtm-search{flex:1 1 100%;min-width:0;max-width:none}.dtm-btn-primary{width:100%;min-width:0}}@media(max-width:640px){.dtm-header,.dtm-header-right{flex-direction:column;align-items:stretch}.dtm-scope,.dtm-select{width:100%}.dtm-search{min-width:0;width:100%}}.dts-page{padding:16px 24px;height:100%;background:#f8fafc;color:#111827}.dts-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;min-width:0}.dts-title{margin:0;display:flex;align-items:baseline;gap:10px;font-size:var(--fs-16);font-weight:600;color:#111827;min-width:0}.dts-scope{display:inline-flex;gap:8px;flex-wrap:wrap;align-items:center}.dts-actions{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end;flex-wrap:nowrap;min-width:0}.dts-scope-select{display:flex;align-items:center;gap:8px;flex:0 0 auto}.dts-select{height:32px;padding:0 10px;border-radius:10px;border:1px solid #d1d5db;background:#fff;color:#111827;font-size:var(--fs-13);font-weight:600;outline:none}.dts-select:focus{border-color:#0284c7;box-shadow:0 0 0 2px #0369a126}.dts-search{height:44px;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:6px 10px;flex:1 1 520px;min-width:320px;max-width:760px;box-shadow:0 10px 26px #0000000f}.dts-search-icon{color:#334155}.dts-search input{width:100%;height:34px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;outline:none;font-size:var(--fs-15);font-weight:600;color:#111827}.dts-search input:focus{background:#fff;border-color:#0284c7;box-shadow:0 0 0 3px #0369a11a}.dts-search input:disabled{opacity:.6;cursor:not-allowed}.dts-search input::placeholder{color:#94a3b8;font-weight:500}.dts-btn-primary,.dts-btn-ghost,.dts-btn-icon,.dts-icon-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:160px;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .1s ease,box-shadow .15s ease,color .15s ease}.dts-btn-primary:hover,.dts-btn-ghost:hover,.dts-icon-btn:hover,.dts-btn-icon:hover{transform:translateY(-1px)}.dts-btn-primary:active,.dts-btn-ghost:active,.dts-icon-btn:active,.dts-btn-icon:active{transform:translateY(0)}.dts-btn-primary:focus-visible,.dts-btn-ghost:focus-visible,.dts-btn-icon:focus-visible,.dts-icon-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #0369a11f}.dts-btn-primary:disabled,.dts-btn-ghost:disabled,.dts-btn-icon:disabled,.dts-icon-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.dts-btn-primary2,.dts-btn-ghost2{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .1s ease,box-shadow .15s ease,color .15s ease}.dts-btn-primary2:hover,.dts-btn-ghost2:hover{transform:translateY(-1px)}.dts-btn-primary2:active,.dts-btn-ghost2:active{transform:translateY(0)}.dts-btn-primary2:focus-visible,.dts-btn-ghost2:focus-visible{outline:none;box-shadow:0 0 0 3px #0369a11f}.dts-btn-primary2:disabled,.dts-btn-ghost2:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.dts-btn-primary{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;height:44px;padding:0 16px;border-radius:12px;font-size:var(--fs-14);font-weight:600}.dts-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.dts-btn-ghost{border:1px solid #e5e7eb;background:#fff;color:#0f172a;height:34px;padding:0 12px;border-radius:10px;font-size:var(--fs-13);font-weight:600;box-shadow:0 1px #0f172a0a}.dts-btn-ghost:hover{background:#f8fafc;border-color:#cbd5e1}.dts-btn-primary2{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;height:44px;padding:0 16px;border-radius:12px;font-size:var(--fs-14);font-weight:600}.dts-btn-primary2:hover{background:#bae6fd;border-color:#7dd3fc}.dts-btn-ghost2{border:1px solid #e5e7eb;background:#fff;color:#0f172a;height:44px;padding:0 12px;border-radius:10px;font-size:var(--fs-13);font-weight:600;box-shadow:0 1px #0f172a0a}.dts-btn-ghost2:hover{background:#fcfaf8;border-color:#cbd5e1}.dts-btn-icon{border:none;background:transparent;color:#334155;height:34px;width:34px;border-radius:10px}.dts-btn-icon:hover{background:#f8fafc;color:#0f172a}.dts-icon-btn{height:36px;width:36px;min-width:36px;padding:0;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#0f172a;box-shadow:0 1px #0f172a0a}.dts-icon-btn:hover{background:#f8fafc;border-color:#cbd5e1}.dts-icon-btn.danger{border-color:#fecaca;background:#fff1f2;color:#991b1b}.dts-icon-btn.danger:hover{background:#fee2e2;border-color:#fca5a5}.dts-grid{display:grid;grid-template-columns:repeat(2,minmax(320px,1fr));gap:16px}.dts-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 10px 26px #0000000f;padding:12px}.dts-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.dts-cat-name{font-size:var(--fs-18);font-weight:700;color:#111827}.dts-card-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.dts-cat-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.dts-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#f1f5f9;border:1px solid #e5e7eb;font-size:var(--fs-12);font-weight:600;color:#0f172a}.dts-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:600;border:1px solid #e5e7eb;background:#fff;color:#0f172a}.dts-pill.on{border-color:#bbf7d0;background:#dcfce7;color:#166534}.dts-pill.off{border-color:#e5e7eb;background:#f1f5f9;color:#6b7280}.dts-muted{color:#6b7280;font-size:var(--fs-12);font-weight:600}.dts-reason-list{border-top:1px solid #f1f5f9;padding-top:10px;display:flex;flex-direction:column;gap:10px}.dts-reason-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid #e5e7eb;background:#fff;border-radius:14px;padding:12px;box-shadow:0 1px #0f172a0a}.dts-reason-left{min-width:0}.dts-reason-text{font-size:var(--fs-18);font-weight:500;color:#111827;line-height:1.25}.dts-reason-sub{margin-top:6px;display:flex;flex-wrap:wrap;gap:8px}.dts-reason-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end;flex:0 0 auto}.dts-empty{padding:12px;text-align:center;color:#6b7280;font-size:var(--fs-13);font-weight:600}.dts-modal-backdrop{position:fixed;inset:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.dts-modal{width:100%;max-width:520px;background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 18px 55px #00000040;overflow:hidden}.dts-modal-head{padding:12px 14px;border-bottom:1px solid #eef2f7;display:flex;align-items:center;justify-content:space-between;background:#f8fafc}.dts-modal-title{font-size:var(--fs-14);font-weight:700;color:#111827}.dts-form{padding:14px;display:flex;flex-direction:column;gap:10px}.dts-field label{display:block;font-size:var(--fs-13);font-weight:600;color:#111827;margin-bottom:6px}.dts-field input,.dts-field select{width:100%;height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;outline:none;font-size:var(--fs-15);font-weight:600;color:#111827}.dts-field input:focus,.dts-field select:focus{background:#fff;border-color:#0284c7;box-shadow:0 0 0 3px #0369a11a}.dts-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.dts-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:8px}.dts-loading{position:fixed;bottom:16px;right:16px;background:#e0f2fe;color:#0f172a;padding:10px 14px;border-radius:12px;font-size:var(--fs-13);font-weight:600;border:1px solid #bae6fd;box-shadow:0 10px 26px #0000001f}@media(max-width:1200px){.dts-grid{grid-template-columns:repeat(2,minmax(320px,1fr))}}@media(max-width:860px){.dts-actions{flex-wrap:wrap;justify-content:flex-start}.dts-search{flex:1 1 100%;min-width:0;max-width:none}.dts-btn-primary{width:100%}}@media(max-width:760px){.dts-grid{grid-template-columns:1fr}}@media(max-width:640px){.dts-header,.dts-actions{flex-direction:column;align-items:stretch}.dts-scope-select,.dts-select{width:100%}.dts-row{grid-template-columns:1fr}}.hdm-page{padding:16px 24px;height:100%;background:#f8fafc;display:flex;flex-direction:column;color:#111827}.hdm-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:12px}.hdm-title{font-size:var(--fs-16);font-weight:700;color:#111827}.hdm-scope-label{margin-left:10px;font-size:var(--fs-12);color:#6b7280}.hdm-header-right{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.hdm-scope{display:flex;gap:8px}.hdm-select{height:40px;padding:0 12px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;color:#111827;font-size:var(--fs-14);outline:none}.hdm-search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:8px 10px;min-width:320px;height:44px;box-shadow:0 1px #0f172a0a}.hdm-search input{border:none;outline:none;width:100%;background:transparent;font-size:var(--fs-14);color:#111827}.hdm-search input:disabled{opacity:.6;cursor:not-allowed}.hdm-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;flex:0 0 auto;height:44px;width:160px;min-width:140px;padding:0 18px;border-radius:12px;border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;font-size:var(--fs-15);font-weight:600;white-space:nowrap;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .1s ease;box-shadow:0 1px #0f172a0a}.hdm-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc;transform:translateY(-1px)}.hdm-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.hdm-layout{flex:1;display:grid;grid-template-columns:360px 1fr;gap:12px;min-height:0}.hdm-materials{background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 10px 26px #0000000f;padding:12px;display:flex;flex-direction:column;min-height:0}.hdm-section-title{font-size:var(--fs-16);font-weight:600;color:#111827;margin-bottom:8px}.hdm-material-list{flex:1;overflow-y:auto;border-top:1px solid #f1f5f9;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.hdm-material-item{padding:10px 12px;border-bottom:1px solid #f1f5f9;cursor:pointer}.hdm-material-item:hover{background:#f8fafc}.hdm-material-item.active{background:#e0f2fe;border-left:4px solid #0284c7}.hdm-mat-no{font-size:var(--fs-15);font-weight:600}.hdm-mat-desc{font-size:var(--fs-12);color:#6b7280;margin-top:2px}.hdm-empty{padding:14px;font-size:var(--fs-13);color:#6b7280}.hdm-reasons{background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 10px 26px #0000000f;padding:12px;min-height:0}.hdm-reasons-inner{height:100%;overflow:auto;padding-right:6px}.hdm-cat{border:1px solid #eef2f7;border-radius:14px;padding:12px;margin-bottom:12px}.hdm-cat-title{font-size:var(--fs-14);font-weight:800}.hdm-muted{color:#6b7280;font-weight:600}.hdm-cat-list{margin-top:10px;display:grid;grid-template-columns:1fr 1fr;gap:8px}.hdm-check{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid #e5e7eb;background:#fff}.hdm-check.on{border-color:#7dd3fc;background:#f0f9ff}.hdm-check input{width:16px;height:16px}.hdm-check-text{font-size:var(--fs-16);font-weight:500;color:#de2225}.hdm-empty-sm{padding:8px 0;font-size:var(--fs-13);color:#6b7280}@media(max-width:980px){.hdm-layout{grid-template-columns:1fr}.hdm-search{min-width:240px}.hdm-cat-list{grid-template-columns:1fr}}.hds-page{padding:16px 24px;height:100%;background:#f8fafc;color:#111827}.hds-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:12px}.hds-title{margin:0;font-size:var(--fs-16);font-weight:800;color:#111827}.hds-scope-label{margin-left:10px;font-size:var(--fs-12);color:#6b7280}.hds-actions{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.hds-scope{display:flex;gap:8px}.hds-select,.hds-input{height:40px;width:100%;padding:0 12px;border-radius:12px;border:1px solid #9ca3af;background:#e8edf5;color:#111827;font-size:var(--fs-14);outline:none}.hds-input:focus,.hds-select:focus{border-color:#7dd3fc;box-shadow:0 0 0 3px #7dd3fc59}.hds-select2,.hds-input2{height:40px;width:150px;padding:0 12px;border-radius:12px;border:1px solid #9ca3af;background:#e8edf5;color:#111827;font-size:var(--fs-14);outline:none}.hds-input2:focus,.hds-select2:focus{border-color:#7dd3fc;box-shadow:0 0 0 3px #7dd3fc59}.hds-help{margin-top:6px;font-size:var(--fs-12);color:#6b7280}.hds-body{min-height:0}.hds-grid{display:grid;grid-template-columns:1fr;gap:12px}.hds-card{background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 10px 26px #0000000f;padding:12px}.hds-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.hds-card-title{font-size:var(--fs-15);font-weight:700}.hds-muted{color:#6b7280;font-weight:500}.hds-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;width:200px;padding:0 14px;border-radius:12px;border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;font-size:var(--fs-14);font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .1s ease}.hds-btn-ghost,.hds-btn-danger,.hds-btn-ghost2,.hds-btn-danger2{height:34px;width:88px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#111827;cursor:pointer}.hds-btn-ghost:hover,.hds-btn-ghost2:hover{background:#f8fafc}.hds-btn-danger,.hds-btn-danger2{border-color:#fecaca;background:#fff1f2;color:#991b1b}.hds-btn-danger:hover,.hds-btn-danger2:hover{background:#ffe4e6}.hds-row-actions{display:flex;gap:8px}.hds-table-wrap{overflow:auto;border-radius:12px;border:1px solid #e5e7eb}.hds-table{width:100%;border-collapse:collapse;font-size:var(--fs-14)}.hds-table thead th{background:#f8fafc;color:#374151;text-align:left;padding:10px 12px;border-bottom:1px solid #e5e7eb;font-weight:700}.hds-table tbody td{padding:10px 12px;border-bottom:1px solid #f1f5f9;vertical-align:top}.hds-empty,.hds-empty-td{padding:14px;color:#6b7280;font-size:var(--fs-13)}.hds-reason{font-weight:500}.hds-badge{display:inline-flex;align-items:center;justify-content:center;height:26px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;border:1px solid #e5e7eb}.hds-badge.ok{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.hds-badge.off{background:#f3f4f6;border-color:#e5e7eb;color:#6b7280}.hds-modal-backdrop{position:fixed;inset:0;background:#0206178c;display:flex;align-items:center;justify-content:center;padding:18px;z-index:9999}.hds-modal{width:min(720px,100%);background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 18px 60px #00000059;overflow:hidden}.hds-modal-header{padding:12px 14px;border-bottom:1px solid #eef2f7}.hds-modal-title{display:inline-flex;gap:8px;align-items:center;font-size:var(--fs-15);font-weight:800}.hds-form{padding:14px}.hds-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.hds-field label{display:block;font-size:var(--fs-12);color:#6b7280;font-weight:700;margin-bottom:6px}.hds-field.full{grid-column:1 / -1}.hds-modal-footer{padding:12px 14px;border-top:1px solid #eef2f7;display:flex;justify-content:flex-end;gap:10px}@media(max-width:640px){.hds-page{padding:14px}.hds-grid2{grid-template-columns:1fr}}.hds-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 14px;border-radius:12px;border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a;font-size:var(--fs-14);font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .1s ease}.hds-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc;transform:translateY(-1px)}.hds-btn-ghost,.hds-btn-danger{display:inline-flex;align-items:center;justify-content:center;height:34px;width:158px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#111827;cursor:pointer;padding:0}.hds-btn-ghost2,.hds-btn-danger2{display:inline-flex;align-items:center;justify-content:center;height:34px;width:88px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#111827;cursor:pointer;padding:0}.hds-btn-ghost2:hover{background:#f8fafc}.hds-btn-danger{border-color:#fecaca;background:#fff1f2;color:#991b1b}.hds-btn-danger:hover{background:#ffe4e6}.hds-row-actions{display:flex;gap:8px;justify-content:flex-end}.hds-modal-footer .hds-btn-ghost,.hds-modal-footer2 .hds-btn-ghost2{width:158px;height:44px;border-radius:14px;font-weight:700}.hds-modal-footer .hds-btn-primary{width:200px;height:44px;border-radius:14px;font-weight:800}.hds-thumb{width:44px;height:44px;border-radius:10px;object-fit:cover;border:1px solid #e5e7eb;background:#f8fafc}.hds-url{margin-top:6px;font-size:var(--fs-12);color:#6b7280;word-break:break-all;line-height:1.25}.hds-row-actions .hds-btn-ghost2,.hds-row-actions .hds-btn-danger2{display:inline-flex;align-items:center;justify-content:center}.hds-table td{vertical-align:middle}.hds-thumb-click{cursor:zoom-in}.hds-preview-backdrop{position:fixed;inset:0;background:#000000b3;z-index:9999;display:flex;align-items:center;justify-content:center}.hds-preview-modal{background:#fff;max-width:90vw;max-height:90vh;width:auto;border-radius:10px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006}.hds-preview-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#f1f5f9;border-bottom:1px solid #e5e7eb}.hds-preview-title{font-weight:600;font-size:var(--fs-14);color:#111827}.hds-preview-close{background:transparent;border:none;font-size:var(--fs-18);cursor:pointer;line-height:1}.hds-preview-body{padding:10px;background:#000;display:flex;align-items:center;justify-content:center}.hds-preview-body img{max-width:100%;max-height:80vh;object-fit:contain}.pd-page{--bg: #f6f8fc;--card: #ffffff;--border: #d6dde8;--border-soft: #e7edf6;--text: #0f172a;--muted: #64748b;--primary: #0284c7;--primary-soft: #e0f2fe;--green-bg: #dcfce7;--green-bd: #86efac;--green-tx: #166534;--red-bg: #ffe4e6;--red-bd: #fecaca;--red-tx: #991b1b;--shadow: 0 10px 28px rgba(15,23,42,.08);--radius: 18px;--event-h: 58px;--timeline-pad-top: 52px;--timeline-pad-bottom: 18px;min-height:100%;padding:14px;display:grid;gap:12px;background:var(--bg);color:var(--text);font-size:var(--fs-14)}.pd-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border-soft);box-shadow:var(--shadow);padding:16px}.pd-header{display:grid;gap:10px}.pd-filters{display:grid;grid-template-columns:160px 220px 160px 1fr auto;gap:12px;align-items:end}.pd-field{display:grid;gap:6px}.pd-label{font-size:var(--fs-11);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.pd-input,.pd-select{height:40px;border-radius:12px;border:1px solid var(--border);background:#f1f5f9;padding:0 12px;font-size:var(--fs-14);font-weight:500;color:var(--text)}.pd-input:focus,.pd-select:focus{outline:none;background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #0284c726}.pd-badge{height:40px;border-radius:999px;background:var(--primary-soft);padding:0 14px;display:inline-flex;align-items:center;gap:6px;font-weight:600;white-space:nowrap}.pd-body{display:grid;grid-template-columns:280px 1fr;gap:12px;align-items:start;min-height:0}.pd-left,.pd-center{min-height:0}.pd-reason-list{max-height:calc(100vh - 240px);overflow:auto;display:grid;gap:10px}.pd-reason{border-radius:14px;border:1px solid var(--border-soft);background:#f8fafc;padding:10px 12px;cursor:grab;font-size:var(--fs-13);-webkit-user-select:none;user-select:none;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.pd-reason:hover{transform:translateY(-1px);border-color:var(--border);box-shadow:0 10px 22px #0f172a14}.pd-reason.planned{background:var(--green-bg);border-color:var(--green-bd);color:var(--green-tx)}.pd-reason.unplanned{background:var(--red-bg);border-color:var(--red-bd);color:var(--red-tx)}.pd-reason-code{font-family:var(--pps-font-mono);font-weight:700}.pd-reason-name{margin-top:2px;font-weight:500;color:inherit}.pd-timeline{position:relative;height:clamp(460px,64vh,680px);border-radius:var(--radius);border:1px dashed #cbd5e1;background:linear-gradient(to bottom,#0284c70d,#0284c700);overflow:hidden;isolation:isolate;padding-top:var(--timeline-pad-top);padding-bottom:var(--timeline-pad-bottom)}.pd-timeline.readonly{opacity:.92;filter:saturate(.95)}.pd-ticks{position:absolute;inset:0;pointer-events:none}.pd-tick{position:absolute;top:0;bottom:0;width:1px;background:#94a3b847}.pd-tick.major{background:#64748b6b}.pd-tick span{position:absolute;top:10px;left:6px;font-size:var(--fs-11);color:#64748b;font-weight:600;background:#ffffffc7;padding:2px 6px;border-radius:999px;border:1px solid #e5e7eb;white-space:nowrap}.pd-event{position:absolute;top:calc(var(--timeline-pad-top) + 6px);height:var(--event-h);border-radius:14px;padding:8px 10px;cursor:grab;-webkit-user-select:none;user-select:none;box-shadow:0 8px 20px #0f172a2e;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease;box-sizing:border-box}.pd-event:active{cursor:grabbing}.pd-event:hover{transform:translateY(-1px);box-shadow:0 12px 26px #0f172a38}.pd-event.planned{background:var(--green-bg);border:1px solid var(--green-bd);color:var(--green-tx)}.pd-event.unplanned{background:var(--red-bg);border:1px solid var(--red-bd);color:var(--red-tx)}.pd-event.selected{outline:2px solid rgba(2,132,199,.55);outline-offset:2px}.pd-event-top{display:flex;justify-content:space-between;gap:8px;font-size:var(--fs-13);font-weight:600}.pd-resize-left,.pd-resize-right{position:absolute;top:0;width:10px;height:100%;cursor:ew-resize;opacity:0;transition:opacity .12s ease}.pd-event:hover .pd-resize-left,.pd-event:hover .pd-resize-right{opacity:1}.pd-resize-left:after,.pd-resize-right:after{content:"";position:absolute;top:10px;bottom:10px;width:3px;border-radius:999px;background:#0f172a2e}.pd-resize-left{left:0}.pd-resize-left:after{left:4px}.pd-resize-right{right:0}.pd-resize-right:after{right:4px}.pd-hint{margin-top:10px;color:var(--muted);font-size:var(--fs-12);font-weight:600}.pd-hint b{color:var(--text)}@media(max-width:1200px){.pd-filters{grid-template-columns:160px 220px 160px 1fr}.pd-badge{grid-column:1 / -1;justify-self:start}}@media(max-width:1100px){.pd-body{grid-template-columns:1fr}.pd-reason-list{max-height:240px}.pd-timeline{height:clamp(380px,55vh,560px)}.pd-filters{grid-template-columns:1fr 1fr}}.smu-panel{padding:16px 24px;height:100%;background:#f8fafc;font-family:var(--pps-font-main);color:#0f172a;display:flex;flex-direction:column;gap:12px}.smu-filterbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:12px}.smu-filter-search{flex:1;min-width:240px}.smu-select,.smu-input{height:40px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;padding:0 12px;font-size:var(--fs-14);color:#0f172a;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.smu-select:focus,.smu-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa40}.smu-count{margin-left:auto;font-size:var(--fs-14);color:#334155;white-space:nowrap}.smu-table-wrapper{flex:1;background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:auto;min-height:280px}.smu-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1100px}.smu-table thead th{position:sticky;top:0;z-index:2;background:#f1f5f9;color:#0f172a;font-weight:700;text-align:left;padding:12px 10px;border-bottom:1px solid #e2e8f0}.smu-table tbody td{padding:10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.smu-table tbody tr:hover td{background:#f8fafc}.smu-table th:nth-child(1),.smu-table td:nth-child(1){width:70px}.smu-table th:nth-child(2),.smu-table td:nth-child(2){width:90px}.smu-table th:nth-child(3),.smu-table td:nth-child(3){width:90px}.smu-table th:nth-child(4),.smu-table td:nth-child(4){width:160px;font-family:var(--pps-font-mono)}.smu-table th:nth-child(5),.smu-table td:nth-child(5){min-width:320px}.smu-table th:nth-child(6),.smu-table td:nth-child(6),.smu-table th:nth-child(7),.smu-table td:nth-child(7),.smu-table th:nth-child(8),.smu-table td:nth-child(8){width:160px}.smu-table th:nth-child(9),.smu-table td:nth-child(9){width:110px}.smu-input-num{width:140px;height:36px;border-radius:10px;padding:0 10px;font-size:var(--fs-14)}.smu-empty{text-align:center;padding:22px 10px;color:#64748b}.smu-btn{height:36px;padding:0 12px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;font-weight:700;cursor:pointer;transition:background .15s ease,transform .05s ease}.smu-btn:hover:enabled{background:#f8fafc}.smu-btn:active:enabled{transform:translateY(1px)}.smu-btn:disabled{opacity:.55;cursor:not-allowed}.smu-btn-primary{background:#2563eb;border-color:#2563eb;color:#fff}.smu-btn-primary:hover:enabled{background:#1d4ed8;border-color:#1d4ed8}.smu-pager{display:flex;gap:8px;align-items:center;justify-content:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:10px 12px}.smu-pageinfo{font-size:var(--fs-14);color:#334155}.smu-scope{display:flex;gap:8px;align-items:center}.smu-scope-badge{background:#f1f5f9;border:1px solid #e2e8f0;padding:6px 10px;border-radius:12px;font-size:var(--fs-13);color:#334155}.smu-row-usage-zero td{background-color:#fff7ed}.smu-row-usage-zero:hover td{background-color:#ffedd5}.msm-page{--bg: #f8fafc;--card: #ffffff;--card-2: #fcfdff;--border: #dbe5ef;--border-soft: #edf2f7;--text: #0f172a;--muted: #64748b;--muted-2: #334155;--primary: #0284c7;--primary-hover: #0369a1;--primary-soft: #e0f2fe;--green: #16a34a;--green-soft: #ecfdf5;--amber: #f59e0b;--amber-soft: #fffbeb;--danger: #dc2626;--danger-soft: #fef2f2;--violet: #8b5cf6;--violet-soft: #f5f3ff;--focus: rgba(2, 132, 199, .18);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 12px 28px rgba(15, 23, 42, .08);--radius: 18px;--radius-md: 14px;--radius-sm: 10px;--row-hover: #f8fafc;--grade-a: #f0fdf4;--grade-a-hover: #dcfce7;--grade-b: #eff6ff;--grade-b-hover: #dbeafe;--grade-c: #fff7ed;--grade-c-hover: #ffedd5;--grade-d: #fef2f2;--grade-d-hover: #fee2e2;min-height:100%;height:100%;min-width:0;padding:16px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);color:var(--text);font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:14px;overflow:auto}.msm-page .msm-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px 20px;border:1px solid var(--border);border-radius:var(--radius);background:radial-gradient(circle at top right,rgba(2,132,199,.1),transparent 28%),linear-gradient(180deg,#fff,#f8fbff);box-shadow:var(--shadow-sm)}.msm-page .msm-hero-left,.msm-page .msm-hero-right{min-width:0}.msm-page .msm-title-wrap{display:flex;align-items:center;gap:14px;min-width:0}.msm-page .msm-title-icon{width:52px;height:52px;flex:0 0 52px;border-radius:16px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);font-size:var(--fs-24);box-shadow:inset 0 0 0 1px #0284c714}.msm-page .msm-title{font-size:var(--fs-24);line-height:1.15;font-weight:800;letter-spacing:-.02em}.msm-page .msm-subtitle{margin-top:6px;font-size:var(--fs-14);color:var(--muted);line-height:1.5}.msm-page .msm-refresh-btn{height:42px;padding:0 14px;border-radius:12px;border:1px solid #bae6fd;background:var(--primary-soft);color:var(--primary);font-weight:800;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .08s ease,box-shadow .18s ease}.msm-page .msm-refresh-btn:hover{background:#bae6fd;border-color:#7dd3fc}.msm-page .msm-refresh-btn:active{transform:translateY(1px)}.msm-page .msm-filterbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;box-shadow:var(--shadow-sm)}.msm-page .msm-select,.msm-page .msm-input{height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;padding:0 13px;font-size:var(--fs-14);color:var(--text);outline:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.msm-page .msm-select:hover,.msm-page .msm-input:hover{border-color:#cbd5e1}.msm-page .msm-select:focus,.msm-page .msm-input:focus{border-color:#38bdf8;box-shadow:0 0 0 3px var(--focus)}.msm-page .msm-count{margin-left:auto;min-height:42px;padding:0 14px;display:inline-flex;align-items:center;border-radius:12px;background:#f8fafc;border:1px solid var(--border);color:var(--muted-2);font-size:var(--fs-14);font-weight:700;white-space:nowrap}.msm-page .msm-scope{display:flex;gap:8px;align-items:center}.msm-page .msm-scope-badge{min-height:42px;padding:0 12px;display:inline-flex;align-items:center;border-radius:12px;background:#f8fafc;border:1px solid var(--border);font-size:var(--fs-13);color:var(--muted-2);white-space:nowrap}.msm-page .msm-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.msm-page .msm-kpi-card{background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:16px;min-width:0}.msm-page .msm-kpi-head{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:var(--fs-13);font-weight:700}.msm-page .msm-kpi-icon{width:28px;height:28px;border-radius:9px;display:grid;place-items:center;background:#eff6ff;color:var(--primary);flex:0 0 28px}.msm-page .msm-kpi-label{min-width:0}.msm-page .msm-kpi-value{margin-top:10px;font-size:var(--fs-28);line-height:1.1;font-weight:800;letter-spacing:-.02em;color:var(--text);overflow-wrap:anywhere}.msm-page .msm-kpi-value.msm-kpi-text{font-size:var(--fs-18);line-height:1.35}.msm-page .msm-kpi-sub{margin-top:6px;font-size:var(--fs-12);color:var(--muted);line-height:1.5}.msm-page .msm-chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.msm-page .msm-card{min-width:0;background:linear-gradient(180deg,#fff,#fcfdff);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:16px}.msm-page .msm-card-wide{grid-column:1 / -1}.msm-page .msm-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.msm-page .msm-card-title{font-size:var(--fs-16);line-height:1.3;font-weight:800;color:var(--text)}.msm-page .msm-card-sub{margin-top:4px;font-size:var(--fs-13);color:var(--muted);line-height:1.45}.msm-page .msm-chart{width:100%;min-width:0}.msm-page .msm-table-card{padding-bottom:0}.msm-page .msm-table-wrapper{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:auto;min-height:320px;max-height:62vh;min-width:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.msm-page .msm-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1700px}.msm-page .msm-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--text);font-weight:800;text-align:left;padding:12px 10px;border-bottom:1px solid var(--border);white-space:nowrap;-webkit-transform:translateZ(0);transform:translateZ(0)}.msm-page .msm-table tbody td{padding:10px;border-bottom:1px solid var(--border-soft);vertical-align:middle;white-space:nowrap}.msm-page .msm-table tbody tr:hover td{background:var(--row-hover)}.msm-page .msm-table tbody td:nth-child(1),.msm-page .msm-table tbody td:nth-child(3),.msm-page .msm-table tbody td:nth-child(9),.msm-page .msm-table tbody td:nth-child(10),.msm-page .msm-table tbody td:nth-child(11),.msm-page .msm-table tbody td:nth-child(12),.msm-page .msm-table tbody td:nth-child(13),.msm-page .msm-table tbody td:nth-child(14){text-align:right}.msm-page .msm-table th:nth-child(1),.msm-page .msm-table td:nth-child(1){width:72px}.msm-page .msm-table th:nth-child(2),.msm-page .msm-table td:nth-child(2){width:90px}.msm-page .msm-table th:nth-child(3),.msm-page .msm-table td:nth-child(3){width:110px}.msm-page .msm-table th:nth-child(4),.msm-page .msm-table td:nth-child(4){width:90px}.msm-page .msm-table th:nth-child(5),.msm-page .msm-table td:nth-child(5){width:90px;font-family:var(--pps-font-mono)}.msm-page .msm-table th:nth-child(6),.msm-page .msm-table td:nth-child(6){min-width:260px}.msm-page .msm-table th:nth-child(7),.msm-page .msm-table td:nth-child(7){width:150px;font-family:var(--pps-font-mono)}.msm-page .msm-table th:nth-child(8),.msm-page .msm-table td:nth-child(8){width:120px;font-family:var(--pps-font-mono)}.msm-page .msm-table th:nth-child(9),.msm-page .msm-table td:nth-child(9),.msm-page .msm-table th:nth-child(10),.msm-page .msm-table td:nth-child(10),.msm-page .msm-table th:nth-child(11),.msm-page .msm-table td:nth-child(11){width:110px}.msm-page .msm-table th:nth-child(12),.msm-page .msm-table td:nth-child(12){width:150px}.msm-page .msm-table th:nth-child(13),.msm-page .msm-table td:nth-child(13),.msm-page .msm-table th:nth-child(14),.msm-page .msm-table td:nth-child(14){width:120px}.msm-page .msm-grade-pill{min-width:34px;height:28px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid transparent;font-size:var(--fs-12);font-weight:800}.msm-page .msm-score-cell{font-weight:800;color:var(--text)}.msm-page .msm-line-cell{white-space:normal;min-width:260px;line-height:1.45}.msm-page .msm-empty{text-align:center!important;padding:24px 12px!important;color:var(--muted)}.msm-page .msm-btn{height:38px;min-width:38px;padding:0 14px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:800;cursor:pointer;transition:background .15s ease,transform .05s ease,border-color .15s ease,box-shadow .15s ease}.msm-page .msm-btn:hover:enabled{background:#f8fafc;border-color:#cbd5e1}.msm-page .msm-btn:active:enabled{transform:translateY(1px)}.msm-page .msm-btn:disabled{opacity:.55;cursor:not-allowed}.msm-page .msm-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.msm-page .msm-btn-primary:hover:enabled{background:var(--primary-hover);border-color:var(--primary-hover)}.msm-page .msm-pager{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;box-shadow:var(--shadow-sm)}.msm-page .msm-pageinfo{min-width:120px;text-align:center;font-size:var(--fs-14);color:var(--muted-2);font-weight:700}.msm-page .msm-row-grade-a td{background:var(--grade-a)}.msm-page .msm-row-grade-a:hover td{background:var(--grade-a-hover)}.msm-page .msm-row-grade-b td{background:var(--grade-b)}.msm-page .msm-row-grade-b:hover td{background:var(--grade-b-hover)}.msm-page .msm-row-grade-c td{background:var(--grade-c)}.msm-page .msm-row-grade-c:hover td{background:var(--grade-c-hover)}.msm-page .msm-row-grade-d td{background:var(--grade-d)}.msm-page .msm-row-grade-d:hover td{background:var(--grade-d-hover)}@media(max-width:1200px){.msm-page .msm-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.msm-page .msm-chart-grid{grid-template-columns:1fr}.msm-page .msm-card-wide{grid-column:auto}}@media(max-width:768px){.msm-page{padding:12px;gap:12px}.msm-page .msm-hero{flex-direction:column;padding:16px}.msm-page .msm-title{font-size:var(--fs-21)}.msm-page .msm-filterbar{padding:10px}.msm-page .msm-count{margin-left:0;width:100%;justify-content:center}.msm-page .msm-kpi-grid{grid-template-columns:1fr}.msm-page .msm-table{min-width:1200px}}@media(max-width:520px){.msm-page .msm-title-wrap{align-items:flex-start}.msm-page .msm-title-icon{width:46px;height:46px;flex-basis:46px;font-size:var(--fs-20)}.msm-page .msm-select,.msm-page .msm-input,.msm-page .msm-refresh-btn{width:100%}.msm-page .msm-filterbar>*{width:100%}.msm-page .msm-pager{justify-content:stretch}.msm-page .msm-pageinfo{width:100%}}.msm-page .msm-compare-toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.msm-page .msm-compare-toolbar .msm-input{flex:1;min-width:260px}.msm-page .msm-selected-badge{height:40px;display:inline-flex;align-items:center;padding:0 14px;border-radius:12px;border:1px solid var(--border);background:#f8fafc;color:var(--text);font-weight:700}.msm-page .msm-compare-table-wrap{border:1px solid var(--border);border-radius:14px;overflow:auto;max-height:520px;background:#fff}.msm-page .msm-compare-table{width:100%;min-width:980px;border-collapse:separate;border-spacing:0}.msm-page .msm-compare-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--text);text-align:left;font-size:var(--fs-13);font-weight:800;padding:12px 14px;border-bottom:1px solid var(--border);white-space:nowrap}.msm-page .msm-compare-table tbody td{padding:11px 14px;border-bottom:1px solid #eef2f7;vertical-align:middle;font-size:var(--fs-14)}.msm-page .msm-compare-table tbody tr:hover td{background:#f8fbff}.msm-page .msm-compare-table .r,.msm-page .msm-compare-table th.r{text-align:right}.msm-page .msm-compare-row-selected td{background:#eff6ff}.msm-page .msm-compare-row-selected:hover td{background:#dbeafe}.pdt-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--green: #16a34a;--red: #dc2626;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;height:100%;width:100%;display:grid;grid-template-columns:420px 1fr;gap:12px;padding:16px 24px;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--pps-font-main)}.pdt-btn,.pdt-btn-primary,.pdt-icon{-webkit-appearance:none;appearance:none;opacity:1!important;visibility:visible!important;color:inherit;text-decoration:none;line-height:1}.pdt-btn svg,.pdt-btn-primary svg,.pdt-icon svg{width:16px;height:16px;display:block;flex:0 0 auto;color:inherit!important;fill:none!important;stroke:currentColor!important;stroke-width:1.6!important}.pdt-btn:focus-visible,.pdt-btn-primary:focus-visible,.pdt-icon:focus-visible{outline:none;box-shadow:0 0 0 3px #38bdf859}.pdt-left{display:flex;flex-direction:column;gap:12px;overflow:hidden}.pdt-card{background:var(--card);border-radius:var(--radius);border:1px solid #e2e8f0;box-shadow:var(--shadow);padding:14px}.pdt-card-scroll{flex:1;overflow:auto;padding-right:6px}.pdt-title{font-size:var(--fs-16);font-weight:900}.pdt-sub{margin-top:4px;font-size:var(--fs-12);color:var(--muted)}.pdt-search{position:relative;margin-top:10px}.pdt-search input{width:100%;height:42px;border-radius:12px;border:1px solid #94a3b8;background:#e8edf5;padding:0 12px 0 40px;font-size:var(--fs-15);outline:none}.pdt-search input:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0369a11a}.pdt-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.pdt-mini{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.pdt-count{font-size:var(--fs-12);color:var(--muted)}.pdt-wo-list{display:flex;flex-direction:column;gap:10px}.pdt-wo-row{text-align:left;width:100%;border-radius:14px;border:1px solid #e5e7eb;background:#f9fafb;padding:12px;cursor:pointer;transition:all .15s}.pdt-wo-row:hover{border-color:#7dd3fc;background:#fff}.pdt-wo-row.active{border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf833;background:#fff}.pdt-wo-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.pdt-wo-code{font-weight:900;font-size:var(--fs-14)}.pdt-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.pdt-badge{height:22px;padding:0 10px;display:inline-flex;align-items:center;border-radius:999px;border:1px solid #bae6fd;background:#e0f2fe;color:#075985;font-size:var(--fs-12);font-weight:800}.pdt-wo-mid{margin-top:6px;font-size:var(--fs-12);color:#334155}.pdt-wo-desc{margin-top:4px;font-size:var(--fs-12);color:var(--muted)}.pdt-wo-time{margin-top:6px;font-size:var(--fs-12);color:#475569}.pdt-right{display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);background:var(--card);border:1px solid #e2e8f0;box-shadow:var(--shadow)}.pdt-right-header{padding:14px 16px;border-bottom:1px solid #e2e8f0;display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}.pdt-actions{display:flex;gap:8px;flex-wrap:wrap}.pdt-right-body{flex:1;overflow:auto;padding:14px;background:var(--bg)}.pdt-empty{padding:18px;border:1px dashed var(--border);border-radius:14px;background:#fff;color:var(--muted);text-align:center}.pdt-btn{height:40px;padding:0 14px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;cursor:pointer;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .15s ease;color:#0f172a}.pdt-btn:hover{background:#f1f5f9}.pdt-btn:disabled{opacity:.6!important;cursor:not-allowed}.pdt-btn-primary{height:40px;padding:0 14px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--primary2),var(--primary));color:#fff;cursor:pointer;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .15s ease}.pdt-btn-primary:hover{filter:brightness(.98)}.pdt-btn-primary:disabled{opacity:.6!important;cursor:not-allowed}.pdt-list{display:flex;flex-direction:column;gap:10px}.pdt-item{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px;display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.pdt-item-time{font-size:var(--fs-13);font-weight:900;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pdt-arrow{color:#94a3b8}.pdt-item-reason{margin-top:8px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.pdt-pill{height:22px;padding:0 10px;border-radius:999px;border:1px solid #e2e8f0;background:#f1f5f9;color:#0f172a;font-size:var(--fs-12);font-weight:900}.pdt-reason-desc{font-size:var(--fs-12);color:#334155;font-weight:700}.pdt-item-meta{margin-top:8px;font-size:var(--fs-12);color:var(--muted);display:flex;gap:6px;flex-wrap:wrap}.pdt-k{color:#64748b}.pdt-dot{color:#cbd5e1}.pdt-item-actions{display:flex;gap:8px}.pdt-icon{width:38px;height:38px;border-radius:12px;border:1px solid #e8eef6;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease;color:#0f172a}.pdt-icon:hover{background:#e0f2fe;border-color:#38bdf8;color:#0369a1}.pdt-icon.danger{border-color:#ffe4e6;background:#fff1f2;color:#b91c1c}.pdt-icon.danger:hover{background:#fecdd3;border-color:#fda4af;color:#7f1d1d}.pdt-modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:10px;z-index:999}.pdt-modal{width:100%;max-width:760px;background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #00000040;padding:12px}.pdt-modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-bottom:10px;border-bottom:1px solid #e5e7eb}.pdt-modal-title{font-size:var(--fs-14);font-weight:900}.pdt-form{padding-top:12px}.pdt-field{display:grid;gap:6px}.pdt-field label{font-size:var(--fs-12);font-weight:900;color:#0f172a}.pdt-field input{height:42px;border-radius:12px;border:1px solid #94a3b8;background:#e8edf5;padding:0 12px;font-size:var(--fs-14);outline:none}.pdt-field input:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0369a11a}.pdt-grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pdt-modal-actions{margin-top:14px;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.pdt-auto-minutes{margin-top:12px;border-radius:16px;padding:16px;background:linear-gradient(135deg,#f8fafc,#fff);border:1px dashed #94a3b8;display:flex;align-items:center;justify-content:space-between;gap:12px}.pdt-auto-label{font-size:var(--fs-12);font-weight:900;color:#334155}.pdt-auto-value{font-size:var(--fs-22);font-weight:900;color:#0f172a}@media(max-width:1150px){.pdt-page{grid-template-columns:1fr;overflow:auto;padding:16px}.pdt-left{overflow:visible}}@media(max-width:640px){.pdt-grid2{grid-template-columns:1fr}.pdt-right-header{align-items:flex-start}.pdt-actions{width:100%}.pdt-btn,.pdt-btn-primary{width:100%;justify-content:center}}.pdt-page,.pdt-page *{color:inherit}.pdt-page{color:var(--text)}.pdt-page input,.pdt-page select,.pdt-page textarea{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;text-shadow:none!important}.pdt-page select option{color:var(--text)!important;background:#fff!important}.pdt-page input:disabled,.pdt-page select:disabled{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important;opacity:.85}.pdt-page .pdt-btn,.pdt-page .pdt-icon{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important}.pdt-page .pdt-btn-primary{color:#fff!important;-webkit-text-fill-color:#ffffff!important}.pdt-page .pdt-btn svg,.pdt-page .pdt-btn-primary svg,.pdt-page .pdt-icon svg{color:currentColor!important}.pdt-page .pdt-pill,.pdt-page .pdt-badge{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important}.pdt-page .pdt-sub,.pdt-page .pdt-count,.pdt-page .pdt-wo-desc,.pdt-page .pdt-item-meta,.pdt-page .pdt-empty{color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important}.pdt-page .pdt-field input{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important}@media(forced-colors:active){.pdt-page{forced-color-adjust:auto}.pdt-page .pdt-card,.pdt-page .pdt-right,.pdt-page .pdt-modal{border:1px solid ButtonText;background:Canvas;color:CanvasText}.pdt-page .pdt-btn,.pdt-page .pdt-icon{border:1px solid ButtonText;background:ButtonFace;color:ButtonText;-webkit-text-fill-color:ButtonText}.pdt-page .pdt-btn-primary{border:1px solid ButtonText;background:Highlight;color:HighlightText;-webkit-text-fill-color:HighlightText}.pdt-page input,.pdt-page select,.pdt-page textarea{border:1px solid ButtonText;background:Field;color:FieldText!important;-webkit-text-fill-color:FieldText!important}}.ssm-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--border-soft: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary-soft: #e0f2fe;--danger: #b91c1c;--danger-soft: #fef2f2;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--font-base: 1rem;--font-sm: .875rem;--font-xs: .75rem;font-family:var(--pps-font-main);font-size:var(--font-base);line-height:1.6;letter-spacing:.01em;min-height:100%;padding:1rem;background:var(--bg);color:var(--text);display:flex;flex-direction:column;gap:1rem}.ssm-title{font-size:var(--fs-18);font-weight:700;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;min-width:0}.ssm-muted{color:var(--muted);font-size:var(--font-sm)}.mono{font-family:var(--pps-font-mono);font-size:var(--font-sm)}.ssm-header{display:flex;flex-direction:column;gap:.75rem}.ssm-scope{margin-left:0;display:inline-flex;flex-wrap:wrap;gap:.5rem}.ssm-badge,.ssm-pill{height:1.75rem;padding:0 .75rem;border-radius:999px;font-size:var(--font-xs);font-weight:600;border:1px solid var(--border);display:inline-flex;align-items:center}.ssm-badge.soft{background:var(--primary-soft);border-color:#bae6fd;color:#0f172a}.ssm-pill.on{background:#ecfdf5;border-color:#bbf7d0;color:#065f46}.ssm-pill.off{background:#f1f5f9;color:var(--muted)}.ssm-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.ssm-scope-select{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.ssm-select,.ssm-search input,.ssm-form input,.ssm-form select{height:2.5rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;padding:0 .75rem;font-size:var(--font-sm);width:100%;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.ssm-select:focus,.ssm-search input:focus,.ssm-form input:focus,.ssm-form select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0369a126}.ssm-select:disabled,.ssm-search input:disabled,.ssm-form input:disabled,.ssm-form select:disabled{opacity:.75;cursor:not-allowed;background:#f8fafc}.ssm-search{position:relative;width:100%;max-width:16rem}.ssm-search input{padding-left:2.25rem}.ssm-search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:var(--fs-14);color:var(--muted)}.ssm-scope-select .ssm-select{width:10.5rem;min-width:9.5rem}.ssm-btn-primary,.ssm-btn-ghost,.ssm-btn-primary2,.ssm-btn-ghost2{height:2.5rem;padding:0 1rem;border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:1px solid var(--border);background:#fff;transition:all .2s ease;white-space:nowrap}.ssm-btn-primary,.ssm-btn-primary2{background:var(--primary);border-color:var(--primary);color:#fff}.ssm-btn-primary:hover,.ssm-btn-primary2:hover{opacity:.9}.ssm-btn-ghost:hover,.ssm-btn-ghost2:hover{background:#f1f5f9}.ssm-btn-primary:disabled,.ssm-btn-primary2:disabled,.ssm-btn-ghost:disabled,.ssm-btn-ghost2:disabled{opacity:.55;cursor:not-allowed}.ssm-btn-icon{height:2.25rem;width:2.25rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.ssm-btn-icon:hover{background:#f1f5f9}.ssm-btn-primary svg,.ssm-btn-ghost svg,.ssm-btn-primary2 svg,.ssm-btn-ghost2 svg,.ssm-icon-btn svg{display:inline-block;width:1.125rem;height:1.125rem;flex-shrink:0;line-height:1;vertical-align:middle}.ssm-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.ssm-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.ssm-table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.ssm-table thead th{background:#f1f5f9;font-weight:600;text-align:left;padding:.75rem;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:2}.ssm-table tbody td{padding:.75rem;border-bottom:1px solid var(--border-soft);vertical-align:top}.ssm-table th,.ssm-table td{white-space:nowrap}.ssm-table td:nth-child(3),.ssm-table td:nth-child(4){white-space:normal;word-break:break-word}.ssm-table td:first-child{text-align:right;font-variant-numeric:tabular-nums}.ssm-table td:nth-child(2){font-variant-numeric:tabular-nums}.ssm-empty-td{padding:1rem;font-size:var(--font-sm);color:var(--muted);text-align:center}.ssm-row-actions{display:flex;justify-content:flex-end;gap:.5rem;min-width:6.5rem}.ssm-icon-btn{height:2rem;width:2.25rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:var(--fs-18);line-height:0}.ssm-icon-btn:hover{background:#f1f5f9}.ssm-icon-btn.danger{background:var(--danger-soft);border-color:#fecaca;color:var(--danger)}.ssm-icon-btn:disabled{opacity:.55;cursor:not-allowed}.ssm-modal-backdrop{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000}.ssm-modal{width:100%;max-width:42rem;background:var(--card);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;max-height:calc(100vh - 2rem);display:flex;flex-direction:column}.ssm-modal-head{padding:1rem;border-bottom:1px solid var(--border-soft);display:flex;justify-content:space-between;align-items:flex-start;flex:0 0 auto}.ssm-modal-title{font-weight:700;font-size:var(--fs-16)}.ssm-modal-sub{font-size:var(--font-xs);color:var(--muted)}.ssm-form{padding:1rem;overflow:auto;-webkit-overflow-scrolling:touch}.ssm-grid2{display:grid;grid-template-columns:1fr;gap:1rem}.ssm-field label{display:block;font-size:var(--font-xs);margin-bottom:.375rem;font-weight:600;color:var(--muted)}.ssm-field.full{grid-column:1 / -1}.ssm-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem;flex-wrap:wrap}@media(min-width:640px){.ssm-header{flex-direction:row;align-items:center;justify-content:space-between}.ssm-grid2{grid-template-columns:1fr 1fr}.ssm-search{width:auto}.ssm-search input{width:16rem}}@media(min-width:1024px){.ssm-page{padding:1.5rem 2rem}}.ssm-page{color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.ssm-page,.ssm-page *{color:inherit}.ssm-page{color:var(--text)}.ssm-page input,.ssm-page select,.ssm-page textarea,.ssm-page .ssm-select,.ssm-page .ssm-search input,.ssm-page .ssm-form input,.ssm-page .ssm-form select{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;background-color:#fff!important;background-clip:padding-box;text-shadow:none!important;-webkit-appearance:none;appearance:none}.ssm-page input::placeholder,.ssm-page textarea::placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.ssm-page input::-webkit-input-placeholder,.ssm-page textarea::-webkit-input-placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.ssm-page select option{color:#0f172a!important;background:#fff!important}.ssm-page input:-webkit-autofill,.ssm-page textarea:-webkit-autofill,.ssm-page select:-webkit-autofill{-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}.ssm-page .ssm-btn-primary,.ssm-page .ssm-btn-ghost,.ssm-page .ssm-btn-primary2,.ssm-page .ssm-btn-ghost2,.ssm-page .ssm-btn-icon,.ssm-page .ssm-icon-btn{-webkit-text-fill-color:currentColor!important}.ssm-page .ssm-btn-primary svg,.ssm-page .ssm-btn-ghost svg,.ssm-page .ssm-btn-primary2 svg,.ssm-page .ssm-btn-ghost2 svg,.ssm-page .ssm-btn-icon svg,.ssm-page .ssm-icon-btn svg{color:currentColor!important;opacity:1!important;visibility:visible!important}.ssm-page .ssm-btn-primary,.ssm-page .ssm-btn-primary2{color:#fff!important;-webkit-text-fill-color:#ffffff!important}.ssm-page .ssm-icon-btn.danger{color:var(--danger)!important;-webkit-text-fill-color:var(--danger)!important}.ssm-page .ssm-muted,.ssm-page .ssm-help,.ssm-page .ssm-empty-td,.ssm-page .ssm-modal-sub,.ssm-page .ssm-field label{color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important}@media(forced-colors:active){.ssm-page{forced-color-adjust:auto}.ssm-page .ssm-card,.ssm-page .ssm-modal{border:1px solid ButtonText!important;background:Canvas!important;color:CanvasText!important}.ssm-page input,.ssm-page select,.ssm-page textarea{border:1px solid ButtonText!important;background:Field!important;color:FieldText!important;-webkit-text-fill-color:FieldText!important}.ssm-page button{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}}.ssd-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #6b7280;--primary: #0369a1;--soft: #e0f2fe;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 10px;height:100%;min-height:100%;padding:16px 24px;background:var(--bg);color:var(--text);overflow:auto}.ssd-header{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:12px}.ssd-title{font-size:var(--fs-18);font-weight:900}.ssd-sub{font-size:var(--fs-13);color:var(--muted);margin-top:4px}.ssd-actions{display:flex;gap:10px;flex-wrap:wrap}.ssd-btn{height:40px;padding:0 14px;border-radius:12px;border:1px solid var(--border);background:var(--card);cursor:pointer;font-weight:800;display:inline-flex;align-items:center;gap:8px}.ssd-btn:hover{background:#f1f5f9}.ssd-btn:disabled{opacity:.6;cursor:not-allowed}.ssd-card{background:var(--card);border:1px solid #e5e7eb;border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}.ssd-filters{display:grid;grid-template-columns:200px 160px 160px 1fr 1.2fr;gap:12px;align-items:end}.ssd-field{display:grid;gap:6px}.ssd-label{font-size:var(--fs-12);color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.5px}.ssd-input,.ssd-select{height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-15);outline:none}.ssd-input:focus,.ssd-select:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #0369a11f}.ssd-search{position:relative}.ssd-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#64748b}.ssd-search input{width:100%;height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px 0 34px;font-size:var(--fs-15);outline:none}.ssd-search input:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #0369a11f}.ssd-hint{margin-top:10px;font-size:var(--fs-12);color:var(--muted)}.ssd-kpi{margin-top:12px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.ssd-kpi-card{background:var(--card);border:1px solid #e5e7eb;border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}.ssd-kpi-card .k{font-size:var(--fs-12);color:var(--muted);font-weight:800;text-transform:uppercase}.ssd-kpi-card .v{margin-top:6px;font-size:var(--fs-24);font-weight:900}.ssd-kpi-card .v.small{font-size:var(--fs-16);font-weight:900}.ssd-grid{margin-top:12px;display:grid;gap:12px;align-items:stretch}.ssd-card-title{font-size:var(--fs-14);font-weight:900;margin-bottom:10px}.ssd-card-chart .ssd-chart{height:320px}.ssd-card-heat .ssd-heat-wrap{max-height:360px;overflow:auto;border:1px solid #eef2f7;border-radius:12px}.ssd-heat-table{min-width:900px}.ssd-heat-head,.ssd-heat-row{display:grid;grid-template-columns:110px repeat(24,1fr);gap:6px;padding:8px}.ssd-heat-head{position:sticky;top:0;background:#f8fafc;z-index:1;border-bottom:1px solid #e5e7eb}.ssd-heat-head .h0{font-weight:900;font-size:var(--fs-12);color:#334155}.ssd-heat-head .hh{text-align:center;font-size:var(--fs-11);color:#64748b;font-weight:800}.ssd-heat-row .d{font-size:var(--fs-12);font-weight:900;color:#0f172a;display:flex;align-items:center}.ssd-heat{height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:var(--fs-11);font-weight:900;border:1px solid #e5e7eb;background:#fff;color:#334155}.ssd-heat.z0{background:#fff}.ssd-heat.z1{background:#e0f2fe;border-color:#bae6fd}.ssd-heat.z2{background:#bae6fd;border-color:#7dd3fc}.ssd-heat.z3{background:#7dd3fc;border-color:#38bdf8}.ssd-heat.z4{background:#38bdf8;border-color:#0284c7;color:#083344}.ssd-legend{margin-top:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ssd-legend .l{padding:4px 10px;border-radius:999px;border:1px solid #e5e7eb;font-size:var(--fs-12);font-weight:900}.ssd-legend .z1{background:#e0f2fe;border-color:#bae6fd}.ssd-legend .z2{background:#bae6fd;border-color:#7dd3fc}.ssd-legend .z3{background:#7dd3fc;border-color:#38bdf8}.ssd-legend .z4{background:#38bdf8;border-color:#0284c7;color:#083344}.ssd-legend .t{color:var(--muted);font-size:var(--fs-12);font-weight:800;margin-left:6px}.ssd-card-table .ssd-table-wrap{max-height:360px;overflow:auto;border:1px solid #eef2f7;border-radius:12px}.ssd-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.ssd-table th{position:sticky;top:0;background:#f8fafc;z-index:1;border-bottom:1px solid #e5e7eb;padding:10px;text-align:left;white-space:nowrap;font-size:var(--fs-13)}.ssd-table td{border-bottom:1px solid #f1f5f9;padding:10px;white-space:nowrap;font-size:var(--fs-13)}.ssd-table td.remark{max-width:420px;overflow:hidden;text-overflow:ellipsis}.ssd-empty,.ssd-empty-td{padding:14px;color:var(--muted);font-weight:700}.ssd-loading{position:fixed;right:16px;bottom:16px;background:#0f172a;color:#fff;padding:10px 12px;border-radius:12px;font-weight:900;box-shadow:0 20px 60px #00000040}@media(max-width:1150px){.ssd-filters,.ssd-kpi{grid-template-columns:1fr 1fr}.ssd-grid{grid-template-columns:1fr}}.ssd-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:12px}.ssd-topbar-left{min-width:0}.ssd-topbar-right{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;justify-content:flex-end}.ssd-field-inline{display:grid;gap:6px}.ssd-field-inline label{font-size:var(--fs-12);color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.4px}.ssd-field-inline select{height:40px;border-radius:12px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-14);outline:none}.ssd-field-inline select:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #0369a11f}@media(max-width:1150px){.ssd-topbar{align-items:flex-start}.ssd-topbar-right{justify-content:flex-start}}.ssd-page{color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.ssd-page{color:var(--text)}.ssd-page input,.ssd-page select,.ssd-page textarea,.ssd-page .ssd-input,.ssd-page .ssd-select,.ssd-page .ssd-search input,.ssd-page .ssd-field-inline select{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;text-shadow:none!important;background-color:#e8edf5!important;background-clip:padding-box;-webkit-appearance:none;appearance:none}.ssd-page .ssd-input:focus,.ssd-page .ssd-select:focus,.ssd-page .ssd-search input:focus,.ssd-page .ssd-field-inline select:focus{background:#fff!important}.ssd-page input::placeholder,.ssd-page textarea::placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.ssd-page input::-webkit-input-placeholder,.ssd-page textarea::-webkit-input-placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.ssd-page select option{color:#111827!important;background:#fff!important}.ssd-page input:-webkit-autofill,.ssd-page textarea:-webkit-autofill,.ssd-page select:-webkit-autofill{-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}.ssd-page svg{display:inline-block;vertical-align:middle;overflow:visible}.ssd-page button svg,.ssd-page .ssd-btn svg,.ssd-page .ssd-search svg{color:currentColor!important;opacity:1!important;visibility:visible!important}.ssd-page .ssd-sub,.ssd-page .ssd-label,.ssd-page .ssd-hint,.ssd-page .ssd-kpi-card .k,.ssd-page .ssd-heat-head .hh,.ssd-page .ssd-legend .t,.ssd-page .ssd-empty,.ssd-page .ssd-empty-td{color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important}@media(forced-colors:active){.ssd-page{forced-color-adjust:auto}.ssd-page .ssd-card,.ssd-page .ssd-kpi-card{border:1px solid ButtonText!important;background:Canvas!important;color:CanvasText!important}.ssd-page input,.ssd-page select,.ssd-page textarea{border:1px solid ButtonText!important;background:Field!important;color:FieldText!important;-webkit-text-fill-color:FieldText!important}.ssd-page button{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}}.icv-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--soft: #e0f2fe;--ok: #16a34a;--ok-soft: #ecfdf5;--danger: #b91c1c;--danger-soft: #fef2f2;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;min-height:100vh;height:auto;overflow-y:auto;background:var(--bg);color:var(--text);padding:14px 16px;display:flex;flex-direction:column;gap:12px;font-family:var(--pps-font-main);color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.icv-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.icv-title{font-size:var(--fs-18);font-weight:800}.icv-sub{margin-top:2px;color:var(--muted);font-size:var(--fs-13)}.icv-actions{display:flex;gap:8px;flex-wrap:wrap}.icv-btn{height:40px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-weight:700;box-shadow:var(--shadow-sm)}.icv-btn:hover{background:#f1f5f9}.icv-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.icv-filters{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px;display:grid;grid-template-columns:180px 220px 1fr 140px;gap:10px;align-items:end}.icv-field,.icv-searchbox,.icv-searchbox input{min-width:0}.icv-field label{display:block;font-size:var(--fs-12);font-weight:800;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}.icv-field select{width:100%;height:40px;border-radius:12px;border:1px solid #cbd5e1;background:#e8edf5;padding:0 10px;outline:none}.icv-field select:focus{border-color:var(--primary);background:var(--card);box-shadow:0 0 0 3px #0369a11f}.icv-searchbox{height:40px;border-radius:12px;border:1px solid #cbd5e1;background:#e8edf5;display:flex;align-items:center;gap:8px;padding:0 10px}.icv-searchbox input{width:100%;border:none;background:transparent;outline:none;font-size:var(--fs-14)}.icv-searchbox:focus-within{border-color:var(--primary);background:var(--card);box-shadow:0 0 0 3px #0369a11f}.icv-toggle-btn{height:40px;width:100%;border-radius:12px;border:1px solid var(--border);cursor:pointer;font-weight:900}.icv-toggle-btn.on{background:var(--ok-soft);border-color:#86efac;color:#166534}.icv-toggle-btn.off{background:#f1f5f9;color:#334155}.icv-count{font-size:var(--fs-13);color:var(--muted)}.icv-grid{overflow:visible;display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:12px;padding:2px}.icv-tile{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;min-height:unset}.icv-tile-head{padding:10px 12px;border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr auto;gap:10px;align-items:start}.icv-tile-title{font-weight:900;font-size:var(--fs-14);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icv-tile-meta{margin-top:6px;display:flex;gap:6px;flex-wrap:wrap}.icv-badge{font-size:var(--fs-12);font-weight:800;color:#0f172a;background:#f1f5f9;border:1px solid #e2e8f0;padding:2px 8px;border-radius:999px}.icv-pill{font-size:var(--fs-12);font-weight:900;padding:2px 8px;border-radius:999px;border:1px solid transparent}.icv-pill.on{background:var(--ok-soft);border-color:#86efac;color:#166534}.icv-pill.off{background:var(--danger-soft);border-color:#fecaca;color:#991b1b}.icv-icon-btn{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:var(--card);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.icv-icon-btn:hover{background:#f1f5f9}.icv-stream{flex:0 0 auto;width:100%;aspect-ratio:21 / 9;background:#0b1220;position:relative;overflow:hidden}@supports not (aspect-ratio: 21 / 9){.icv-stream{height:260px}}.icv-stream img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center;display:block;background:#0b1220}.icv-fallback{padding:14px;text-align:center;color:#cbd5e1}.icv-fallback-title{font-weight:900;margin-bottom:8px;color:#e2e8f0}.icv-link{color:#7dd3fc;font-weight:800;text-decoration:none}.icv-link:hover{text-decoration:underline}.icv-empty{padding:16px;border:1px dashed var(--border);border-radius:var(--radius);background:#fff;color:var(--muted);text-align:center}.icv-modal-backdrop{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:10px;z-index:999}.icv-modal{width:min(1100px,98vw);height:min(720px,92vh);background:var(--card);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:0 20px 60px #00000059;display:flex;flex-direction:column}.icv-modal-head{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.icv-modal-title{font-weight:900;font-size:var(--fs-15);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icv-modal-sub{font-size:var(--fs-12);color:var(--muted);margin-top:2px}.icv-modal-body{flex:1;background:#0b1220;display:flex;align-items:center;justify-content:center}.icv-modal-img{width:100%;height:100%;object-fit:contain}.icv-modal-foot{padding:10px 14px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}@media(max-width:1100px){.icv-grid{grid-template-columns:repeat(2,minmax(260px,1fr))}.icv-filters{grid-template-columns:1fr 1fr}}@media(max-width:640px){.icv-grid,.icv-filters{grid-template-columns:1fr}}.icv-page input,.icv-page select,.icv-page textarea{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;text-shadow:none!important;background-clip:padding-box;-webkit-appearance:none;appearance:none}.icv-page .icv-field select,.icv-page .icv-searchbox{background:#e8edf5!important}.icv-page .icv-searchbox input{background:transparent!important}.icv-page input::placeholder,.icv-page textarea::placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.icv-page input::-webkit-input-placeholder,.icv-page textarea::-webkit-input-placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.icv-page select option{color:#0f172a!important;background:#fff!important}.icv-page input:-webkit-autofill,.icv-page textarea:-webkit-autofill,.icv-page select:-webkit-autofill{-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}.icv-page .icv-btn,.icv-page .icv-icon-btn,.icv-page .icv-toggle-btn{-webkit-text-fill-color:currentColor!important}.icv-page svg{display:inline-block;vertical-align:middle;overflow:visible}.icv-page button svg,.icv-page .icv-searchbox svg{color:currentColor!important;stroke:currentColor!important;fill:none!important;opacity:1!important;visibility:visible!important}.icv-page .icv-sub,.icv-page .icv-count,.icv-page .icv-field label,.icv-page .icv-modal-sub,.icv-page .icv-empty{color:var(--muted)!important;-webkit-text-fill-color:var(--muted)!important}@media(forced-colors:active){.icv-page{forced-color-adjust:auto}.icv-page input,.icv-page select,.icv-page textarea{border:1px solid ButtonText!important;background:Field!important;color:FieldText!important;-webkit-text-fill-color:FieldText!important}.icv-page button{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}}.icm-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--ok: #16a34a;--ok-soft: #ecfdf5;--danger: #b91c1c;--danger-soft: #fef2f2;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;min-height:100%;background:var(--bg);color:var(--text);padding:14px 16px;display:flex;flex-direction:column;gap:12px;font-family:var(--pps-font-main);color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.icm-page *{box-sizing:border-box}.icm-page svg{display:inline-block;vertical-align:middle;overflow:visible}.icm-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.icm-title{font-size:var(--fs-18);font-weight:900;line-height:1.1}.icm-sub{margin-top:2px;font-size:var(--fs-13);color:var(--muted);max-width:72ch}.icm-actions{display:flex;gap:8px;flex-wrap:wrap}.icm-btn{height:40px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-weight:800;box-shadow:var(--shadow-sm);transition:background .15s ease,filter .15s ease,opacity .15s ease}.icm-btn:hover{background:#f1f5f9}.icm-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.icm-btn.primary{border:none;background:linear-gradient(180deg,var(--primary2),var(--primary));color:#fff;-webkit-text-fill-color:#fff}.icm-btn.primary:hover{filter:brightness(.98)}.icm-btn.ghost{background:#f1f5f9}.icm-filters{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px;display:grid;grid-template-columns:260px 320px 1fr 240px;gap:10px;align-items:end;overflow:visible}.icm-filters>*,.icm-field,.icm-searchbox,.icm-searchbox input{min-width:0}.icm-field label{display:block;font-size:var(--fs-12);font-weight:900;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.35px}.icm-field select,.icm-field input{width:100%;height:40px;border-radius:12px;border:1px solid #cbd5e1;background:#e8edf5;padding:0 10px;outline:none}.icm-searchbox{position:relative;width:100%;height:40px;border-radius:12px;border:1px solid #cbd5e1;background:#e8edf5;display:flex;align-items:center;gap:10px;padding:0 10px;overflow:hidden}.icm-searchbox svg{flex:0 0 auto;width:18px;height:18px;color:var(--muted);position:relative;z-index:2}.icm-searchbox input{flex:1 1 auto;height:100%;line-height:40px;border:none;background:transparent;outline:none;font-size:var(--fs-14);font-weight:800;position:relative;z-index:2}.icm-toggleRow{width:100%;height:40px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 12px;border:1px solid #cbd5e1;background:#e8edf5;border-radius:12px;box-shadow:inset 0 0 0 1px #ffffff40}.icm-toggleLabel{margin:0;font-size:var(--fs-12);font-weight:900;color:var(--muted);white-space:nowrap;text-transform:uppercase;letter-spacing:.35px}.icm-toggleBtn{flex:0 0 auto;height:30px;min-width:88px;padding:0 12px;border-radius:999px;border:1px solid var(--border);cursor:pointer;font-weight:900;background:#fff;transition:filter .15s ease,background .15s ease,border-color .15s ease}.icm-toggleBtn:hover{filter:brightness(.99)}.icm-toggleBtn.on{background:var(--ok-soft);border-color:#86efac;color:#166534}.icm-toggleBtn.off{background:#f1f5f9;color:#334155}.icm-tableWrap{flex:1;min-height:0;overflow:auto;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);font-variant-numeric:tabular-nums}.icm-table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-13)}.icm-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;border-bottom:1px solid rgba(226,232,240,.9);padding:10px;font-weight:900;text-align:left;color:var(--text);white-space:nowrap}.icm-table tbody td{border-bottom:1px solid #eef2f7;padding:10px;vertical-align:middle}.icm-table tbody tr:nth-child(odd) td{background:#f8fafc8c}.icm-table tbody tr:hover td{background:#f1f5f9}.icm-strong{font-weight:900}.icm-mono{font-family:var(--pps-font-mono)}.icm-ellipsis{max-width:420px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icm-row{display:flex;gap:8px;align-items:center}.icm-pill{height:30px;padding:0 10px;border-radius:999px;border:1px solid transparent;font-weight:900;cursor:pointer}.icm-pill.on{background:var(--ok-soft);border-color:#86efac;color:#166534}.icm-pill.off{background:var(--danger-soft);border-color:#fecaca;color:#991b1b}.icm-backdrop{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:10px;z-index:999}.icm-modal{width:min(860px,98vw);height:min(720px,92vh);background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:0 20px 60px #00000059;display:flex;flex-direction:column;overflow:hidden}.icm-modal-head{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:10px}.icm-modal-body{flex:1;min-height:0;overflow:auto;padding:12px 14px}.icm-form{display:grid;grid-template-columns:1fr 1fr;gap:10px}.icm-span2{grid-column:1/span 2}.icm-modal-foot{padding:12px 14px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.icm-page input,.icm-page select,.icm-page textarea{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;text-shadow:none!important;background-clip:padding-box;-webkit-appearance:none;appearance:none}.icm-page input::placeholder,.icm-page textarea::placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.icm-page select option{color:#0f172a!important;background:#fff!important}.icm-page input:-webkit-autofill,.icm-page textarea:-webkit-autofill,.icm-page select:-webkit-autofill{-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}.icm-field select:focus,.icm-field input:focus,.icm-searchbox:focus-within{border-color:var(--primary);background:#fff!important;box-shadow:0 0 0 3px #0369a11f}.icm-btn svg,.icm-searchbox svg{color:currentColor!important;opacity:1!important;visibility:visible!important}@media(max-width:980px){.icm-filters,.icm-form{grid-template-columns:1fr 1fr}}@media(max-width:640px){.icm-filters,.icm-form{grid-template-columns:1fr}.icm-span2{grid-column:auto}}@media(forced-colors:active){.icm-page input,.icm-page select,.icm-page textarea{border:1px solid ButtonText!important;background:Field!important;color:FieldText!important;-webkit-text-fill-color:FieldText!important}.icm-page .icm-btn{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}.icm-page .icm-btn.primary{background:Highlight!important;color:HighlightText!important;-webkit-text-fill-color:HighlightText!important}}.icm-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.icm-actions{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;align-items:center}.icm-headLeft{min-width:0}.ssm-page{padding:16px;background:#f8fafc;min-height:100%;color:#0f172a}.ssm-topbar,.ssm-filters,.ssm-summary,.ssm-bulkbar,.ssm-actions,.ssm-filter-buttons{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.ssm-topbar{justify-content:space-between;margin-bottom:16px}.ssm-title{display:flex;align-items:center;gap:10px;font-size:var(--fs-24);font-weight:700}.ssm-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:16px;box-shadow:0 10px 30px #0f172a0f;margin-bottom:16px}.ssm-field{min-width:180px;display:flex;flex-direction:column;gap:6px}.ssm-field-search{flex:1 1 320px}.ssm-field label{font-size:var(--fs-13);font-weight:600;color:#334155}.ssm-input{width:100%;height:40px;border:1px solid #cbd5e1;border-radius:10px;padding:0 12px;outline:none;background:#fff}.ssm-search-wrap{position:relative}.ssm-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.ssm-search-input{padding-left:36px}.ssm-btn{height:40px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;border-radius:10px;padding:0 14px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-weight:600}.ssm-btn:hover:not(:disabled){background:#f8fafc}.ssm-btn-primary{background:#0f766e;border-color:#0f766e;color:#fff}.ssm-btn-primary:hover:not(:disabled){background:#115e59}.ssm-btn:disabled{opacity:.6;cursor:not-allowed}.ssm-summary{margin-top:12px;color:#475569;font-size:var(--fs-14)}.ssm-table-wrap{overflow:auto;max-height:calc(100vh - 300px);border:1px solid #e2e8f0;border-radius:12px}.ssm-table{width:100%;border-collapse:collapse;min-width:1200px}.ssm-table thead th{position:sticky;top:0;background:#e2e8f0;z-index:1;text-align:left;padding:12px;border-bottom:1px solid #cbd5e1}.ssm-table tbody td{padding:10px 12px;border-bottom:1px solid #e2e8f0;vertical-align:middle}.ssm-table tbody tr:hover{background:#f8fafc}.ssm-table tbody tr.is-changed{background:#fef9c3}.ssm-empty{text-align:center;padding:24px!important;color:#64748b}.ssm-switch{display:inline-flex;align-items:center;gap:10px}.ssm-switch input{display:none}.ssm-slider{width:44px;height:24px;background:#cbd5e1;border-radius:999px;position:relative;transition:.2s ease}.ssm-slider:after{content:"";position:absolute;left:3px;top:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:.2s ease}.ssm-switch input:checked+.ssm-slider{background:#14b8a6}.ssm-switch input:checked+.ssm-slider:after{transform:translate(20px)}.ssm-badge{min-width:62px;text-align:center;border-radius:999px;padding:4px 10px;font-size:var(--fs-12);font-weight:700}.ssm-badge.on{background:#dcfce7;color:#166534}.ssm-badge.off{background:#fee2e2;color:#991b1b}@media(max-width:920px){.ssm-topbar{flex-direction:column;align-items:stretch}.ssm-actions{width:100%}.ssm-btn{justify-content:center}}.ssm-field-search{flex:1 1 420px;display:flex;flex-direction:column;gap:6px}.ssm-search-row{display:flex;align-items:center;gap:12px;width:100%}.ssm-search-wrap{position:relative;flex:1}.ssm-filter-buttons{display:flex;gap:12px;align-items:center;flex-shrink:0}@media(max-width:1200px){.ssm-search-row{flex-wrap:wrap;align-items:stretch}.ssm-filter-buttons{width:100%;flex-wrap:wrap}}.sdc-page{padding:16px;background:#f8fafc;min-height:100%;color:#0f172a}.sdc-topbar,.sdc-actions,.sdc-filter-buttons,.sdc-summary,.sdc-toolbar,.sdc-toolbar-left,.sdc-toolbar-right,.sdc-pagination-controls,.sdc-pagination-info{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.sdc-topbar{justify-content:space-between;margin-bottom:16px}.sdc-title{display:flex;align-items:center;gap:10px;font-size:var(--fs-24);font-weight:700;line-height:1.2}.sdc-card{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:16px;box-shadow:0 8px 24px #0f172a0d;margin-bottom:16px}.sdc-filter-card{padding-bottom:12px}.sdc-filters{display:grid;grid-template-columns:180px minmax(220px,1fr) minmax(220px,1fr) 170px minmax(420px,1.4fr);gap:14px;align-items:end}.sdc-field,.sdc-field-search{min-width:0;display:flex;flex-direction:column;gap:6px}.sdc-field label,.sdc-page-size span{font-size:var(--fs-13);font-weight:700;color:#334155}.sdc-input{width:100%;height:40px;border:1px solid #cbd5e1;border-radius:12px;padding:0 12px;outline:none;background:#fff;color:#0f172a;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.sdc-input:hover{border-color:#94a3b8}.sdc-input:focus{border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61f}.sdc-input:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.sdc-search-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center}.sdc-search-wrap{position:relative;min-width:0}.sdc-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b;pointer-events:none}.sdc-search-input{padding-left:36px}.sdc-btn{height:40px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;border-radius:12px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-weight:700;white-space:nowrap;transition:background-color .15s ease,border-color .15s ease,transform .05s ease}.sdc-btn:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8}.sdc-btn:active:not(:disabled){transform:translateY(1px)}.sdc-btn-primary{background:#7bb5ad;border-color:#7bb5ad;color:#fff}.sdc-btn-primary:hover:not(:disabled){background:#6aa79f;border-color:#6aa79f}.sdc-btn:disabled{opacity:.6;cursor:not-allowed}.sdc-filter-buttons{flex-wrap:nowrap}.sdc-summary{margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0;color:#475569;font-size:var(--fs-14);row-gap:8px}.sdc-summary span{display:inline-flex;align-items:center;gap:4px}.sdc-toolbar{justify-content:space-between;gap:16px;margin-bottom:14px;padding:12px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px}.sdc-toolbar-left,.sdc-toolbar-right{gap:12px}.sdc-toolbar-right{margin-left:auto;justify-content:flex-end}.sdc-pagination-info{color:#334155;font-size:var(--fs-14);font-weight:500}.sdc-pagination-controls{gap:10px}.sdc-page-size{display:flex;flex-direction:column;gap:6px;min-width:130px}.sdc-page-size-inline{flex-direction:row;align-items:center;gap:8px}.sdc-page-size-inline .sdc-input{width:120px}.sdc-table-wrap{overflow:auto;max-height:calc(100vh - 320px);border:1px solid #e2e8f0;border-radius:14px;background:#fff}.sdc-table{width:100%;border-collapse:collapse;min-width:1280px}.sdc-table thead th{position:sticky;top:0;background:#e2e8f0;z-index:2;text-align:left;padding:12px;border-bottom:1px solid #cbd5e1;color:#0f172a;font-weight:700;white-space:nowrap}.sdc-table tbody td{padding:10px 12px;border-bottom:1px solid #e2e8f0;vertical-align:middle}.sdc-table tbody tr:hover{background:#f8fafc}.sdc-table tbody tr.is-changed{background:#fef9c3}.sdc-table tbody tr.is-changed:hover{background:#fde68a}.sdc-cell-wrap{white-space:normal;word-break:break-word;line-height:1.45}.sdc-empty{text-align:center;padding:24px!important;color:#64748b}.sdc-switch{display:inline-flex;align-items:center;gap:10px}.sdc-switch input{display:none}.sdc-slider{width:44px;height:24px;background:#cbd5e1;border-radius:999px;position:relative;transition:.2s ease;flex-shrink:0}.sdc-slider:after{content:"";position:absolute;left:3px;top:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:.2s ease;box-shadow:0 1px 2px #0f172a33}.sdc-switch input:checked+.sdc-slider{background:#14b8a6}.sdc-switch input:checked+.sdc-slider:after{transform:translate(20px)}.sdc-badge{min-width:62px;text-align:center;border-radius:999px;padding:4px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2}.sdc-badge.on{background:#dcfce7;color:#166534}.sdc-badge.off{background:#fee2e2;color:#991b1b}@media(max-width:1440px){.sdc-filters{grid-template-columns:repeat(4,minmax(180px,1fr))}.sdc-field-search{grid-column:1 / -1}}@media(max-width:1100px){.sdc-search-row{grid-template-columns:1fr}.sdc-filter-buttons{flex-wrap:wrap}.sdc-toolbar{flex-direction:column;align-items:stretch}.sdc-toolbar-right{margin-left:0;justify-content:flex-start}}@media(max-width:920px){.sdc-topbar{flex-direction:column;align-items:stretch}.sdc-actions{width:100%}.sdc-actions .sdc-btn{flex:1 1 0}.sdc-filters{grid-template-columns:1fr}.sdc-page-size-inline{flex-direction:column;align-items:flex-start}.sdc-pagination-controls .sdc-btn{flex:1 1 120px}}@media(max-width:640px){.sdc-page{padding:12px}.sdc-card{padding:12px;border-radius:14px}.sdc-title{font-size:var(--fs-20)}.sdc-btn,.sdc-filter-buttons .sdc-btn{width:100%}.sdc-summary{font-size:var(--fs-13)}}.up-page{padding:16px 24px;height:100%;background:#f8fafc;font-size:var(--fs-16);font-weight:400}.up-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.up-title{display:flex;align-items:center;gap:10px;color:#111827}.up-title h2{margin:0;font-size:var(--fs-16);font-weight:700;color:#111827}.up-btn-primary,.up-btn-secondary{height:42px;padding:0 18px;border-radius:12px;cursor:pointer;font-weight:700;font-size:var(--fs-16);text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap}.up-btn{height:40px;padding:0 16px;border-radius:12px;font-weight:700;font-size:var(--fs-16);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background .15s ease,border-color .15s ease,transform .1s ease}.up-btn:active{transform:translateY(0)}.up-btn:hover{transform:translateY(-1px)}.up-btn:focus{outline:none;box-shadow:0 0 0 3px #0369a11f}.up-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.up-btn-primary{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a}.up-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.up-btn-secondary{border:1px solid #e5e7eb;background:#fee2e2;color:#991b1b}.up-btn-secondary:hover{background:#fecaca;border-color:#fca5a5}.up-header .up-btn-primary{width:220px;flex:0 0 auto}.up-header button.up-btn-primary{width:220px!important}.up-role-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px;margin-bottom:12px;box-shadow:0 6px 16px #0000000d}.up-role-title{font-size:var(--fs-16);font-weight:700;margin-bottom:8px;color:#111827}.up-role-table{width:100%;border-collapse:collapse}.up-role-table th{text-align:left;font-size:var(--fs-16);font-weight:700;padding:8px 10px;background:#f8fafc;border-bottom:1px solid #e5e7eb;white-space:nowrap;color:#111827}.up-role-table td{padding:8px 10px;border-bottom:1px solid #f3f4f6;font-size:var(--fs-16);font-weight:400;color:#111827}.up-toolbar{display:flex;align-items:center;margin-bottom:12px}.up-search{position:relative;width:100%;max-width:560px}.up-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65;font-size:var(--fs-16);font-weight:700}.up-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-16);font-weight:400;color:#111827}.up-search-input:focus{outline:none;background:#fff}.up-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 260px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.up-card::-webkit-scrollbar{width:8px;height:8px}.up-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.up-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.up-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.up-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-16);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.up-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;font-size:var(--fs-16);font-weight:400;color:#111827;vertical-align:top;line-height:1.35}.up-table tr:hover{background:#f8fafc}.up-mono{font-family:var(--pps-font-mono)}.up-badge{padding:4px 10px;border-radius:999px;font-size:var(--fs-16);font-weight:700}.up-active{background:#dcfce7;color:#166534}.up-inactive{background:#fee2e2;color:#991b1b}.up-actions{display:flex;gap:10px;justify-content:flex-end;padding-right:6px}.up-icon-btn{height:36px;min-width:110px;padding:0 12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:var(--fs-16);color:#111827;white-space:nowrap;box-shadow:0 1px #0f172a0a}.up-icon-text{font-size:var(--fs-16);font-weight:400}.up-icon-btn:hover{background:#f8fafc;border-color:#cbd5e1}.up-icon-btn.up-edit:hover{background:#e0f2fe;border-color:#7dd3fc}.up-icon-btn.up-del:hover{background:#fee2e2;border-color:#fecaca}.up-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999;overflow:hidden}.up-modal{width:min(1100px,100%);max-height:calc(100dvh - 32px);background:#fff;border-radius:18px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #0003;overflow:hidden;display:flex;flex-direction:column}.up-modal-header{position:relative;display:flex;justify-content:flex-start;align-items:center;padding:12px 14px;background:#f8fafc;border-bottom:1px solid #e5e7eb;flex:0 0 auto}.up-modal-title{display:flex;align-items:center;gap:10px;font-size:var(--fs-16);font-weight:700;color:#111827}.up-modal-close{position:absolute;top:10px;right:12px;height:34px;width:34px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-size:var(--fs-22);line-height:1;display:inline-flex;align-items:center;justify-content:center}.up-modal-close:hover{background:#f8fafc}.up-form{padding:14px;overflow:auto;flex:1 1 auto;min-height:0;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.up-form::-webkit-scrollbar{width:8px;height:8px}.up-form::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.up-form::-webkit-scrollbar-thumb:hover{background:#94a3b8}.up-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.up-form label{display:block;font-size:var(--fs-16);font-weight:700;margin-bottom:6px;color:#111827}.up-form input,.up-form select{width:100%;height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-16);font-weight:400;color:#111827}.up-form input:focus,.up-form select:focus{outline:none;background:#fff}.up-password{position:relative}.up-pass-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65;font-size:var(--fs-16);font-weight:700}.up-password input{padding-left:38px}.up-role-hint,.up-hint{margin-top:6px;font-size:var(--fs-16);font-weight:400;color:#6b7280;opacity:1}.up-scope{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:12px}.up-scope-box{border:1px solid #e5e7eb;border-radius:14px;padding:12px;background:#fff}.up-form-actions{position:sticky;bottom:-14px;z-index:5;display:flex;justify-content:flex-end;gap:10px;margin:14px -14px -14px;padding:12px 14px;background:#fffffff5;border-top:1px solid #e5e7eb;box-shadow:0 -10px 24px #0f172a0f;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.up-loading{padding:10px;text-align:center;color:#6b7280;font-weight:700;font-size:var(--fs-16)}.up-deny{padding:16px;border:1px solid #fecaca;background:#fff1f2;border-radius:12px;color:#991b1b;font-size:var(--fs-16);font-weight:700}:root{--up-text: #0f172a;--up-muted: #64748b;--up-border: #e2e8f0;--up-bg: #ffffff;--up-soft: #f8fafc;--up-blue: #0284c7;--up-blue-soft: #e0f2fe}.ms-field{display:flex;flex-direction:column;gap:8px}.ms-label-row{display:flex;align-items:center;justify-content:space-between}.ms-label{font-weight:700;font-size:var(--fs-16);color:var(--up-text);letter-spacing:.2px}.ms-clear{border:none;background:transparent;cursor:pointer;font-weight:700;font-size:var(--fs-16);color:var(--up-blue);padding:2px 6px;border-radius:8px}.ms-clear:hover{background:var(--up-blue-soft)}.ms-selected{min-height:44px;border:1px solid var(--up-border);background:var(--up-soft);border-radius:12px;padding:8px 10px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.ms-placeholder{color:var(--up-muted);font-size:var(--fs-16);font-weight:400;padding-left:2px}.ms-tag{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:6px 10px;border:1px solid #dbeafe;background:#eff6ff;color:#1e40af;font-weight:700;font-size:var(--fs-16)}.ms-tag-text{font-family:var(--pps-font-mono);letter-spacing:.2px}.ms-tag-x{border:none;background:transparent;cursor:pointer;height:20px;width:20px;border-radius:999px;font-size:var(--fs-16);line-height:1;color:#64748b;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.ms-tag-x:hover{background:#0284c71f;color:#0f172a}.ms-trigger{height:40px;border-radius:12px;border:1px solid var(--up-border);background:var(--up-bg);cursor:pointer;font-weight:700;font-size:var(--fs-16);color:var(--up-text);display:inline-flex;align-items:center;justify-content:space-between;padding:0 12px;box-shadow:0 1px #0f172a0a}.ms-trigger:hover{background:var(--up-soft)}.ms-caret{color:var(--up-muted);font-size:var(--fs-16);font-weight:700}.ms-panel{margin-top:6px;border:1px solid var(--up-border);border-radius:14px;overflow:hidden;background:var(--up-bg);box-shadow:0 18px 46px #0206171f}.ms-search-wrap{padding:10px;border-bottom:1px solid var(--up-border);background:var(--up-soft)}.ms-search{width:100%;height:38px;border-radius:12px;border:1px solid var(--up-border);background:#fff;padding:0 12px;font-size:var(--fs-16);font-weight:400;color:var(--up-text)}.ms-search:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f626}.ms-list{max-height:260px;overflow:auto}.ms-item{width:100%;border:none;background:#fff;cursor:pointer;padding:10px 12px;display:grid;grid-template-columns:26px 1fr;gap:10px;text-align:left;border-bottom:1px solid #f1f5f9}.ms-item:hover{background:var(--up-soft)}.ms-item.on{background:#ecfeff}.ms-check{height:18px;width:18px;border-radius:6px;border:1px solid #cbd5e1;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--fs-16);color:#0f766e}.ms-check.on{border-color:#5eead4;background:#ccfbf1}.ms-item-main{display:flex;flex-direction:column;gap:2px}.ms-item-text{font-weight:700;font-size:var(--fs-16);color:var(--up-text)}.ms-item-sub{font-size:var(--fs-16);font-weight:400;color:#6b7280}.ms-empty{padding:14px;text-align:center;color:var(--up-muted);font-size:var(--fs-16);font-weight:400}.ms-field.is-disabled .ms-trigger,.ms-field.is-disabled .ms-selected{opacity:.6;cursor:not-allowed}.up-wrap2{white-space:normal!important;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:20}.up-td-dept{max-width:520px}.up-td-plant{max-width:220px}.up-td-mrp{max-width:520px}@media(max-width:1024px){.up-scope{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.up-modal-backdrop{padding:8px;align-items:stretch}.up-modal{max-height:calc(100dvh - 16px);border-radius:14px}.up-header .up-btn-primary{width:100%!important}.up-actions{justify-content:center;padding-right:0}.up-icon-btn{min-width:100px}.up-grid,.up-scope{grid-template-columns:1fr}.up-form-actions{justify-content:stretch}.up-form-actions .up-btn-primary,.up-form-actions .up-btn-secondary{flex:1 1 0;padding:0 10px}}.ms-label-actions{display:flex;gap:8px;align-items:center}.ms-list.ms-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.ms-list.ms-grid .ms-item{width:100%}.up-mrp-cell{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;white-space:normal;line-height:1.4;max-width:180px}.up-mrp-cell{max-width:220px;line-height:1.4}.up-mrp-toggle{margin-left:6px;background:none;border:none;color:#0284c7;font-size:var(--fs-12);cursor:pointer;padding:0}.up-mrp-toggle:hover{text-decoration:underline}.up-users-table{width:100%;min-width:1180px;table-layout:fixed}.up-users-table th,.up-users-table td{white-space:normal;vertical-align:middle}.up-users-table .up-col-no{width:56px;text-align:center}.up-users-table .up-col-user{width:220px}.up-users-table .up-col-role{width:130px}.up-users-table .up-col-contact,.up-users-table .up-col-dept{width:260px}.up-users-table .up-col-plant{width:240px}.up-users-table .up-col-telegram{width:110px;text-align:center}.up-users-table .up-col-actions{width:230px}.up-cell-title{color:#0f172a;font-weight:700;line-height:1.25}.up-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.up-role-badge{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:4px 10px;border-radius:999px;border:1px solid #bae6fd;background:#e0f2fe;color:#075985;font-family:var(--pps-font-mono);font-size:var(--fs-13, 13px);font-weight:800;white-space:nowrap}.up-chip-list{display:flex;align-items:center;flex-wrap:wrap;gap:6px;max-height:72px;overflow:hidden}.up-chip{display:inline-flex;align-items:center;max-width:100%;min-height:26px;padding:3px 8px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;color:#334155;font-size:var(--fs-12, 12px);font-weight:700;line-height:1.2}.up-users-table .up-actions{justify-content:flex-start;align-items:center;gap:8px;flex-wrap:wrap}.up-users-table .up-icon-btn{min-width:96px;height:34px;padding:0 10px;font-size:var(--fs-13, 13px)}.up-users-table .up-icon-text{font-size:var(--fs-13, 13px)}.up-users-table .up-badge{display:inline-flex;align-items:center;justify-content:center;min-width:54px;min-height:28px;font-size:var(--fs-13, 13px)}.up-wrap2{-webkit-line-clamp:2;line-clamp:2;line-height:1.35}@media(max-width:1280px){.up-users-table{min-width:1040px}.up-users-table .up-col-contact{width:230px}.up-users-table .up-col-dept,.up-users-table .up-col-plant{width:210px}.up-users-table .up-col-actions{width:190px}}.up-users-table-original-heads{width:100%;min-width:1420px;table-layout:fixed}.up-users-table-original-heads th,.up-users-table-original-heads td{white-space:normal;vertical-align:middle}.up-users-table-original-heads .up-col-no{width:60px;text-align:center}.up-users-table-original-heads .up-col-username,.up-users-table-original-heads .up-col-fullname{width:180px}.up-users-table-original-heads .up-col-email{width:220px}.up-users-table-original-heads .up-col-phone{width:140px}.up-users-table-original-heads .up-col-emp{width:120px}.up-users-table-original-heads .up-col-dept{width:140px}.up-users-table-original-heads .up-col-app,.up-users-table-original-heads .up-col-role,.up-users-table-original-heads .up-col-plant,.up-users-table-original-heads .up-col-mrp{width:100px}.up-users-table-original-heads .up-col-telegram{width:120px;text-align:center}.up-users-table-original-heads .up-col-serial{width:220px}.up-users-table-original-heads .up-col-status{width:110px;text-align:center}.up-users-table-original-heads .up-col-actions{width:160px}.up-row-no{color:#475569;font-weight:700}.up-user-cell,.up-contact-cell{display:flex;flex-direction:column;gap:4px;min-width:0}.up-cell-title{color:#0f172a;font-weight:700;line-height:1.25;overflow:hidden;text-overflow:ellipsis}.up-cell-sub,.up-cell-meta,.up-muted{color:#64748b;font-size:var(--fs-13, 13px);line-height:1.3}.up-email{white-space:nowrap;max-width:100%}.up-role-badge,.up-app-badge{display:inline-flex;align-items:center;justify-content:center;min-height:28px;max-width:100%;padding:4px 10px;border-radius:999px;border:1px solid #bae6fd;background:#e0f2fe;color:#075985;font-family:var(--pps-font-mono);font-size:var(--fs-13, 13px);font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-app-badge{border-color:#e2e8f0;background:#f8fafc;color:#334155}.up-chip-list{display:flex;align-items:center;flex-wrap:wrap;gap:6px;max-height:58px;overflow:hidden}.up-chip{display:inline-flex;align-items:center;max-width:100%;min-height:24px;padding:3px 8px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;color:#334155;font-size:var(--fs-12, 12px);font-weight:700;line-height:1.2}.up-chip-mono{font-family:var(--pps-font-mono)}.up-chip-more{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.up-users-table-original-heads .up-actions{justify-content:flex-start;align-items:center;gap:8px;flex-wrap:wrap}.up-users-table-original-heads .up-icon-btn{min-width:96px;height:34px;padding:0 10px;font-size:var(--fs-13, 13px)}.up-users-table-original-heads .up-icon-text{font-size:var(--fs-13, 13px)}.up-users-table-original-heads .up-badge{display:inline-flex;align-items:center;justify-content:center;min-width:54px;min-height:28px;font-size:var(--fs-13, 13px)}.up-serial-plants{margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:1280px){.up-users-table-original-heads{min-width:1320px}.up-users-table-original-heads .up-col-fullname{width:160px}.up-users-table-original-heads .up-col-email{width:200px}.up-users-table-original-heads .up-col-serial{width:190px}.up-users-table-original-heads .up-col-actions{width:150px}}.hmv-page{min-height:100%;width:100%;max-width:100%;overflow-x:hidden}.hmv-page,.hmv-page *{box-sizing:border-box}.hmv-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;min-width:0;max-width:100%}.hmv-header>div{min-width:0}.hmv-header .up-btn-primary{flex:0 0 auto;max-width:100%;white-space:nowrap}.hmv-title{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:800;color:#0f172a;min-width:0;overflow-wrap:anywhere}.hmv-subtitle{margin-top:6px;color:#64748b;font-size:13px}.hmv-layout{display:grid;grid-template-columns:minmax(280px,380px) minmax(0,1fr);gap:16px;align-items:start;width:100%;max-width:100%;min-width:0}.hmv-menu-panel{min-width:0;max-width:100%}.hmv-user-panel{position:sticky;top:12px;padding:14px;max-height:calc(100vh - 128px);overflow:hidden;display:flex;flex-direction:column;gap:10px;min-width:0;max-width:100%}.hmv-panel-title{display:flex;align-items:center;gap:8px;color:#0f172a;font-weight:800;font-size:15px}.hmv-user-search{margin:0;min-width:0;width:100%}.hmv-user-meta{min-height:18px;color:#64748b;font-size:12px}.hmv-user-meta span{display:inline-flex;align-items:center;gap:6px}.hmv-spin{animation:hmv-spin .8s linear infinite}@keyframes hmv-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hmv-user-list{display:grid;gap:6px;overflow:auto;padding-right:4px;max-height:300px}.hmv-user-row{width:100%;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;text-align:left;border:1px solid #e2e8f0;background:#fff;color:#0f172a;border-radius:12px;padding:10px;cursor:pointer}.hmv-user-row:hover{background:#f8fafc;border-color:#bfdbfe}.hmv-user-row.active{background:#eff6ff;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1f}.hmv-user-main{min-width:0}.hmv-user-main b,.hmv-user-main em{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hmv-user-main b{font-size:13px;font-weight:800}.hmv-user-main em{margin-top:2px;color:#64748b;font-size:12px;font-style:normal}.hmv-user-badges{display:flex;flex-direction:column;gap:4px;align-items:flex-end}.hmv-user-badges small{max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-radius:999px;background:#f1f5f9;color:#334155;font-size:10px;font-weight:800;padding:3px 7px}.hmv-empty-user{text-align:center;color:#94a3b8;border:1px dashed #cbd5e1;border-radius:12px;padding:20px 10px}.hmv-load-more{border:1px solid #cbd5e1;background:#fff;color:#1e40af;border-radius:12px;padding:10px 12px;font-weight:800;cursor:pointer}.hmv-load-more:hover{background:#eff6ff}.hmv-toolbar{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;padding:14px;margin-bottom:16px;width:100%;max-width:100%;min-width:0;overflow:hidden}.hmv-toolbar>*{min-width:0}.hmv-selected-user{flex:1 1 260px;min-width:0}.hmv-selected-user span{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13px;color:#334155;margin-bottom:7px}.hmv-selected-user b{display:block;height:42px;line-height:42px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:1px solid #cbd5e1;border-radius:12px;padding:0 12px;background:#f8fafc;color:#0f172a;font-size:13px}.hmv-search{flex:1 1 260px;margin:0;min-width:0;width:auto}.hmv-page .up-search{max-width:100%}.hmv-page .up-search-input{min-width:0;width:100%}.hmv-counter{flex:0 1 auto;min-width:0;max-width:100%;min-height:42px;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:999px;background:#eef2ff;color:#3730a3;font-weight:800;white-space:normal;overflow-wrap:anywhere;text-align:center}.hmv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,340px),1fr));gap:14px;width:100%;max-width:100%;min-width:0}.hmv-group-card{min-width:0;max-width:100%;background:#fff;border:1px solid #e2e8f0;border-radius:18px;box-shadow:0 12px 30px #0f172a0f;overflow:hidden}.hmv-group-head{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;padding:14px;background:linear-gradient(180deg,#f8fafc,#fff);border-bottom:1px solid #e2e8f0}.hmv-checkline{display:flex;align-items:flex-start;gap:10px;cursor:pointer;min-width:0}.hmv-checkline input,.hmv-mini-check input{margin-top:3px;width:16px;height:16px;accent-color:#2563eb}.hmv-checkline span{min-width:0}.hmv-checkline b{display:block;color:#0f172a;font-size:13px;word-break:break-word}.hmv-checkline em{display:block;margin-top:2px;color:#64748b;font-size:12px;font-style:normal;word-break:break-word}.hmv-group-check b{font-size:14px}.hmv-mini-check{flex:0 0 auto;display:flex;align-items:center;gap:6px;color:#475569;font-size:12px;white-space:nowrap}.hmv-items{display:grid;gap:2px;padding:8px;max-height:360px;overflow:auto}.hmv-item-check{padding:9px 10px;border-radius:12px}.hmv-item-check:hover{background:#f8fafc}@media(max-width:1100px){.hmv-layout{grid-template-columns:1fr}.hmv-toolbar{display:grid;grid-template-columns:1fr}.hmv-counter{width:100%}.hmv-user-panel{position:static;max-height:none}.hmv-user-list{max-height:420px}}@media(max-width:900px){.hmv-header{flex-direction:column}.hmv-header .up-btn-primary{width:100%;justify-content:center}.hmv-grid{grid-template-columns:1fr}}@media(max-width:520px){.hmv-group-head{align-items:flex-start;flex-direction:column}.hmv-mini-check{margin-left:26px}}.moee-page{padding:16px 24px;height:100%;background:#f8fafc;font-size:var(--fs-16);font-weight:400;color:#111827}.moee-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.moee-title{display:flex;align-items:center;gap:10px;color:#111827}.moee-title h2{margin:0;font-size:var(--fs-16);font-weight:700}.moee-btn-primary{height:42px;width:220px;padding:0 18px;border-radius:12px;border:1px solid #bae6fd;background:#e0f2fe;cursor:pointer;font-weight:700;font-size:var(--fs-16);color:#0f172a;text-align:center;white-space:nowrap}.moee-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.moee-btn-secondary{height:40px;padding:0 16px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-weight:700;font-size:var(--fs-16);color:#0f172a;text-align:center;white-space:nowrap}.moee-btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.moee-btn-secondary:disabled,.moee-btn-primary:disabled{opacity:.65;cursor:not-allowed}.moee-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:12px}.moee-search{position:relative;width:100%;max-width:720px}.moee-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65;font-size:var(--fs-16);font-weight:700}.moee-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-16);font-weight:400;color:#111827}.moee-search-input:focus{outline:none;background:#fff}.moee-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 210px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.moee-card::-webkit-scrollbar{width:8px;height:8px}.moee-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.moee-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.moee-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.moee-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-16);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.moee-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;font-size:var(--fs-16);font-weight:400;color:#111827}.moee-table tr:hover{background:#f8fafc}.moee-mono{font-family:var(--pps-font-mono)}.moee-center{text-align:center}.moee-loading,.moee-empty{padding:10px;text-align:center;font-size:var(--fs-16);font-weight:700;color:#6b7280}.moee-badge{padding:4px 10px;border-radius:999px;font-size:var(--fs-16);font-weight:700}.moee-posted{background:#dcfce7;color:#166534}.moee-not{background:#fee2e2;color:#991b1b}.moee-actions{display:flex;justify-content:flex-end;gap:8px;white-space:nowrap}.moee-icon-btn{height:36px;min-width:110px;padding:0 12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:var(--fs-16);color:#111827;white-space:nowrap;box-shadow:0 1px #0f172a0a}.moee-icon-text{font-size:var(--fs-16);font-weight:700}.moee-icon-btn:hover{background:#e0f2fe;border-color:#7dd3fc}.moee-icon-btn.moee-del:hover{background:#fee2e2;border-color:#fecaca}.moee-pagination{margin-top:12px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.moee-pageinfo{font-size:var(--fs-16);font-weight:700;color:#111827}.moee-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.moee-modal{width:min(980px,100%);background:#fff;border-radius:18px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #0003;overflow:hidden}.moee-modal-header{display:flex;align-items:center;padding:12px 14px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.moee-modal-title{display:flex;align-items:center;gap:10px;font-weight:700;font-size:var(--fs-16);color:#111827}.moee-form{padding:14px}.moee-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;align-items:start}.moee-col-span-2{grid-column:span 2}.moee-col-span-3{grid-column:span 3}@media(max-width:980px){.moee-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:820px){.moee-grid{grid-template-columns:1fr}}.moee-field label{display:block;font-size:var(--fs-16);font-weight:700;margin-bottom:6px;color:#111827}.moee-field input{width:100%;height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-16);font-weight:400;color:#111827}.moee-field input:focus{outline:none;background:#fff}.moee-switch-row{margin-top:12px;display:flex;justify-content:flex-start}.moee-switch{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:var(--fs-16);color:#111827}.moee-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.moee-hint{margin-top:10px;font-size:var(--fs-16);font-weight:700;opacity:.75;color:#6b7280}.moee-flags{grid-column:1 / -1}.moee-flags-box{border:1px solid #e5e7eb;background:#f8fafc;border-radius:14px;padding:10px 12px}.moee-checklist{display:flex;flex-wrap:wrap;gap:10px 14px}.moee-check{display:inline-flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;font-size:var(--fs-16);font-weight:700;color:#0f172a;box-shadow:0 1px #0f172a0a}.moee-check:hover{background:#e0f2fe;border-color:#7dd3fc}.moee-check input[type=checkbox]{width:18px;height:18px;accent-color:#0284c7;cursor:pointer}.moee-check small{font-size:var(--fs-16);font-weight:700;color:#111827}@media(max-width:820px){.moee-checklist{gap:10px}.moee-check{width:100%;justify-content:flex-start}}.moee-deny{padding:16px;border:1px solid #fecaca;background:#fff1f2;border-radius:12px;color:#991b1b;font-size:var(--fs-16);font-weight:700}:root{--ss-text: #0f172a;--ss-muted: #64748b;--ss-border: #e2e8f0;--ss-bg: #ffffff;--ss-soft: #f8fafc;--ss-blue: #0284c7;--ss-blue-soft: #e0f2fe}.ss-field{display:flex;flex-direction:column;gap:8px}.ss-label{font-weight:700;font-size:var(--fs-16);color:var(--ss-text)}.ss-selected{min-height:44px;border:1px solid var(--ss-border);background:var(--ss-soft);border-radius:12px;padding:8px 10px;display:flex;align-items:center}.ss-placeholder{color:var(--ss-muted);font-size:var(--fs-16);font-weight:400}.ss-picked-main{display:flex;gap:8px;align-items:baseline}.ss-picked-text{font-weight:400;color:var(--ss-text);font-size:var(--fs-16)}.ss-picked-val{color:var(--ss-muted);font-size:var(--fs-16);font-weight:700}.ss-picked-sub{margin-top:4px;color:var(--ss-muted);font-size:var(--fs-16);font-weight:400}.ss-trigger{height:40px;border-radius:12px;border:1px solid var(--ss-border);background:var(--ss-bg);cursor:pointer;font-weight:700;font-size:var(--fs-16);color:var(--ss-text);display:inline-flex;align-items:center;justify-content:space-between;padding:0 12px}.ss-trigger:hover{background:var(--ss-soft)}.ss-caret{color:var(--ss-muted);font-size:var(--fs-16);font-weight:700}.ss-panel{margin-top:6px;border:1px solid var(--ss-border);border-radius:14px;overflow:hidden;background:var(--ss-bg);box-shadow:0 18px 46px #0206171f}.ss-search-wrap{padding:10px;border-bottom:1px solid var(--ss-border);background:var(--ss-soft)}.ss-search{width:100%;height:38px;border-radius:12px;border:1px solid var(--ss-border);background:#fff;padding:0 12px;font-size:var(--fs-16);font-weight:400;color:var(--ss-text)}.ss-search:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f626}.ss-list{max-height:260px;overflow:auto}.ss-item{width:100%;border:none;background:#fff;cursor:pointer;padding:10px 12px;display:grid;grid-template-columns:26px 1fr;gap:10px;text-align:left;border-bottom:1px solid #f1f5f9}.ss-item:hover{background:#f8fafc}.ss-item.on{background:var(--ss-blue-soft)}.ss-check{width:22px;height:22px;border-radius:8px;border:1px solid var(--ss-border);display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:var(--fs-16);color:var(--ss-blue)}.ss-check.on{border-color:#7dd3fc;background:#fff}.ss-item-main{display:grid}.ss-item-text{font-weight:700;color:var(--ss-text);font-size:var(--fs-16)}.ss-item-sub{font-size:var(--fs-16);color:var(--ss-muted);font-weight:400;margin-top:2px}.ss-empty{padding:12px;color:var(--ss-muted);font-weight:400;font-size:var(--fs-16)}.is-disabled{opacity:.65;pointer-events:none}.tl-paging{margin-top:12px;background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:nowrap}.tl-paging-left,.tl-paging-center,.tl-paging-right{display:flex;align-items:center;gap:10px;white-space:nowrap}.tl-paging-left{min-width:220px}.tl-paging-center{flex:1;justify-content:center}.tl-paging-right{min-width:220px;justify-content:flex-end}.tl-paging-meta{font-size:var(--fs-16);font-weight:700;color:#111827}.tl-btn-ghost{height:40px;width:100px;padding:0 14px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-size:var(--fs-16);font-weight:700;color:#111827;white-space:nowrap}.tl-btn-ghost:hover{background:#f8fafc;border-color:#cbd5e1}.tl-btn-ghost:disabled{opacity:.55;cursor:not-allowed}.tl-pagebox{display:inline-flex;align-items:center;gap:10px;font-size:var(--fs-16);font-weight:700;color:#111827}.tl-pagebox input{width:90px;height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-16);font-weight:700;color:#111827;text-align:center}@media(max-width:640px){.tl-paging{flex-wrap:wrap;justify-content:center}.tl-paging-left,.tl-paging-center,.tl-paging-right{width:100%;justify-content:center;min-width:0}.tl-paging-right{justify-content:center}}.moee-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.moee-modal{width:min(980px,100%);background:#fff;border-radius:18px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #0003;overflow:hidden;max-height:calc(100vh - 32px);max-height:calc(100dvh - 32px);display:flex;flex-direction:column}.moee-modal-header{display:flex;align-items:center;padding:12px 14px;background:#f8fafc;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:2}.moee-form{padding:14px;overflow:auto;-webkit-overflow-scrolling:touch;min-height:0}.moee-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px;position:sticky;bottom:0;z-index:2;background:#fff;padding-top:10px;border-top:1px solid #f1f5f9}@media(max-width:640px){.moee-modal-backdrop{padding:10px}.moee-modal{max-height:calc(100dvh - 20px)}}.tl-page{padding:16px 24px;height:100%;background:#f8fafc;font-size:var(--fs-16);font-weight:400;color:#111827}.tl-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.tl-title{display:flex;align-items:center;gap:10px;color:#111827}.tl-title h2{margin:0;font-size:var(--fs-16);font-weight:700}.tl-btn-primary{height:42px;width:220px;padding:0 18px;border-radius:12px;border:1px solid #bae6fd;background:#e0f2fe;cursor:pointer;font-weight:700;color:#0f172a;text-align:center;margin-left:auto;font-size:var(--fs-16)}.tl-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.tl-btn-primary:disabled{opacity:.6;cursor:not-allowed}.tl-toolbar{display:flex;align-items:center;margin-bottom:12px;justify-content:space-between;gap:12px}.tl-search{position:relative;width:100%;max-width:720px}.tl-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65;font-size:var(--fs-16);font-weight:700}.tl-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-16);font-weight:400;color:#111827}.tl-search-input:focus{outline:none;background:#fff}.tl-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 210px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.tl-card::-webkit-scrollbar{width:8px;height:8px}.tl-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.tl-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.tl-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.tl-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-16);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.tl-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;font-size:var(--fs-16);font-weight:400;color:#111827}.tl-table tr:hover{background:#f8fafc}.tl-mono{font-family:var(--pps-font-mono)}.tl-deny{padding:16px;border:1px solid #fecaca;background:#fff1f2;border-radius:12px;color:#991b1b;font-size:var(--fs-16);font-weight:700}.tl-filters{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000d;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:12px}.tl-field{display:flex;flex-direction:column;gap:6px}.tl-field label{font-size:var(--fs-16);font-weight:700;color:#0f172a}.tl-input{height:40px;border-radius:10px;border:1px solid #cbd5e1;background:#eef6ff;padding:0 12px;font-size:var(--fs-16);font-weight:400;min-width:160px;color:#0f172a}.tl-input::placeholder{color:#94a3b8;font-weight:400}.tl-input:focus{outline:none;border-color:#7dd3fc;background:#fff;box-shadow:0 0 0 2px #bae6fd}.tl-meta{margin-left:auto;font-size:var(--fs-16);color:#6b7280;font-weight:700;padding-bottom:2px}@media(max-width:900px){.tl-meta{width:100%;margin-left:0}.tl-input{min-width:140px}}.tl-empty{padding:18px;text-align:center;color:#6b7280;font-weight:700;font-size:var(--fs-16)}.tl-path{max-width:520px;overflow:hidden;text-overflow:ellipsis}.tl-badge{padding:4px 10px;border-radius:999px;font-size:var(--fs-16);font-weight:700}.tl-badge.info{background:#f0f9ff;border:1px solid #7dd3fc;color:#0ea5e9}.tl-badge.warn{background:#fef3c7;border:1px solid #fcd34d;color:#f59e0b}.tl-badge.error{background:#fee2e2;border:1px solid #fecaca;color:#ef4444}.tl-paging{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding:12px 16px;background:#fff;border-radius:16px;box-shadow:0 10px 26px #0000000f;flex-wrap:nowrap}.tl-paging-left,.tl-paging-center,.tl-paging-right{display:flex;align-items:center;gap:8px;flex:0 0 auto}.tl-btn-ghost{min-width:96px;height:36px;padding:0 14px;border-radius:10px;border:1px solid #e5e7eb;background:#f8fafc;font-weight:700;font-size:var(--fs-16);color:#111827;cursor:pointer;white-space:nowrap}.tl-btn-ghost:hover{background:#e0f2fe;border-color:#7dd3fc}.tl-btn-ghost:disabled{opacity:.5;cursor:not-allowed}.tl-pagebox{display:flex;align-items:center;gap:8px;font-size:var(--fs-16);font-weight:700;color:#111827}.tl-pagebox input{width:72px;height:36px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;text-align:center;font-weight:700;font-size:var(--fs-16);color:#111827}.tl-pagebox input:focus{outline:none;background:#fff}@media(max-width:640px){.tl-paging{flex-wrap:wrap;justify-content:center;gap:10px}}.dm-page{padding:16px 24px;height:100%;background:#f8fafc;font-size:var(--fs-16);font-weight:400;color:#111827}.dm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px}.dm-title{display:flex;align-items:center;gap:10px;color:#111827}.dm-title h2{margin:0;font-size:var(--fs-16);font-weight:700;color:#111827}.dm-btn{height:40px;padding:0 16px;border-radius:12px;font-size:var(--fs-16);font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background .15s ease,border-color .15s ease,transform .1s ease;white-space:nowrap}.dm-btn:active{transform:translateY(0)}.dm-btn:hover{transform:translateY(-1px)}.dm-btn:focus{outline:none;box-shadow:0 0 0 3px #0369a11f}.dm-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.dm-btn-primary,.dm-btn-secondary{height:42px;padding:0 18px;border-radius:12px;cursor:pointer;font-size:var(--fs-16);font-weight:700;text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap}.dm-btn-primary{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a}.dm-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.dm-btn-primary:disabled{opacity:.6;cursor:not-allowed}.dm-btn-secondary{border:1px solid #e5e7eb;background:#fee2e2;color:#991b1b}.dm-btn-secondary:hover{background:#fecaca;border-color:#fca5a5}.dm-header .dm-btn-primary{width:220px;flex:0 0 auto}.dm-header button.dm-btn-primary{width:220px!important}.dm-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:12px}.dm-search{position:relative;width:100%;max-width:560px}.dm-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65;font-size:var(--fs-16);font-weight:700}.dm-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-16);font-weight:400;color:#111827}.dm-search-input::placeholder{color:#94a3b8;font-weight:400}.dm-search-input:focus{outline:none;background:#fff}.dm-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 220px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.dm-card::-webkit-scrollbar{width:8px;height:8px}.dm-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.dm-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dm-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.dm-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-16);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.dm-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;font-size:var(--fs-16);font-weight:400;color:#111827}.dm-table tr:hover{background:#f8fafc}.dm-mono{font-family:var(--pps-font-mono)}.dm-actions{display:flex;gap:10px;justify-content:flex-end;padding-right:6px}.dm-icon-btn{height:36px;min-width:110px;padding:0 12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-16);font-weight:700;color:#111827;white-space:nowrap;box-shadow:0 1px #0f172a0a}.dm-icon-btn:hover{background:#f8fafc;border-color:#cbd5e1}.dm-icon-btn.dm-edit:hover{background:#e0f2fe;border-color:#7dd3fc}.dm-icon-btn.dm-del:hover{background:#fee2e2;border-color:#fecaca}.dm-icon-btn:disabled{opacity:.55;cursor:not-allowed}.dm-loading{padding:10px;text-align:center;color:#6b7280;font-size:var(--fs-16);font-weight:700}.dm-empty{padding:14px;text-align:center;color:#6b7280;font-size:var(--fs-16);font-weight:700}.dm-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.dm-modal{width:min(900px,100%);background:#fff;border-radius:18px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #0003;overflow:hidden}.dm-modal-header{display:flex;justify-content:flex-start;align-items:center;padding:12px 14px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.dm-modal-title{display:flex;align-items:center;gap:10px;font-size:var(--fs-16);font-weight:700;color:#111827}.dm-form{padding:14px}.dm-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.dm-form label{display:block;font-size:var(--fs-16);font-weight:700;margin-bottom:6px;color:#111827}.dm-form input,.dm-form select{width:100%;height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-16);font-weight:400;color:#111827}.dm-form input::placeholder{color:#94a3b8;font-weight:400}.dm-form input:focus,.dm-form select:focus{outline:none;background:#fff}.dm-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.dm-hint{margin-top:10px;font-size:var(--fs-16);font-weight:400;color:#6b7280;opacity:1}.dm-deny{padding:16px;border:1px solid #fecaca;background:#fff1f2;border-radius:12px;color:#991b1b;font-size:var(--fs-16);font-weight:700}@media(max-width:640px){.dm-header{flex-wrap:wrap;align-items:flex-start}.dm-header .dm-btn-primary{width:100%!important}.dm-actions{justify-content:center;padding-right:0}.dm-icon-btn{min-width:100px}.dm-grid{grid-template-columns:1fr}}:root{--pps-font-main: "Inter", "Noto Sans Thai", "Sarabun", system-ui, sans-serif;--pps-bg: #f8fafc;--pps-card: #ffffff;--pps-border: #e5e7eb;--pps-border-strong: #cbd5e1;--pps-text: #0f172a;--pps-text-soft: #334155;--pps-muted: #64748b;--pps-primary: #0369a1;--pps-danger: #b91c1c;--pps-radius-sm: 10px;--pps-radius-md: 14px;--pps-radius-lg: 18px;--pps-shadow: 0 4px 16px rgba(15, 23, 42, .05);--pps-text-xs: 12px;--pps-text-sm: 13px;--pps-text-md: 14px;--pps-text-lg: 16px}.mdm-page{min-height:100vh;width:100%;max-width:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);color-scheme:light;font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;overflow-x:hidden;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.mdm-page *{min-width:0}.mdm-page input,.mdm-page select,.mdm-page textarea,.mdm-page button{font:inherit;color:inherit;font-family:inherit}.mdm-topbar,.mdm-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);box-shadow:var(--pps-shadow)}.mdm-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:16px;margin-bottom:16px}.mdm-title{display:flex;gap:10px;align-items:center;font-size:var(--pps-text-lg);font-weight:800;line-height:1.3;color:var(--pps-text)}.mdm-sub{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45;display:flex;flex-wrap:wrap;gap:6px;align-items:center}.mdm-sub b{color:var(--pps-text)}.mdm-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.mdm-btn,.mdm-btn-primary,.mdm-btn-danger,.mdm-iconbtn{min-height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border-strong);background:#fff;color:var(--pps-text);-webkit-text-fill-color:currentColor!important;cursor:pointer;font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.mdm-btn:hover,.mdm-btn-primary:hover,.mdm-btn-danger:hover,.mdm-iconbtn:hover{transform:translateY(-1px)}.mdm-btn:hover,.mdm-iconbtn:hover{background:#f8fafc}.mdm-btn-primary{border:none;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff!important;-webkit-text-fill-color:#ffffff!important;box-shadow:0 6px 14px #0284c72e}.mdm-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985)}.mdm-btn-danger{border-color:#fecaca;background:#fef2f2;color:var(--pps-danger)}.mdm-btn-danger:hover{background:#fee2e2}.mdm-btn:disabled,.mdm-btn-primary:disabled,.mdm-btn-danger:disabled,.mdm-iconbtn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.mdm-grid{display:grid;gap:16px;align-items:start;grid-template-columns:minmax(360px,.9fr) minmax(0,1.6fr)}.mdm-grid>*{min-width:0}.mdm-grid-tight{grid-template-columns:minmax(420px,.9fr) minmax(520px,1.8fr)}.mdm-card{padding:16px;max-width:100%;overflow:hidden;min-height:0}.mdm-card-table{display:flex;flex-direction:column;min-height:0}.mdm-card-title{margin-bottom:12px;display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.35;color:var(--pps-text)}.mdm-row{display:grid;gap:6px;margin-bottom:12px}.mdm-row label{font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.mdm-help,.mdm-note,.mdm-muted{color:var(--pps-muted)!important;-webkit-text-fill-color:var(--pps-muted)!important;font-size:var(--pps-text-xs);font-weight:500;line-height:1.45}.mdm-input,.mdm-textarea,.mdm-in-cell{width:100%;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc!important;color:var(--pps-text)!important;-webkit-text-fill-color:var(--pps-text)!important;caret-color:var(--pps-text)!important;padding:0 12px;outline:none;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);text-shadow:none!important;background-clip:padding-box}.mdm-input,.mdm-in-cell{min-height:40px}.mdm-textarea{min-height:180px;padding-top:10px;padding-bottom:10px;resize:vertical;line-height:1.5}.mdm-input::placeholder,.mdm-textarea::placeholder,.mdm-in-cell::placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important;font-weight:500}.mdm-input:focus,.mdm-textarea:focus,.mdm-in-cell:focus{background:#fff!important;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.mdm-in-cell.bad{border-color:#fca5a5;box-shadow:0 0 0 3px #ef44441a}.mdm-2col{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mdm-applybar{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.mdm-tabs{display:flex;gap:8px;flex-wrap:wrap}.mdm-tab{min-height:38px;padding:0 12px;border-radius:999px;border:1px solid var(--pps-border);background:#fff;color:var(--pps-text);cursor:pointer;font-size:var(--pps-text-sm);font-weight:800;font-family:var(--pps-font-main);display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.mdm-tab.on{background:#e0f2fe;border-color:#7dd3fc;color:#075985}.mdm-tab:disabled{opacity:.6;cursor:not-allowed}.mdm-preview-wrap{border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);max-width:100%;overflow:auto;background:#fff;-webkit-overflow-scrolling:touch;flex:1 1 auto;min-height:0;max-height:68vh}.mdm-table{width:100%;min-width:980px;table-layout:fixed;border-collapse:separate;border-spacing:0}.mdm-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft)!important;font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.mdm-table td{color:var(--pps-text)!important;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:middle;overflow:hidden;text-overflow:ellipsis}.mdm-table tbody tr:nth-child(2n){background:#fafafa}.mdm-table tbody tr:hover{background:#f1f5f9}.mdm-table tr.is-bad{background:#fff1f2}.mdm-table-tight th,.mdm-table-tight td{white-space:nowrap}.mdm-empty{padding:24px!important;text-align:center;color:var(--pps-muted)!important;-webkit-text-fill-color:var(--pps-muted)!important;font-size:var(--pps-text-md);font-weight:600}.mdm-td-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mdm-th-check,.mdm-td-check{width:46px;text-align:center}.mdm-td-err{font-weight:700;color:var(--pps-muted)!important;-webkit-text-fill-color:var(--pps-muted)!important}.mdm-td-err.on{color:var(--pps-danger)!important;-webkit-text-fill-color:var(--pps-danger)!important}.mdm-td-act{text-align:center}.mdm-iconbtn{width:34px;height:34px;min-height:34px;padding:0}.mdm-note{margin-top:10px}.mdm-page input,.mdm-page select,.mdm-page textarea{-webkit-appearance:none;appearance:none}.mdm-page select option{color:var(--pps-text)!important;background:#fff!important}.mdm-page input:-webkit-autofill,.mdm-page textarea:-webkit-autofill,.mdm-page select:-webkit-autofill{-webkit-text-fill-color:var(--pps-text)!important;caret-color:var(--pps-text)!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}@media(max-width:980px){.mdm-grid,.mdm-grid-tight{grid-template-columns:1fr}.mdm-actions{width:100%;justify-content:flex-start}.mdm-btn,.mdm-btn-primary,.mdm-btn-danger{flex:1 1 auto}}@media(max-width:640px){.mdm-page{padding:12px}.mdm-topbar,.mdm-card{padding:12px;border-radius:14px}.mdm-title{font-size:var(--fs-15)}.mdm-actions{flex-direction:column;align-items:stretch}.mdm-btn,.mdm-btn-primary,.mdm-btn-danger{width:100%}.mdm-2col{grid-template-columns:1fr}.mdm-preview-wrap{max-height:60vh}.mdm-table{min-width:920px}.mdm-table th{font-size:var(--fs-12);padding:10px 8px}.mdm-table td{font-size:var(--fs-13);padding:10px 8px}}@media(forced-colors:active){.mdm-page{forced-color-adjust:auto}.mdm-page .mdm-topbar,.mdm-page .mdm-card,.mdm-page .mdm-preview-wrap{border:1px solid ButtonText!important;background:Canvas!important;color:CanvasText!important}.mdm-page input,.mdm-page select,.mdm-page textarea,.mdm-page .mdm-input,.mdm-page .mdm-textarea,.mdm-page .mdm-in-cell{border:1px solid ButtonText!important;background:Field!important;color:FieldText!important;-webkit-text-fill-color:FieldText!important}.mdm-page .mdm-btn,.mdm-page .mdm-btn-primary,.mdm-page .mdm-btn-danger,.mdm-page .mdm-iconbtn{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}}.mds-page{--bg: #f8fafc;--card: #ffffff;--border: #dbe2ea;--text: #0f172a;--muted: #64748b;--muted-strong: #475569;--primary: #0369a1;--primary-soft: #e0f2fe;--warn: #a16207;--warn-soft: #fef3c7;--danger: #b91c1c;--danger-soft: #fee2e2;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--radius: 16px;--radius-sm: 12px;min-height:100%;height:100%;padding:16px;display:grid;grid-template-columns:280px 1fr;gap:16px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.mds-page2{--bg: #f8fafc;--card: #ffffff;--border: #dbe2ea;--text: #0f172a;--muted: #64748b;--muted-strong: #475569;--primary: #0369a1;--primary-soft: #e0f2fe;--warn: #a16207;--warn-soft: #fef3c7;--danger: #b91c1c;--danger-soft: #fee2e2;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--radius: 16px;--radius-sm: 12px;min-height:100%;height:100%;padding:16px;display:grid;grid-template-columns:1fr;gap:16px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.mds-sidebar,.mds-main{min-width:0;display:flex;flex-direction:column;gap:16px}.mds-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.mds-title{font-size:var(--fs-16);font-weight:700}.mds-sub{margin-top:4px;color:var(--muted);font-size:var(--fs-15);line-height:1.5}.mds-sidebar .mds-card:first-child,.mds-toolbar,.mds-table-card{padding:16px}.mds-menu{padding:10px;display:grid;gap:8px}.mds-menu-btn,.mds-btn,.mds-icon-btn{border:1px solid var(--border);background:#fff;color:var(--text);cursor:pointer;transition:.2s ease}.mds-menu-btn{height:42px;border-radius:12px;text-align:left;padding:0 14px;font-size:var(--fs-15);font-weight:600}.mds-menu-btn.active{background:var(--primary-soft);color:var(--primary);border-color:#7dd3fc}.mds-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.mds-toolbar-right{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.mds-search{position:relative;min-width:280px}.mds-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted-strong)}.mds-search input,.mds-input,.mds-select,.mds-textarea{width:100%;border-radius:12px;border:1px solid #b8c4d1;background:#eef3f8;color:var(--text);font-size:var(--fs-15);outline:none}.mds-select2{width:100px;height:42px;padding:0 12px;border-radius:12px;border:1px solid #b8c4d1;background:#eef3f8;color:var(--text);font-size:var(--fs-15);outline:none}.mds-search input,.mds-input,.mds-select{height:42px;padding:0 12px}.mds-search input{padding-left:38px}.mds-textarea{min-height:120px;padding:10px 12px;resize:vertical}.mds-search input:focus,.mds-input:focus,.mds-select:focus,.mds-textarea:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #0369a11a}.mds-select2:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #0369a11a}.mds-btn{height:42px;padding:0 14px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700}.mds-btn-primary{background:var(--primary-soft);color:var(--primary);border-color:#7dd3fc}.mds-btn-warn{background:var(--warn-soft);color:var(--warn);border-color:#fcd34d}.mds-btn-soft:hover,.mds-btn-primary:hover,.mds-btn-warn:hover,.mds-menu-btn:hover,.mds-icon-btn:hover{background:#f8fbff}.mds-table-wrap{overflow:auto;max-height:calc(100vh - 220px)}.mds-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.mds-table th,.mds-table td{padding:12px;border-bottom:1px solid #edf2f7;text-align:left;vertical-align:top;font-size:var(--fs-15)}.mds-table th{position:sticky;top:0;z-index:1;background:#f8fafc;font-weight:700}.mds-cell-text{max-width:320px;white-space:pre-wrap;word-break:break-word}.mds-actions{display:flex;gap:8px}.mds-icon-btn{width:38px;height:38px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center}.mds-icon-btn.danger{color:var(--danger);background:var(--danger-soft);border-color:#fecaca}.mds-empty{min-height:180px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.mds-modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.mds-modal{width:min(980px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:18px;border:1px solid var(--border);box-shadow:0 25px 60px #0003;padding:16px}.mds-modal-head,.mds-modal-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.mds-form-grid{margin-top:16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.mds-field{display:grid;gap:6px}.mds-field label{font-size:var(--fs-14);font-weight:700;color:var(--muted)}.mds-field.span-2{grid-column:span 2}.mds-color-wrap{display:grid;grid-template-columns:70px 1fr;gap:10px}.mds-color-input{padding:4px}.mds-modal-actions{margin-top:16px;justify-content:flex-end}.mds-menu-btn svg,.mds-btn svg,.mds-icon-btn svg,.mds-search svg{width:18px;height:18px;flex-shrink:0;display:inline-block;vertical-align:middle;color:currentColor!important;opacity:1!important;visibility:visible!important}.mds-btn svg,.mds-menu-btn svg{color:currentColor!important}.mds-btn-primary svg{color:var(--primary)!important}.mds-btn-warn svg{color:var(--warn)!important}.mds-icon-btn svg{color:var(--text)!important}.mds-icon-btn.danger svg{color:var(--danger)!important}.mds-search svg{color:var(--muted-strong)!important}.mds-menu-btn svg path,.mds-btn svg path,.mds-icon-btn svg path,.mds-search svg path,.mds-menu-btn svg line,.mds-btn svg line,.mds-icon-btn svg line,.mds-search svg line,.mds-menu-btn svg polyline,.mds-btn svg polyline,.mds-icon-btn svg polyline,.mds-search svg polyline,.mds-menu-btn svg circle,.mds-btn svg circle,.mds-icon-btn svg circle,.mds-search svg circle,.mds-menu-btn svg rect,.mds-btn svg rect,.mds-icon-btn svg rect,.mds-search svg rect{stroke:currentColor}.mds-menu-btn svg polygon,.mds-btn svg polygon,.mds-icon-btn svg polygon,.mds-search svg polygon,.mds-menu-btn svg path:not([stroke]),.mds-btn svg path:not([stroke]),.mds-icon-btn svg path:not([stroke]),.mds-search svg path:not([stroke]){fill:currentColor}@media(max-width:1024px){.mds-page,.mds-page2{grid-template-columns:1fr}.mds-search{min-width:220px}}@media(max-width:640px){.mds-page,.mds-page2{padding:12px}.mds-toolbar,.mds-toolbar-right,.mds-modal-head,.mds-modal-actions{flex-direction:column;align-items:stretch}.mds-search{min-width:0}.mds-form-grid{grid-template-columns:1fr}.mds-field.span-2{grid-column:span 1}}:root{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-light: #e0f2fe;--primary-lighter: #bae6fd;--primary-dark: #075985;--green: #166534;--green-bg: #ecfdf5;--green-border: #86efac;--green-soft: #d1fae5;--red: #991b1b;--red-light: #fee2e2;--red-medium: #ef4444;--gray-50: #f9fafb;--gray-100: #f1f5f9;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--shadow: 0 8px 24px rgba(0,0,0,.06);--shadow-sm: 0 4px 12px rgba(0,0,0,.04);--shadow-lg: 0 10px 20px rgba(0,0,0,.08);--radius: 16px;--radius-sm: 8px}*{box-sizing:border-box;font-family:var(--pps-font-main)}html,body,#root{height:100%;margin:0;background:var(--bg);color:var(--text);font-size:var(--fs-16)}.afc-page{height:100%;width:100%;padding:24px;display:flex;flex-direction:column;gap:16px;overflow:hidden}.afc-left{display:none!important}.afc-right{flex:1;width:100%;display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow)}.afc-right-header{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--card);display:flex;justify-content:space-between;align-items:center;gap:16px}.afc-right-body{flex:1;padding:16px;overflow-y:auto;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--border) transparent}.afc-right-body::-webkit-scrollbar{width:8px}.afc-right-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.afc-right-body::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.afc-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.afc-title{font-size:var(--fs-18);font-weight:400;margin-bottom:4px;color:var(--text)}.afc-sub{font-size:var(--fs-16);color:var(--muted);line-height:1.5}.afc-label{font-size:var(--fs-13);color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px}.afc-input,.afc-select{width:100%;height:40px;border-radius:var(--radius-sm);border:1px solid var(--gray-400);background:#e8edf5;padding:0 12px;font-size:var(--fs-16);font-weight:500;color:var(--text);outline:none;transition:all .2s}.afc-input:focus,.afc-select:focus{background:var(--card);border-color:var(--primary);box-shadow:0 0 0 3px #0369a11a}.afc-input::placeholder{color:var(--gray-400);font-weight:400}.afc-input:disabled,.afc-select:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.afc-form-card{margin-bottom:16px}.afc-grid{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.afc-wide{grid-column:1 / -1}.afc-field{display:grid;gap:6px}.afc-seg{display:grid;grid-template-columns:1fr 1fr;gap:12px}.afc-seg-btn{height:40px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--card);font-weight:600;font-size:var(--fs-16);color:var(--gray-700);cursor:pointer;transition:all .2s}.afc-seg-btn:hover{background:var(--gray-50)}.afc-seg-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.afc-seg-btn:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.afc-btn-save{height:40px;padding:0 24px;border-radius:var(--radius-sm);border:none;background:var(--primary);color:#fff;font-weight:600;font-size:var(--fs-18);cursor:pointer;transition:all .2s}.afc-btn-save:hover{background:var(--primary-hover)}.afc-btn-save:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.afc-error{margin-top:12px;font-size:var(--fs-14);color:var(--red);font-weight:500;background:var(--red-light);border:1px solid #fecaca;padding:10px 14px;border-radius:var(--radius-sm)}.afc-empty{color:var(--muted);font-weight:500;padding:16px;background:var(--gray-50);border:1px dashed var(--border);border-radius:var(--radius-sm);text-align:center}.afc-table-title{font-weight:600;font-size:var(--fs-14);margin-bottom:12px;color:var(--text)}.afc-table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.afc-table{width:100%;border-collapse:separate;border-spacing:0;min-width:900px;table-layout:auto}.afc-table th{position:sticky;top:0;background:linear-gradient(180deg,#f8fafc,#f1f5f9);font-size:var(--fs-12);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-600);padding:12px 10px;border-bottom:2px solid var(--border);white-space:nowrap}.afc-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;font-size:var(--fs-18);color:var(--text);font-weight:400}.afc-table tr:hover{background:var(--bg)}.afc-mono{font-family:var(--pps-font-mono);font-weight:700;color:var(--primary);font-size:var(--fs-14);text-align:center}.afc-num{text-align:center;font-weight:700;font-family:var(--pps-font-mono)}.afc-actions-td{text-align:right;width:auto}.afc-btn-del{height:32px;padding:0 12px;border-radius:var(--radius-sm);border:1px solid #fecaca;background:#fff;color:var(--red);font-weight:700;font-size:var(--fs-13);cursor:pointer;transition:all .2s;width:auto}.afc-btn-del:hover{background:var(--red-light);transform:translateY(-1px)}@media(max-width:1100px){.afc-page{padding:16px}.afc-grid{grid-template-columns:1fr}}@media(max-width:768px){.afc-table{min-width:720px}.afc-seg{grid-template-columns:1fr}.afc-btn-save{width:auto;padding:0 16px}}.afc-split{height:100%;display:grid;grid-template-columns:420px 1fr;gap:16px;min-height:0}.afc-pane{min-height:0;overflow:hidden;display:flex;flex-direction:column}.afc-pane-left,.afc-pane-right{overflow:auto;padding-right:2px}.afc-table{min-width:760px}@media(max-width:1100px){.afc-split{grid-template-columns:1fr}.afc-table{min-width:720px}}.afc-summary-card{border:1px solid var(--border);box-shadow:var(--shadow-sm)}.afc-summary-title{font-size:var(--fs-14);font-weight:800;color:var(--gray-700);margin-bottom:10px;text-transform:uppercase;letter-spacing:.6px}.afc-summary-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.afc-summary-item{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:12px;text-align:center}.afc-summary-label{font-size:var(--fs-12);font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.afc-summary-value{margin-top:6px;font-size:var(--fs-20);font-weight:900;color:var(--text);font-family:var(--pps-font-mono)}@media(max-width:1100px){.afc-summary-grid{grid-template-columns:1fr}.afc-summary-value{font-size:var(--fs-18)}}.gr-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-light: #e0f2fe;--primary-lighter: #bae6fd;--green: #166534;--green-bg: #ecfdf5;--green-border: #86efac;--green-soft: #d1fae5;--red: #991b1b;--red-light: #fee2e2;--red-soft: #fecaca;--gray-50: #f9fafb;--gray-100: #f1f5f9;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .2);--radius: 16px;--radius-sm: 10px;height:100%;width:100%;padding:16px 24px;display:grid;grid-template-columns:420px 1fr;gap:12px;overflow:hidden;background:var(--bg);color:var(--text)}.gr-left{display:flex;flex-direction:column;gap:16px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--border) transparent;height:100%}.gr-left::-webkit-scrollbar{width:8px}.gr-left::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.gr-left::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.gr-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.gr-title{font-size:var(--fs-16);font-weight:700;color:var(--text);margin-bottom:4px}.gr-sub{margin-top:4px;font-size:var(--fs-16);font-weight:400;line-height:1.5;color:var(--muted)}.gr-search{position:relative;margin-top:12px}.gr-search input{width:100%;height:40px;border-radius:10px;border:1px solid var(--gray-400);background:#e8edf5;color:var(--text);padding:0 12px 0 38px;font-size:var(--fs-16);font-weight:400;outline:none;transition:all .2s}.gr-search input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0369a11a;background:var(--card)}.gr-search input::placeholder{color:var(--gray-400);font-weight:400}.gr-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--gray-500);opacity:.9}.gr-label{font-size:var(--fs-16);color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.gr-input,.gr-select{width:100%;height:40px;border-radius:10px;border:1px solid var(--gray-400);background:#e8edf5;color:var(--text);padding:0 12px;font-size:var(--fs-16);font-weight:400;outline:none;transition:all .2s}.gr-input:focus,.gr-select:focus{border-color:var(--primary);background:var(--card);box-shadow:0 0 0 3px #0369a11a}.gr-input:disabled,.gr-select:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.gr-field{display:grid;gap:6px}.gr-order-list{display:flex;flex-direction:column;gap:10px}.gr-order-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--gray-50);border:1px solid var(--gray-200);align-items:center}.gr-order-no{font-size:var(--fs-16);font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gr-order-mat{margin-top:2px;font-size:var(--fs-16);color:var(--muted);font-weight:400;font-family:var(--pps-font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gr-order-basic{font-size:var(--fs-16);font-weight:400;color:var(--muted);margin-top:2px}.gr-order-badges{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.gr-badge{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:999px;border:1px solid transparent;font-size:var(--fs-16);font-weight:700;letter-spacing:.2px}.gr-badge-red{border-color:#fecaca;background:#fee2e2;color:#991b1b}.gr-badge-amber{border-color:#fde68a;background:#fef3c7;color:#92400e}.gr-btn-add{width:40px;height:40px;border-radius:999px;border:1.5px solid var(--green-border);background:var(--green-bg);color:#16a34a;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;box-shadow:0 1px 3px #0000000d}.gr-btn-add:hover{background:var(--green-soft);border-color:#4ade80;box-shadow:0 2px 4px #22c55e26}.gr-btn-add:active{background:#bbf7d0;transform:scale(.98)}.gr-btn-add:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;filter:grayscale(.2)}.gr-btn-add:disabled:hover{background:var(--green-bg);border-color:var(--green-border);box-shadow:none}.gr-btn-remove{width:40px;height:40px;border-radius:999px;border:1.5px solid #fecaca;background:var(--red-light);color:var(--red);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;box-shadow:0 1px 3px #0000000d}.gr-btn-remove:hover{background:#fecaca;border-color:#fca5a5;box-shadow:0 2px 4px #ef44441f}.gr-btn-remove:active{background:#fca5a5;transform:scale(.98)}.gr-btn-remove:disabled{opacity:.5;cursor:not-allowed}.gr-btn-ghost{width:40px;height:40px;border-radius:12px;border:1px solid #e5e7eb;background:var(--card);color:var(--gray-500);cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000f;display:inline-flex;align-items:center;justify-content:center;padding:0}.gr-btn-ghost:hover{background:var(--gray-50);border-color:#7dd3fc;box-shadow:0 2px 4px #00000014}.gr-btn-ghost:active{background:var(--gray-100);box-shadow:0 1px 2px #0000000d;transform:scale(.98)}.gr-right{display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow);background:var(--card)}.gr-right-header{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--card)}.gr-right-body{flex:1;padding:16px;overflow-y:auto;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--border) transparent}.gr-right-body::-webkit-scrollbar{width:8px}.gr-right-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.gr-right-body::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.gr-plan-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--gray-200);padding:14px 16px;display:grid;grid-template-columns:1fr 1fr auto;gap:16px;margin-bottom:12px;align-items:flex-start;box-shadow:var(--shadow-sm);transition:box-shadow .2s}.gr-plan-card:hover{box-shadow:var(--shadow)}.gr-plan-title{font-size:var(--fs-16);font-weight:700;color:var(--text)}.gr-plan-mat{font-size:var(--fs-16);color:var(--muted);margin-top:2px;font-weight:400;font-family:var(--pps-font-mono)}.gr-plan-left{min-width:0}.gr-fields-mid{display:grid;grid-template-columns:1fr .4fr;gap:10px;padding-top:0}@media(max-width:640px){.gr-fields-mid{grid-template-columns:1fr}}.gr-fields-right{display:grid;gap:12px;align-content:start}.gr-fields-actions{display:flex;justify-content:flex-end;margin-top:4px}.gr-empty{color:var(--muted);font-weight:400;padding:16px;background:var(--gray-50);border:1px dashed var(--border);border-radius:var(--radius-sm);text-align:center}.gr-footer{padding:16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px;background:var(--card)}.gr-btn-clear{width:100%;max-width:200px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--gray-300);background:var(--red-light);color:var(--gray-700);font-weight:600;font-size:var(--fs-16);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.gr-btn-clear:hover{background:var(--red-soft);border-color:#fca5a5;color:var(--red)}.gr-btn-clear:disabled{background:var(--gray-100);color:var(--gray-400);border-color:var(--gray-200);cursor:not-allowed}.gr-btn-create{width:100%;max-width:200px;height:40px;border-radius:10px;border:none;background:#bbf7d0;color:var(--gray-700);font-weight:600;font-size:var(--fs-16);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.gr-btn-create:hover{background:#4ade80}.gr-btn-create:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.gr-card-scroll{flex:1;overflow-y:auto;padding-right:6px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.gr-card-scroll::-webkit-scrollbar{width:8px}.gr-card-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.gr-card-scroll::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.gr-order-row-norouting{border-color:#fecaca;background:#fff1f2}.gr-order-row-norouting .gr-order-no{color:#991b1b}.gr-order-row-nolinematerial{border-color:#fde68a;background:#fffbeb}.gr-order-row-nolinematerial .gr-order-no{color:#92400e}@media(max-width:1150px){.gr-page{grid-template-columns:1fr;padding:16px}.gr-plan-card{grid-template-columns:1fr;gap:14px;align-items:stretch}.gr-right-body{padding:14px}.gr-left{padding-right:0}.gr-input,.gr-select{width:100%;max-width:100%}}@media(max-width:640px){.gr-footer{flex-direction:column;align-items:stretch;gap:10px}.gr-btn-clear,.gr-btn-create{max-width:none;width:100%}.gr-right-header{padding:14px}.gr-right-body{padding:12px}.gr-card{padding:14px}}@media(max-width:480px){.gr-page{padding:12px}.gr-order-row{padding:10px 12px;gap:10px}.gr-btn-add,.gr-btn-remove{width:38px;height:38px}.gr-plan-card{padding:12px;gap:12px}.gr-input,.gr-select{height:38px;font-size:var(--fs-16);font-weight:400}}@media(max-height:720px){.gr-page{overflow:auto}}.gr-actions-col{display:flex;flex-direction:column;gap:10px;align-items:flex-end}.qp-icon-btn.qp-print.gr-btn-print{width:40px;height:40px;min-width:40px;padding:0;border-radius:999px;border:1.5px solid #bae6fd;background:#e0f2fe;color:#0369a1;display:inline-flex;align-items:center;justify-content:center;gap:0;box-shadow:0 1px 3px #0000000d}.qp-icon-btn.qp-print.gr-btn-print:hover{background:#bae6fd;border-color:#7dd3fc}.qp-icon-btn.qp-print.gr-btn-print:disabled{opacity:.5;cursor:not-allowed}.qpa-page{padding:16px 24px;height:100%;background:#f8fafc;color:#111827}.qpa-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.qpa-title-wrap{display:flex;flex-direction:column;gap:2px}.qpa-title{font-size:var(--fs-16);font-weight:700;color:#111827}.qpa-sub{font-size:var(--fs-13);font-weight:600;color:#6b7280}.qpa-mono{font-family:var(--pps-font-mono)}.qpa-btn{height:42px;width:120px;padding:0 16px;border-radius:12px;cursor:pointer;font-weight:700;font-size:var(--fs-14);display:inline-flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .1s ease;border:1px solid #e5e7eb;background:#fff;color:#111827}.qpa-btn:active{transform:translateY(0)}.qpa-btn:hover{transform:translateY(-1px)}.qpa-btn:focus{outline:none;box-shadow:0 0 0 3px #0369a11f}.qpa-btn-primary{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a}.qpa-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.qpa-toolbar{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;display:flex;gap:12px;align-items:center;margin-bottom:12px}.qpa-search{position:relative;width:100%;max-width:720px;flex:1 1 auto}.qpa-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65}.qpa-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-15);color:#111827}.qpa-search-input:focus{outline:none;background:#fff;border-color:#0284c7;box-shadow:0 0 0 2px #7dd3fc73}.qpa-stat{min-width:120px;display:grid;gap:2px;justify-items:end}.qpa-stat-label{font-size:var(--fs-12);color:#6b7280;font-weight:600}.qpa-stat{min-width:120px;display:grid;gap:2px;justify-items:end;margin-left:auto}.qpa-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 230px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.qpa-card::-webkit-scrollbar{width:8px;height:8px}.qpa-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.qpa-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.qpa-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.qpa-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-14);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.qpa-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;color:#111827}.qpa-table tr:hover{background:#f8fafc}.qpa-num{text-align:right;font-variant-numeric:tabular-nums}.qpa-row-bad{background:#fff1f2}.qpa-row-bad:hover{background:#ffe4e6}.qpa-badge{padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;letter-spacing:.2px}.qpa-badge-green{background:#dcfce7;color:#166534}.qpa-badge-red{background:#fee2e2;color:#991b1b}.qpa-actions{display:flex;gap:10px;justify-content:flex-end;padding-right:6px}.qpa-icon-btn{height:36px;min-width:108px;padding:0 12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:var(--fs-13);color:#111827;white-space:nowrap;box-shadow:0 1px #0f172a0a}.qpa-icon-btn span{font-weight:600;font-size:var(--fs-13)}.qpa-icon-btn:hover{background:#f8fafc;border-color:#cbd5e1}.qpa-icon-btn.qpa-recreate:hover{background:#e0f2fe;border-color:#7dd3fc}.qpa-icon-btn.qpa-delete:hover{background:#fee2e2;border-color:#fecaca}.qpa-loading,.qpa-empty{padding:12px;text-align:center;color:#6b7280;font-weight:700}@media(max-width:640px){.qpa-page{padding:12px 14px}.qpa-toolbar{flex-direction:column;align-items:stretch}.qpa-stat{justify-items:start}.qpa-actions{justify-content:center;padding-right:0}.qpa-icon-btn{min-width:100px}}.qp-page{padding:16px 24px;height:100%;background:#f8fafc;color:#111827}.qp-mono{font-family:var(--pps-font-mono)}.qp-toolbar{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin-bottom:12px}.qp-search{position:relative;width:100%;max-width:560px;flex:1 1 360px}.qp-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65}.qp-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-15);color:#111827}.qp-search-input:focus{outline:none;background:#fff;border-color:#0284c7;box-shadow:0 0 0 2px #7dd3fc73}.qp-field{display:grid;gap:6px;min-width:160px}.qp-field-small{min-width:110px}.qp-label{font-size:var(--fs-12);font-weight:700;color:#111827}.qp-input,.qp-select{width:100%;height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-15);color:#111827}.qp-input:focus,.qp-select:focus{outline:none;background:#fff;border-color:#0284c7}.qp-btn{height:42px;width:120px;padding:0 16px;border-radius:12px;cursor:pointer;font-weight:700;font-size:var(--fs-14);display:inline-flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .1s ease;border:1px solid #e5e7eb;background:#fff;color:#111827}.qp-btn:hover{transform:translateY(-1px)}.qp-btn:focus{outline:none;box-shadow:0 0 0 3px #0369a11f}.qp-btn-primary{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a}.qp-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.qp-toggle{display:inline-flex;gap:8px;align-items:center;height:42px;padding:0 10px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;font-weight:700;font-size:var(--fs-13);color:#111827;-webkit-user-select:none;user-select:none}.qp-toggle input{width:16px;height:16px}.qp-stat{min-width:120px;display:grid;gap:2px;justify-items:end}.qp-stat-label{font-size:var(--fs-12);color:#6b7280;font-weight:600}.qp-stat{min-width:120px;display:grid;gap:2px;justify-items:end;margin-left:auto}.qp-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 230px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.qp-card::-webkit-scrollbar{width:8px;height:8px}.qp-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.qp-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.qp-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.qp-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-14);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.qp-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;color:#111827}.qp-table tr:hover{background:#f8fafc}.qp-num{text-align:right;font-variant-numeric:tabular-nums}.qp-badge{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:800;letter-spacing:.2px;border:1px solid transparent}.qp-badge-green{border-color:#86efac;background:#ecfdf5;color:#166534}.qp-badge-gray{border-color:#e5e7eb;background:#f3f4f6;color:#374151}.qp-actions{display:flex;justify-content:flex-end;gap:10px;padding-right:6px}.qp-icon-btn{height:36px;min-width:110px;padding:0 12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:var(--fs-13);color:#111827;white-space:nowrap;box-shadow:0 1px #0f172a0a}.qp-icon-btn:hover{background:#f8fafc;border-color:#cbd5e1}.qp-icon-btn.qp-print:hover{background:#e0f2fe;border-color:#7dd3fc}.qp-icon-btn:disabled{opacity:.55;cursor:not-allowed}.qp-loading{padding:12px;text-align:center;color:#6b7280;font-weight:700}.qp-empty{padding:12px;text-align:center;color:#6b7280;font-weight:600}@media(max-width:640px){.qp-page{padding:12px 14px}.qp-btn{width:100%}.qp-stat{width:100%;justify-items:start}}.qp-badge-red{border-color:#fecaca;background:#fef2f2;color:#991b1b}.qp-icon-btn.qp-complete{border:1px solid #16a34a;background:#ecfdf5;color:#166534}.qp-icon-btn.qp-complete:disabled{opacity:.6;cursor:not-allowed}.qrp-page{padding:16px 24px;height:100%;background:#f8fafc;color:#111827}.qrp-mono{font-family:var(--pps-font-mono)}.qrp-toolbar{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin-bottom:12px}.qrp-search{position:relative;width:100%;max-width:420px;flex:1 1 320px}.qrp-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65}.qrp-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-15);color:#111827}.qrp-search-input:focus{outline:none;background:#fff;border-color:#0284c7;box-shadow:0 0 0 2px #7dd3fc73}.qrp-field{display:grid;gap:6px;min-width:160px}.qrp-field-small{min-width:120px;width:50px}.qrp-label{font-size:var(--fs-12);font-weight:700;color:#111827}.qrp-input{width:100%;height:40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-15);color:#111827}.qrp-input:focus{outline:none;background:#fff;border-color:#0284c7}.qrp-btn{height:42px;width:120px;padding:0 16px;border-radius:12px;cursor:pointer;font-weight:700;font-size:var(--fs-14);display:inline-flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .1s ease;border:1px solid #e5e7eb;background:#fff;color:#111827}.qrp-btn:hover{transform:translateY(-1px)}.qrp-btn:focus{outline:none;box-shadow:0 0 0 3px #0369a11f}.qrp-btn-primary{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a}.qrp-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.qrp-btn-warn{border:1px solid #fde68a;background:#fffbeb;color:#92400e}.qrp-btn-warn:hover{background:#fef3c7;border-color:#f59e0b}.qrp-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.qrp-stat{min-width:120px;display:grid;gap:2px;justify-items:end;margin-left:auto}.qrp-stat-label{font-size:var(--fs-12);color:#6b7280;font-weight:600}.qrp-stat{min-width:120px;display:grid;gap:2px;justify-items:end}.qrp-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 230px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.qrp-card::-webkit-scrollbar{width:8px;height:8px}.qrp-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.qrp-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.qrp-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.qrp-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-14);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.qrp-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;color:#111827}.qrp-table tr:hover{background:#f8fafc}.qrp-num{text-align:right;font-variant-numeric:tabular-nums}.qrp-actions{display:flex;justify-content:flex-end;gap:10px;padding-right:6px}.qrp-icon-btn{height:36px;min-width:120px;padding:0 12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:var(--fs-13);color:#111827;white-space:nowrap;box-shadow:0 1px #0f172a0a}.qrp-icon-btn:hover{background:#f8fafc;border-color:#cbd5e1}.qrp-icon-btn.qrp-print:hover{background:#e0f2fe;border-color:#7dd3fc}.qrp-icon-btn:disabled{opacity:.55;cursor:not-allowed}.qrp-loading{padding:12px;text-align:center;color:#6b7280;font-weight:700}.qrp-empty{padding:12px;text-align:center;color:#6b7280;font-weight:600}@media(max-width:640px){.qrp-page{padding:12px 14px}.qrp-btn{width:100%}.qrp-stat{width:100%;justify-items:start}}.qph-page{padding:16px 24px;height:100%;background:#f8fafc;color:#111827}.qph-mono{font-family:var(--pps-font-mono)}.qph-strong{font-weight:700}.qph-num{font-variant-numeric:tabular-nums}.qph-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.qph-title-wrap{display:flex;flex-direction:column;gap:2px}.qph-title{font-size:var(--fs-16);font-weight:700;color:#111827}.qph-sub{font-size:var(--fs-13);font-weight:600;color:#6b7280}.qph-btn{height:42px;width:120px;padding:0 16px;border-radius:12px;cursor:pointer;font-weight:700;font-size:var(--fs-14);display:inline-flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .1s ease;border:1px solid #e5e7eb;background:#fff;color:#111827}.qph-btn:hover{transform:translateY(-1px);background:#f8fafc;border-color:#cbd5e1}.qph-btn:active{transform:translateY(0)}.qph-btn:focus{outline:none;box-shadow:0 0 0 3px #0369a11f}.qph-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.qph-btn-primary{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a}.qph-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.qph-toolbar{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;display:flex;gap:12px;align-items:center;margin-bottom:12px}.qph-search{position:relative;width:100%;max-width:720px;flex:1 1 auto}.qph-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65}.qph-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-15);color:#111827}.qph-search-input:focus{outline:none;background:#fff;border-color:#0284c7;box-shadow:0 0 0 2px #7dd3fc73}.qph-month{display:grid;gap:4px;min-width:170px}.qph-month-label{font-size:var(--fs-12);font-weight:600;color:#6b7280}.qph-month-input{height:40px;border-radius:10px;border:1px solid #9ca3af;background:#fff;padding:0 10px;font-size:var(--fs-14);color:#111827}.qph-month-input:focus{outline:none;border-color:#0284c7;box-shadow:0 0 0 2px #7dd3fc73}.qph-stat{min-width:140px;display:grid;gap:2px;justify-items:end;margin-left:auto}.qph-stat-label{font-size:var(--fs-12);color:#6b7280;font-weight:600}.qph-stat-value{font-size:var(--fs-14);font-weight:700;color:#111827}.qph-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 230px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.qph-card::-webkit-scrollbar{width:8px;height:8px}.qph-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.qph-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.qph-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.qph-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-14);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.qph-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;color:#111827}.qph-table tr:hover{background:#f8fafc}.qph-cell-main{display:flex;gap:8px;align-items:baseline}.qph-cell-sub{margin-top:3px;font-size:var(--fs-12);color:#6b7280;font-weight:600}.qph-loading,.qph-empty{padding:12px;text-align:center;color:#6b7280;font-weight:700}@media(max-width:860px){.qph-page{padding:12px 14px}.qph-toolbar{flex-direction:column;align-items:stretch}.qph-month{width:100%;min-width:0}.qph-stat{justify-items:start;margin-left:0}.qph-btn{width:100%}}.qph-month{min-width:170px}.qph-month-select{height:40px;width:100%;border-radius:10px;border:1px solid #9ca3af;background:#fff;padding:0 10px;font-size:var(--fs-14);color:#111827}.qph-month-select:focus{outline:none;border-color:#0284c7;box-shadow:0 0 0 2px #7dd3fc73}.so-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--primary-light: #e0f2fe;--primary-lighter: #bae6fd;--green: #166534;--green-bg: #ecfdf5;--green-border: #86efac;--green-soft: #d1fae5;--red: #991b1b;--red-light: #fee2e2;--red-soft: #fecaca;--gray-50: #f9fafb;--gray-100: #f1f5f9;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-700: #374151;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--radius-sm: 10px;height:100%;width:100%;padding:16px 24px;display:grid;grid-template-columns:420px 1fr;gap:12px;overflow:hidden;background:var(--bg);color:var(--text)}.so-left{display:flex;flex-direction:column;gap:16px;overflow-y:auto;padding-right:4px;height:100%;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.so-left::-webkit-scrollbar{width:8px}.so-left::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}.so-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.so-title{font-size:var(--fs-16);font-weight:700;color:var(--text);margin-bottom:4px}.so-sub{margin-top:4px;font-size:var(--fs-16);font-weight:400;line-height:1.5;color:var(--muted)}.so-search{position:relative;margin-top:12px}.so-search input{width:100%;height:40px;border-radius:10px;border:1px solid var(--gray-400);background:#e8edf5;color:var(--text);padding:0 12px 0 38px;font-size:var(--fs-16);font-weight:400;outline:none;transition:all .2s}.so-search input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0369a11a;background:var(--card)}.so-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--gray-500);opacity:.9}.so-label{font-size:var(--fs-16);color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.so-input,.so-select{width:100%;height:40px;border-radius:10px;border:1px solid var(--gray-400);background:#e8edf5;color:var(--text);padding:0 12px;font-size:var(--fs-16);font-weight:400;outline:none;transition:all .2s}.so-input:focus,.so-select:focus{border-color:var(--primary);background:var(--card);box-shadow:0 0 0 3px #0369a11a}.so-input:disabled,.so-select:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.so-field{display:grid;gap:6px}.so-list{display:flex;flex-direction:column;gap:10px}.so-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--gray-50);border:1px solid var(--gray-200);align-items:center}.so-row.on{border-color:var(--primary-lighter);background:var(--primary-light)}.so-matno{font-size:var(--fs-16);font-weight:700;color:var(--text);font-family:var(--pps-font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.so-desc{margin-top:2px;font-size:var(--fs-16);color:var(--muted);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.so-badges{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.so-badge{display:inline-flex;align-items:center;height:24px;padding:0 10px;border-radius:999px;border:1px solid transparent;font-size:var(--fs-16);font-weight:700}.so-badge-blue{border-color:#dbeafe;background:#eff6ff;color:#1e40af}.so-btn-add{width:40px;height:40px;border-radius:999px;border:1.5px solid var(--green-border);background:var(--green-bg);color:#16a34a;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;box-shadow:0 1px 3px #0000000d}.so-btn-add:hover{background:var(--green-soft);border-color:#4ade80}.so-btn-add:disabled{opacity:.45;cursor:not-allowed}.so-btn-remove{width:40px;height:40px;border-radius:999px;border:1.5px solid #fecaca;background:var(--red-light);color:var(--red);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1;box-shadow:0 1px 3px #0000000d}.so-btn-remove:hover{background:var(--red-soft);border-color:#fca5a5}.so-btn-remove:disabled{opacity:.5;cursor:not-allowed}.so-btn-ghost{width:40px;height:40px;border-radius:12px;border:1px solid var(--gray-200);background:var(--card);color:var(--gray-500);cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000000f;display:inline-flex;align-items:center;justify-content:center;padding:0}.so-btn-ghost:hover{background:var(--gray-50);border-color:#7dd3fc}.so-right{display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow);background:var(--card)}.so-right-header{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--card)}.so-right-body{flex:1;padding:16px;overflow-y:auto;background:var(--bg)}.so-plan-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--gray-200);padding:14px 16px;display:grid;grid-template-columns:1fr .8fr auto;gap:16px;margin-bottom:12px;align-items:flex-start;box-shadow:var(--shadow-sm)}.so-plan-title{font-size:var(--fs-16);font-weight:700;color:var(--text)}.so-plan-mono{margin-top:2px;font-size:var(--fs-16);color:var(--muted);font-weight:400;font-family:var(--pps-font-mono)}.so-empty{color:var(--muted);font-weight:400;padding:16px;background:var(--gray-50);border:1px dashed var(--border);border-radius:var(--radius-sm);text-align:center}.so-footer{padding:16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px;background:var(--card)}.so-btn-clear,.so-btn-create{width:100%;max-width:200px;height:40px;border-radius:var(--radius-sm);font-weight:600;font-size:var(--fs-16);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.so-btn-clear{border:1px solid var(--gray-300);background:var(--red-light);color:var(--gray-700)}.so-btn-clear:hover{background:var(--red-soft);border-color:#fca5a5;color:var(--red)}.so-btn-clear:disabled{background:var(--gray-100);color:var(--gray-400);border-color:var(--gray-200);cursor:not-allowed}.so-btn-create{border:none;background:#bbf7d0;color:var(--gray-700)}.so-btn-create:hover{background:#4ade80}.so-btn-create:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}@media(max-width:1150px){.so-page{grid-template-columns:1fr;padding:16px;overflow:auto}.so-plan-card{grid-template-columns:1fr}}@media(max-width:640px){.so-footer{flex-direction:column;align-items:stretch;gap:10px}.so-btn-clear,.so-btn-create{max-width:none;width:100%}}.so-tabs{display:inline-flex;gap:6px;padding:4px;border:1px solid var(--border, #cbd5e1);background:#f8fafc;border-radius:999px}.so-tab{appearance:none;border:0;background:transparent;color:#334155;font-weight:700;font-size:var(--fs-13);padding:8px 14px;border-radius:999px;cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease}.so-tab:hover{background:#e2e8f0}.so-tab.is-active{background:#fff;color:#0369a1;box-shadow:0 1px 2px #0f172a1f}.so-tab:focus-visible{outline:3px solid rgba(2,132,199,.25);outline-offset:2px}.gq-page{padding:12px;height:100%;background:#f8fafc;color:#111827}.gq-header{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.gq-title{font-size:var(--fs-16);font-weight:800}.gq-sub{font-size:var(--fs-12);color:#6b7280;margin-top:2px}.gq-actions{display:flex;gap:8px;flex-wrap:wrap}.gq-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px;margin-bottom:12px;box-shadow:0 6px 16px #0000000d}.gq-row label{display:block;font-size:var(--fs-13);font-weight:800;margin-bottom:6px}.gq-row input{width:100%;height:44px;border-radius:12px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px;font-size:var(--fs-15)}.gq-row input:focus{outline:none;background:#fff;border-color:#38bdf8}.gq-parsed{margin-top:10px;display:grid;grid-template-columns:1fr;gap:6px;font-size:var(--fs-13)}.gq-btn{height:42px;padding:0 14px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-14)}.gq-btn:hover{background:#f8fafc}.gq-btn:disabled{opacity:.6;cursor:not-allowed}.gq-btn-primary{width:100%;margin-top:10px;border:1px solid #bae6fd;background:#e0f2fe}.gq-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.gq-btn-soft{border:1px solid #bae6fd;background:#e0f2fe}.gq-history-header{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.gq-history-title{font-size:var(--fs-14);font-weight:900}.gq-table-wrap{overflow-x:auto;overflow-y:auto;max-height:55vh}.gq-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.gq-table th{position:sticky;top:0;background:#f8fafc;border-bottom:1px solid #e5e7eb;padding:10px;font-size:var(--fs-16);text-align:left;white-space:nowrap;z-index:1}.gq-table td{border-bottom:1px solid #f1f5f9;padding:10px;white-space:nowrap;font-size:var(--fs-16)}.gq-empty{text-align:center;color:#6b7280;padding:18px}.gq-modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:8px;z-index:999}.gq-modal{width:100%;max-width:520px;background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #00000040;padding:12px}.gq-modal-title{font-weight:900;font-size:var(--fs-14);margin-bottom:8px}.gq-qr-region{width:100%;min-height:320px}@media(min-width:640px){.gq-page{padding:16px}.gq-header{flex-direction:row;align-items:flex-end;justify-content:space-between}.gq-parsed{grid-template-columns:repeat(2,1fr)}.gq-history-header{flex-direction:row;align-items:center;justify-content:space-between}}@media(min-width:1024px){.gq-page{padding:16px 24px}.gq-title{font-size:var(--fs-18)}.gq-table-wrap{max-height:calc(100vh - 360px)}.gq-modal{max-width:600px}}.gq-title{color:#0f172a}.gq-sub{color:#475569}.gq-row label,.gq-parsed,.gq-history-title{color:#0f172a}.gq-empty{color:#64748b}.gq-row input{background:#f1f5f9;border:1px solid #94a3b8;color:#0f172a}.gq-row input::placeholder{color:#64748b}.gq-row input:focus{border-color:#0284c7;background:#fff}.gq-btn{color:#0f172a;background:#fff;border:1px solid #cbd5e1}.gq-btn:hover{background:#f1f5f9}.gq-btn-primary{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;border:none;font-size:var(--fs-15);font-weight:900}.gq-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985)}.gq-btn-primary:disabled{background:#94a3b8;color:#f8fafc}.gq-btn-soft{background:#e0f2fe;border:1px solid #7dd3fc;color:#075985;font-weight:800}.gq-btn-soft:hover{background:#bae6fd}.gq-btn:not(.gq-btn-primary):not(.gq-btn-soft){background:#fff;color:#334155}.gq-btn:not(.gq-btn-primary):not(.gq-btn-soft):hover{background:#f8fafc}.gq-table th{color:#0f172a;font-weight:900}.gq-table td{color:#0f172a}.gq-table td.mono{color:#1e293b}.gq-modal-title{color:#0f172a}.gq-tr-latest td{background:#ecfdf5;border-bottom-color:#bbf7d0}.gq-tr-latest td:first-child{box-shadow:inset 4px 0 #22c55e}@keyframes gqPulse{0%{filter:brightness(1)}50%{filter:brightness(1.03)}to{filter:brightness(1)}}.gq-tr-latest{animation:gqPulse .9s ease-in-out 1}.stm-page{--bg: #f8fafc;--card: #ffffff;--border: #9ca3af;--text: #0f172a;--muted: #475569;--primary: #0369a1;--primary-soft: #e0f2fe;--primary-soft-hover: #bae6fd;--primary-border: #7dd3fc;--danger: #991b1b;--danger-soft: #fee2e2;--danger-soft-hover: #fecaca;--danger-border: #fca5a5;padding:16px 24px;height:100%;background:var(--bg);color:var(--text)}.stm-page,.stm-page *{color:inherit}.stm-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.stm-title{font-size:var(--fs-16);font-weight:800;color:var(--text)}.stm-subtitle{margin-top:4px;font-size:var(--fs-12);font-weight:700;color:var(--muted)}.stm-toolbar{display:flex;gap:12px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.stm-search{position:relative;width:100%;max-width:560px;flex:1 1 360px}.stm-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.85;color:var(--muted)}.stm-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid var(--border);background:#e8edf5;font-size:var(--fs-15);color:var(--text)}.stm-search-input::placeholder{color:var(--muted);opacity:.9}.stm-search-input:focus{outline:none;background:#fff;border-color:var(--primary-border)}.stm-filters{display:flex;gap:10px;flex:0 0 auto}.stm-filters select{height:40px;border-radius:10px;border:1px solid var(--border);background:#e8edf5;padding:0 10px;font-size:var(--fs-15);color:var(--text);appearance:auto}.stm-filters select:focus{outline:none;background:#fff;border-color:var(--primary-border)}.stm-filters select option{color:var(--text);background:#fff}.stm-btn,.stm-icon-btn,.stm-btn-primary,.stm-btn-secondary{color:var(--text)!important;font-weight:900;cursor:pointer;border:1px solid transparent}.stm-btn{height:40px;padding:0 16px;border-radius:12px;border-color:var(--primary-border);background:var(--primary-soft)}.stm-btn:hover{background:var(--primary-soft-hover);border-color:var(--primary-border)}.stm-btn:disabled{opacity:.6;cursor:not-allowed}.stm-icon-btn{height:36px;padding:0 12px;border-radius:10px;border-color:var(--primary-border);background:var(--primary-soft);display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-13)}.stm-icon-btn:hover{background:var(--primary-soft-hover);border-color:var(--primary-border)}.stm-icon-btn:disabled{opacity:.5;cursor:not-allowed}.stm-btn-primary{height:40px;padding:0 16px;border-radius:12px;border-color:var(--primary-border);background:var(--primary-soft)}.stm-btn-primary:hover{background:var(--primary-soft-hover)}.stm-btn-primary:disabled{opacity:.6;cursor:not-allowed}.stm-btn-secondary{height:40px;padding:0 16px;border-radius:12px;border-color:var(--danger-border);background:var(--danger-soft);color:var(--danger)!important}.stm-btn-secondary:hover{background:var(--danger-soft-hover)}.stm-btn-secondary:disabled{opacity:.6;cursor:not-allowed}.stm-card{background:var(--card);border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 180px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.stm-card::-webkit-scrollbar{width:8px;height:8px}.stm-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.stm-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.stm-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.stm-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-14);font-weight:800;padding:10px;border-bottom:1px solid #e5e7eb;text-align:left;white-space:nowrap;color:var(--text)}.stm-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;color:var(--text)}.stm-table tr:hover{background:#f8fafc}.stm-actions{text-align:right}.stm-empty,.stm-loading,.hint{color:var(--muted)}.stm-empty{text-align:center;padding:16px;font-weight:700}.stm-loading{padding:10px;text-align:center;font-weight:800}.stm-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.stm-modal{width:min(760px,100%);background:#fff;border-radius:18px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #0003;overflow:hidden}.stm-modal-header{padding:12px 14px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.stm-modal-title{font-size:var(--fs-14);font-weight:900;color:var(--text)}.stm-form{padding:14px}.stm-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stm-grid .full{grid-column:1 / -1}.stm-form label{display:block;font-size:var(--fs-13);font-weight:800;margin-bottom:6px;color:var(--text)}.stm-form input{width:100%;height:40px;border-radius:10px;border:1px solid var(--border);background:#e8edf5;padding:0 12px;font-size:var(--fs-15);color:var(--text)}.stm-form input::placeholder{color:var(--muted);opacity:.9}.stm-form input:focus{outline:none;background:#fff;border-color:var(--primary-border)}.stm-form input:disabled{opacity:.85;color:var(--text);-webkit-text-fill-color:var(--text)}@media(max-width:640px){.stm-page{padding:12px 14px}.stm-grid{grid-template-columns:1fr}.stm-filters,.stm-filters select{width:100%}}.stm-form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}.oil-page{height:100%;padding:16px 18px;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px}.oil-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.oil-title{display:flex;flex-direction:column;gap:6px}.oil-h1{font-size:var(--fs-18);font-weight:800}.oil-sub{font-size:var(--fs-13);color:#475569;line-height:1.4}.oil-sub code{font-family:var(--pps-font-mono)}.oil-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.oil-file{max-width:320px;border:1px solid #e2e8f0;border-radius:12px;padding:8px 10px;background:#fff}.oil-btn{height:38px;padding:0 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;cursor:pointer;font-weight:700}.oil-btn:hover{background:#f1f5f9}.oil-btn:disabled{opacity:.55;cursor:not-allowed}.oil-primary{border-color:#0284c7;background:#0284c7;color:#fff}.oil-primary:hover{background:#0369a1}.oil-ghost{background:#fff}.oil-grid{display:grid;grid-template-columns:360px 1fr;gap:12px;align-items:start}.oil-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f}.oil-card-h{font-weight:900;margin-bottom:10px}.oil-kv{display:grid;grid-template-columns:140px 1fr;gap:8px 10px;font-size:var(--fs-13)}.oil-kv .k{color:#64748b}.oil-kv .v{color:#0f172a;font-weight:700}.oil-warn{margin-top:12px;padding:10px 12px;border-radius:12px;border:1px solid #fecaca;background:#fff1f2;color:#9f1239;font-weight:700;font-size:var(--fs-13)}.oil-preview{min-height:360px}.oil-table-wrap{max-height:420px;overflow:auto;border:1px solid #e2e8f0;border-radius:12px}.oil-table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-13)}.oil-table thead th{position:sticky;top:0;background:#f8fafc;border-bottom:1px solid #e2e8f0;text-align:left;padding:10px;font-weight:900;z-index:1}.oil-table tbody td{padding:9px 10px;border-bottom:1px solid #f1f5f9;vertical-align:top}.oil-table tbody tr:hover td{background:#f8fafc}.oil-empty{text-align:center;padding:26px 10px!important;color:#64748b}.oil-hint{margin-top:8px;font-size:var(--fs-12);color:#64748b}.oil-result{grid-column:1 / -1}.oil-notfound{margin-top:8px;max-height:220px;overflow:auto;padding:10px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc}@media(max-width:980px){.oil-grid{grid-template-columns:1fr}.oil-actions{justify-content:flex-start}.oil-file{max-width:100%}}.gqa-page{height:100%;padding:16px 18px;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px}.gqa-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.gqa-title{display:flex;flex-direction:column;gap:6px}.gqa-h1{font-size:var(--fs-18);font-weight:900}.gqa-sub{font-size:var(--fs-13);color:#475569;line-height:1.4;display:flex;gap:10px;flex-wrap:wrap;align-items:center}.gqa-sub code{font-family:var(--pps-font-mono)}.gqa-danger{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid #fecaca;background:#fff1f2;color:#9f1239;font-weight:800}.gqa-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.gqa-btn{height:38px;padding:0 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;cursor:pointer;font-weight:800;display:inline-flex;align-items:center;gap:8px}.gqa-btn:hover{background:#f1f5f9}.gqa-btn:disabled{opacity:.55;cursor:not-allowed}.gqa-dangerBtn{border-color:#ef4444;background:#ef4444;color:#fff}.gqa-dangerBtn:hover{background:#dc2626}.gqa-ghost{background:#fff}.gqa-grid{display:grid;grid-template-columns:380px 1fr;gap:12px;align-items:start}.gqa-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f}.gqa-card-h{font-weight:900;margin-bottom:10px}.gqa-form{display:flex;flex-direction:column;gap:10px}.gqa-form label{display:flex;flex-direction:column;gap:6px;font-size:var(--fs-13);color:#334155;font-weight:800}.gqa-form select{height:38px;border-radius:12px;border:1px solid #e2e8f0;padding:0 10px;outline:none;background:#fff}.gqa-form select:focus{border-color:#0284c7;box-shadow:0 0 0 3px #0284c726}.chk{flex-direction:row!important;align-items:center;font-weight:800;gap:10px!important}.chk input{height:auto}.gqa-hint{margin-top:12px;font-size:var(--fs-12);color:#64748b;line-height:1.45}.gqa-result{min-height:420px}.gqa-empty{padding:18px;border-radius:12px;border:1px dashed #cbd5e1;background:#f8fafc;color:#64748b}.gqa-kv{display:grid;grid-template-columns:140px 1fr;gap:8px 10px;font-size:var(--fs-13);margin-bottom:10px}.gqa-kv .k{color:#64748b}.gqa-kv .v{font-weight:900;color:#0f172a}.gqa-sql{margin:10px 0 12px;padding:10px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc}.gqa-sql-h{font-weight:900;margin-bottom:6px}.gqa-tableWrap{max-height:360px;overflow:auto;border:1px solid #e2e8f0;border-radius:12px}.gqa-table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-12)}.gqa-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;border-bottom:1px solid #e2e8f0;text-align:left;padding:10px;font-weight:900;white-space:nowrap}.gqa-table tbody td{padding:9px 10px;border-bottom:1px solid #f1f5f9;white-space:nowrap}.gqa-table tbody tr:hover td{background:#f8fafc}.gqa-emptyRow{text-align:center;padding:18px 10px!important;color:#64748b}.gqa-warn{margin-top:12px;padding:10px 12px;border-radius:12px;border:1px solid #fde68a;background:#fffbeb;color:#92400e;font-weight:900;font-size:var(--fs-13)}@media(max-width:980px){.gqa-grid{grid-template-columns:1fr}.gqa-actions{justify-content:flex-start}}.gqa-mini{margin-top:6px;font-size:var(--fs-12);color:#64748b;font-weight:700}.grr-page{height:100%;padding:16px 18px;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px}.grr-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.grr-title{display:flex;flex-direction:column;gap:6px}.grr-h1{font-size:var(--fs-18);font-weight:900}.grr-sub{font-size:var(--fs-13);color:#475569;line-height:1.4;display:flex;flex-direction:column;gap:4px}.grr-sub2{font-size:var(--fs-12);color:#64748b;font-weight:800}.grr-actions{display:flex;gap:8px;flex-wrap:wrap}.grr-btn{height:38px;padding:0 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.grr-btn:hover{background:#f1f5f9}.grr-btn:disabled{opacity:.55;cursor:not-allowed}.grr-ghost{background:#fff}.grr-grid{display:grid;grid-template-columns:380px 1fr;gap:12px;align-items:start}.grr-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f}.grr-card-h{font-weight:900;margin-bottom:10px}.grr-form{display:flex;flex-direction:column;gap:10px}.grr-form label{display:flex;flex-direction:column;gap:6px;font-size:var(--fs-13);font-weight:900;color:#334155}.grr-form select,.grr-form input{height:38px;border-radius:12px;border:1px solid #e2e8f0;padding:0 10px;outline:none;background:#fff}.grr-form select:focus,.grr-form input:focus{border-color:#0284c7;box-shadow:0 0 0 3px #0284c726}.grr-result{min-height:520px}.grr-empty{padding:18px;border-radius:12px;border:1px dashed #cbd5e1;background:#f8fafc;color:#64748b}.grr-kv{display:grid;grid-template-columns:180px 1fr;gap:8px 10px;font-size:var(--fs-13);margin-bottom:10px}.grr-kv .k{color:#64748b}.grr-kv .v{font-weight:900}.grr-search{margin:10px 0 12px}.grr-search input{width:100%;height:38px;border-radius:12px;border:1px solid #e2e8f0;padding:0 10px}.grr-tableWrap{max-height:520px;overflow:auto;border:1px solid #e2e8f0;border-radius:12px}.grr-table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-12)}.grr-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:10px;text-align:left;font-weight:900;white-space:nowrap}.grr-table tbody td{padding:9px 10px;border-bottom:1px solid #f1f5f9;white-space:nowrap}.grr-table tbody tr:hover td{background:#f8fafc}.grr-emptyRow{text-align:center;padding:18px 10px!important;color:#64748b}.grr-link{height:30px;padding:0 10px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.grr-link:hover{background:#f1f5f9}.grr-hint{margin-top:10px;font-size:var(--fs-12);color:#64748b;line-height:1.45}@media(max-width:980px){.grr-grid{grid-template-columns:1fr}}.prd-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);display:flex;flex-direction:column;gap:12px;overflow:auto}.ppshome-content,.ppshome-body{min-height:0}.prd-page input,.prd-page select,.prd-page textarea{color:var(--text);-webkit-text-fill-color:var(--text);caret-color:var(--text)}.prd-page button{color:var(--text);-webkit-text-fill-color:var(--text)}.prd-page input::placeholder,.prd-page textarea::placeholder{color:var(--muted);-webkit-text-fill-color:var(--muted)}.prd-page .recharts-text,.prd-page .recharts-cartesian-axis-tick-value,.prd-page .recharts-legend-item-text,.prd-page .recharts-label{fill:var(--text)}.prd-page .recharts-cartesian-grid line{stroke:#e5e7eb}.prd-topbar{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 14px;display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}.prd-topbar-left{min-width:260px}.prd-title{font-weight:600;display:flex;align-items:center;gap:8px;font-size:var(--fs-16)}.prd-sub{margin-top:2px;color:var(--muted);font-size:var(--fs-13)}.prd-topbar-right{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.prd-field-inline{display:grid;gap:6px}.prd-field-inline label{font-size:var(--fs-12);color:var(--muted);font-weight:800;letter-spacing:.3px;text-transform:uppercase}.prd-field-inline select{height:40px;border-radius:12px;border:1px solid #94a3b8;background:#e8edf5;padding:0 10px;font-size:var(--fs-14)}.prd-field-inline select:focus{outline:none;border-color:var(--primary2);background:var(--card)}.prd-btn{height:40px;padding:0 12px;border-radius:12px;border:1px solid #cbd5e1;background:var(--card);color:var(--text);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.prd-btn:hover{background:#f1f5f9}.prd-btn:disabled{opacity:.6;cursor:not-allowed}.prd-btn-soft{background:var(--soft);border-color:#7dd3fc;color:#075985;-webkit-text-fill-color:#075985}.prd-btn-soft:hover{background:#bae6fd}.prd-btn-ghost{background:transparent;color:var(--text);-webkit-text-fill-color:var(--text)}.prd-btn-mini{height:38px;padding:0 12px;border-radius:12px;font-weight:600}.prd-btn svg,.prd-btn-mini svg{color:currentColor}.prd-search{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.prd-search input{flex:1;min-width:260px;height:44px;border-radius:14px;border:1px solid #94a3b8;background:#e8edf5;padding:0 12px;font-size:var(--fs-15)}.prd-search input:focus{outline:none;background:var(--card);border-color:var(--primary2)}.prd-banner{border-radius:var(--radius);border:1px solid var(--border);background:var(--card);padding:10px 12px;display:flex;gap:10px;align-items:flex-start;box-shadow:var(--shadow-sm)}.prd-banner-warn{border-color:#fde68a;background:#fffbeb}.prd-banner-title{font-weight:600}.prd-banner-sub{color:var(--muted);font-size:var(--fs-13)}.prd-kpis{display:grid;grid-template-columns:repeat(4,minmax(220px,1fr));gap:12px}.prd-kpi{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 14px}.prd-kpi .k{color:var(--muted);text-transform:uppercase;letter-spacing:.3px;font-weight:600;font-size:var(--fs-12)}.prd-kpi .v{margin-top:6px;font-size:var(--fs-26);font-weight:600}.prd-kpi .s{margin-top:4px;font-size:var(--fs-12);color:var(--muted)}.prd-kpi-progress .v{font-size:var(--fs-24)}.prd-progress{margin-top:8px;height:10px;background:#eef2ff;border-radius:999px;overflow:hidden;border:1px solid #c7d2fe}.prd-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary2),var(--primary))}.prd-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:stretch}.prd-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 14px;overflow:hidden;min-height:0}.prd-card-wide{grid-column:1 / -1}.prd-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}.prd-card-title{font-weight:600;display:flex;gap:8px;align-items:center}.prd-card-sub{color:var(--muted);font-size:var(--fs-12)}.prd-chart{background:#f8fafc;border:1px dashed #dbeafe;border-radius:var(--radius-sm);padding:8px}.prd-mini-list{margin-top:10px;max-height:220px;overflow:auto}.prd-mini-row{display:flex;justify-content:space-between;gap:10px;padding:10px;border-bottom:1px solid #f1f5f9}.prd-mini-row .t{font-weight:600;font-size:var(--fs-13)}.prd-mini-row .m{color:var(--muted);margin-left:6px;font-weight:700}.prd-mini-row .sub{color:var(--muted);font-size:var(--fs-12);margin-top:2px}.prd-mini-row .b{text-align:right}.prd-mini-row .n{font-weight:600;font-size:var(--fs-14)}.prd-table{margin-top:10px;border:1px solid #e5e7eb;border-radius:var(--radius-sm);overflow:hidden}.prd-table .thead,.prd-table .tr{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;padding:10px}.prd-table .thead{background:#f8fafc;font-weight:600;font-size:var(--fs-12);color:#334155;border-bottom:1px solid #e5e7eb}.prd-table .tbody{max-height:220px;overflow:auto}.prd-table .tr{border-bottom:1px solid #f1f5f9;font-size:var(--fs-13)}.prd-table .r{text-align:right}.prd-table .empty{padding:14px;color:var(--muted)}.prd-live-card{padding:14px 16px 16px}.prd-live-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:12px}.prd-live-titlewrap{min-width:260px}.prd-live-title{font-weight:950;font-size:var(--fs-18);line-height:1.1}.prd-live-sub{margin-top:6px;color:var(--muted);font-size:var(--fs-13)}.prd-live-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.prd-live-chip{padding:8px 12px;border-radius:999px;border:1px solid #cbd5e1;background:#f8fafc;font-weight:600;color:var(--text)}.prd-live-rows{display:flex;align-items:center;gap:8px}.prd-live-rows .lbl{font-size:var(--fs-12);font-weight:600;color:var(--muted);letter-spacing:.3px;text-transform:uppercase}.prd-live-rows select{height:38px;border-radius:12px;border:1px solid #cbd5e1;background:#f8fafc;padding:0 12px;font-weight:600;color:var(--text);-webkit-text-fill-color:var(--text)}.prd-live-nav{display:flex;align-items:center;gap:8px}.prd-live-toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:10px}.prd-live-search{flex:1;min-width:260px;height:42px;border-radius:14px;border:1px solid #cbd5e1;background:#f1f5f9;padding:0 12px;font-size:var(--fs-14);color:var(--text);-webkit-text-fill-color:var(--text)}.prd-live-search:focus{outline:none;border-color:var(--primary2);background:#fff}.prd-live-meta{color:var(--muted);font-size:var(--fs-13);white-space:nowrap}.prd-live-table{border:1px solid #e5e7eb;border-radius:var(--radius-sm);overflow:auto;background:#fff;max-height:60vh;min-height:220px}.prd-live-table table{width:100%;border-collapse:separate;border-spacing:0}.prd-live-table thead th{position:sticky;top:0;background:#f8fafc;border-bottom:1px solid #e5e7eb;padding:10px 12px;font-size:var(--fs-12);font-weight:600;text-align:left;white-space:nowrap;z-index:2;color:var(--text)}.prd-live-table td{border-bottom:1px solid #f1f5f9;padding:12px;font-size:var(--fs-13);white-space:nowrap;vertical-align:top;color:var(--text)}.prd-live-table tbody tr:hover td{background:#f8fafc}.prd-live-table .r{text-align:right}.prd-live-table .mono{font-family:var(--pps-font-mono)}.prd-live-table .muted{color:var(--muted)}.prd-live-table .empty{text-align:center;color:var(--muted);padding:16px}.prd-mat{min-width:420px}.prd-mat-top{font-weight:600}.prd-mat-desc{margin-top:4px;color:var(--muted);font-size:var(--fs-13);white-space:normal;line-height:1.25;max-width:620px}.prd-num-green{color:#16a34a;font-weight:950}.prd-num-red{color:#ef4444;font-weight:950}.prd-footnote{color:var(--muted);font-size:var(--fs-12);padding:0 2px}.prd-row-confirmed{background:#ecfdf5}.prd-row-confirmed td{color:#065f46;font-weight:500}.prd-page .prd-field-inline select option,.prd-page .prd-live-rows select option{color:var(--text);background:#fff}.prd-page .prd-field-inline select:disabled,.prd-page .prd-live-rows select:disabled{color:var(--text);-webkit-text-fill-color:var(--text);opacity:.85}@media(forced-colors:active){.prd-page{forced-color-adjust:auto}.prd-page .prd-topbar,.prd-page .prd-card,.prd-page .prd-banner,.prd-page .prd-live-table{border:1px solid ButtonText;background:Canvas;color:CanvasText}.prd-page .prd-btn,.prd-page .prd-btn-mini,.prd-page .prd-live-chip{border:1px solid ButtonText;background:ButtonFace;color:ButtonText;-webkit-text-fill-color:ButtonText}.prd-page input,.prd-page select,.prd-page textarea,.prd-page .prd-live-search{border:1px solid ButtonText;background:Field;color:FieldText;-webkit-text-fill-color:FieldText}.prd-page .prd-table .thead,.prd-page .prd-live-table thead th,.prd-page .prd-live-table td{background:Canvas;color:CanvasText}}@media(max-width:1100px){.prd-kpis{grid-template-columns:1fr 1fr}.prd-grid{grid-template-columns:1fr}.prd-card-wide{grid-column:auto}.prd-mat{min-width:320px}}@media(max-width:640px){.prd-kpis{grid-template-columns:1fr}.prd-search input,.prd-live-search{min-width:0}.prd-mat{min-width:260px}}.mb51-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--border-soft: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary-soft: #e0f2fe;--green: #16a34a;--green-soft: #ecfdf5;--amber: #f59e0b;--amber-soft: #fffbeb;--danger: #dc2626;--danger-soft: #fef2f2;--slate: #475569;--slate-soft: #f1f5f9;--violet: #7c3aed;--violet-soft: #f5f3ff;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--radius-sm: 10px;min-height:100%;height:100%;padding:16px;background:var(--bg);color:var(--text);overflow:auto;font-family:var(--pps-font-main);color-scheme:light;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.mb51-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.mb51-topbar-left{min-width:0}.mb51-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-20);font-weight:800}.mb51-sub{margin-top:4px;color:var(--muted);font-size:var(--fs-14)}.mb51-topbar-right{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.mb51-field-inline{display:grid;gap:4px;min-width:88px}.mb51-field-inline label{font-size:var(--fs-12);font-weight:700;color:var(--muted)}.mb51-field-inline select,.mb51-search input,.mb51-live-search{height:40px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);padding:0 12px;outline:none}.mb51-field-inline select:focus,.mb51-search input:focus,.mb51-live-search:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0369a11f}.mb51-btn{height:40px;border:1px solid var(--border);background:#fff;color:var(--text);border-radius:10px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;cursor:pointer;transition:.18s ease;-webkit-text-fill-color:currentColor}.mb51-btn:hover{background:#f8fafc;border-color:#b6c3d1}.mb51-btn:disabled{opacity:.6;cursor:not-allowed}.mb51-btn-soft{background:var(--primary-soft);border-color:#bae6fd;color:var(--primary)}.mb51-btn-soft:hover{background:#bae6fd}.mb51-btn-ghost{background:#fff}.mb51-btn-mini{height:34px;padding:0 12px}.mb51-search{display:flex;gap:10px;margin-bottom:12px}.mb51-search input{flex:1}.mb51-banner{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-radius:12px;margin-bottom:12px;background:#fff;border:1px solid var(--border-soft)}.mb51-banner-warn{background:var(--amber-soft);border:1px solid #fde68a;color:#92400e}.mb51-banner-title{font-weight:800}.mb51-banner-sub{font-size:var(--fs-13)}.mb51-kpis{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-bottom:12px}.mb51-kpi{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 16px;border:1px solid var(--border-soft)}.mb51-kpi .k{font-size:var(--fs-12);font-weight:700;color:var(--muted);text-transform:uppercase}.mb51-kpi .v{margin-top:8px;font-size:var(--fs-24);font-weight:800;line-height:1.1}.mb51-kpi .v.small{font-size:var(--fs-14);line-height:1.4;word-break:break-word}.mb51-kpi .s{margin-top:6px;font-size:var(--fs-12);color:var(--muted)}.mb51-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}.mb51-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;min-width:0;border:1px solid rgba(226,232,240,.8)}.mb51-card-wide{grid-column:1 / -1}.mb51-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}.mb51-card-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-16);font-weight:800}.mb51-card-sub{color:var(--muted);font-size:var(--fs-13)}.mb51-chart{width:100%;min-width:0}.mb51-live-card{padding:0;overflow:hidden}.mb51-live-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--border-soft)}.mb51-live-title{font-size:var(--fs-18);font-weight:800}.mb51-live-sub{font-size:var(--fs-13);color:var(--muted)}.mb51-live-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.mb51-live-chip{height:34px;display:inline-flex;align-items:center;padding:0 12px;border-radius:999px;background:#f1f5f9;color:#334155;font-weight:700}.mb51-live-rows{display:flex;align-items:center;gap:8px}.mb51-live-rows .lbl{font-size:var(--fs-12);color:var(--muted);font-weight:700}.mb51-live-rows select{height:34px;border-radius:10px;border:1px solid var(--border);padding:0 10px;background:#fff;color:var(--text)}.mb51-live-nav{display:flex;gap:8px}.mb51-live-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-soft);background:#fcfcfd}.mb51-live-search{width:320px;max-width:100%}.mb51-live-meta{font-size:var(--fs-13);color:var(--muted)}.mb51-live-table{overflow:auto;max-height:68vh}.mb51-live-table table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.mb51-live-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:#0f172a;text-align:left;font-size:var(--fs-13);font-weight:800;padding:10px 12px;border-bottom:1px solid var(--border-soft);white-space:nowrap}.mb51-live-table td{padding:10px 12px;border-bottom:1px solid #f1f5f9;font-size:var(--fs-14);white-space:nowrap;vertical-align:top}.mb51-live-table tbody tr:hover{background:#f8fafc}.mb51-live-table .r,.mb51-live-table th.r{text-align:right}.mb51-live-table .mono{font-family:var(--pps-font-mono)}.mb51-live-table .empty{text-align:center;color:var(--muted);padding:18px}.mb51-footnote{margin-top:10px;color:var(--muted);font-size:var(--fs-12)}.mb51-status-pill{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:800;letter-spacing:.02em;white-space:nowrap}.mb51-progress-wrap{min-width:110px}.mb51-progress{width:100%;height:8px;border-radius:999px;background:#e2e8f0;overflow:hidden}.mb51-progress-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,#0284c7,#22c55e)}.mb51-progress-text{margin-top:6px;font-size:var(--fs-12);font-weight:700;color:var(--muted)}.mb51-expand-btn{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s ease}.mb51-expand-btn:hover{background:#f8fafc;border-color:#b6c3d1}.mb51-detail-cell{padding:0!important;background:#fcfdff}.mb51-detail-box{padding:14px 16px 16px;background:linear-gradient(180deg,#fcfdff,#f8fbff)}.mb51-detail-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.mb51-detail-title{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-14);font-weight:800;color:var(--text)}.mb51-detail-meta{display:flex;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:var(--fs-13)}.mb51-detail-meta span{display:inline-flex;align-items:center;gap:6px}.mb51-detail-table{overflow:auto;border:1px solid var(--border-soft);border-radius:12px;background:#fff}.mb51-detail-table table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.mb51-detail-table th{position:sticky;top:0;z-index:1;background:#f8fafc;color:var(--text);text-align:left;font-size:var(--fs-12);font-weight:800;padding:10px 12px;border-bottom:1px solid var(--border-soft);white-space:nowrap}.mb51-detail-table td{padding:10px 12px;font-size:var(--fs-13);border-bottom:1px solid #f1f5f9;white-space:nowrap}.mb51-detail-table .r{text-align:right}.mb51-detail-table .empty{text-align:center;color:var(--muted);padding:16px}.mb51-row-status-in_progress>td{background:linear-gradient(90deg,#e0f2fe7a,#fff0)}.mb51-row-status-not_started>td{background:linear-gradient(90deg,#f1f5f9bf,#fff0)}.mb51-row-status-completed>td{background:linear-gradient(90deg,#ecfdf5a6,#fff0)}.mb51-row-status-confirmed>td{background:linear-gradient(90deg,#f5f3ffb3,#fff0)}.mb51-row-status-closed>td{background:linear-gradient(90deg,#f1f5f9f2,#fff0)}.mb51-row-status-in_progress:hover>td,.mb51-row-status-not_started:hover>td,.mb51-row-status-completed:hover>td,.mb51-row-status-confirmed:hover>td,.mb51-row-status-closed:hover>td{filter:brightness(.99)}.mb51-mat{min-width:0}.mb51-page input,.mb51-page select,.mb51-page textarea,.mb51-page .mb51-live-search,.mb51-page .mb51-field-inline select,.mb51-page .mb51-live-rows select{color:var(--text)!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;text-shadow:none!important;background-clip:padding-box;-webkit-appearance:none;appearance:none}.mb51-page input::placeholder,.mb51-page textarea::placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.mb51-page select option{color:#0f172a!important;background:#fff!important}.mb51-page input:-webkit-autofill,.mb51-page textarea:-webkit-autofill,.mb51-page select:-webkit-autofill{-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s}.mb51-btn svg,.mb51-title svg,.mb51-card-title svg,.mb51-detail-title svg,.mb51-expand-btn svg,.mb51-live-chip svg,.mb51-detail-meta svg{width:18px;height:18px;flex-shrink:0;display:inline-block;vertical-align:middle;color:currentColor!important;opacity:1!important;visibility:visible!important;transform:translateZ(0)}.mb51-btn svg path,.mb51-title svg path,.mb51-card-title svg path,.mb51-detail-title svg path,.mb51-expand-btn svg path,.mb51-live-chip svg path,.mb51-detail-meta svg path,.mb51-btn svg line,.mb51-title svg line,.mb51-card-title svg line,.mb51-detail-title svg line,.mb51-expand-btn svg line,.mb51-live-chip svg line,.mb51-detail-meta svg line,.mb51-btn svg polyline,.mb51-title svg polyline,.mb51-card-title svg polyline,.mb51-detail-title svg polyline,.mb51-expand-btn svg polyline,.mb51-live-chip svg polyline,.mb51-detail-meta svg polyline,.mb51-btn svg circle,.mb51-title svg circle,.mb51-card-title svg circle,.mb51-detail-title svg circle,.mb51-expand-btn svg circle,.mb51-live-chip svg circle,.mb51-detail-meta svg circle{stroke:currentColor}.mb51-banner-warn svg{color:#92400e!important}.mb51-btn-soft svg{color:var(--primary)!important}.mb51-expand-btn svg{color:var(--text)!important}.mb51-live-chip svg{color:#334155!important}@media(max-width:1400px){.mb51-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:1100px){.mb51-grid{grid-template-columns:1fr}.mb51-card-wide{grid-column:auto}.mb51-topbar{flex-direction:column}.mb51-topbar-right{justify-content:flex-start}.mb51-detail-head{flex-direction:column;align-items:stretch}}@media(max-width:768px){.mb51-page{padding:12px}.mb51-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.mb51-search,.mb51-live-toolbar,.mb51-live-head{flex-direction:column;align-items:stretch}.mb51-live-search,.mb51-topbar-right{width:100%}.mb51-field-inline{min-width:0}.mb51-progress-wrap{min-width:90px}}@media(max-width:520px){.mb51-kpis{grid-template-columns:1fr}.mb51-field-inline,.mb51-field-inline select,.mb51-btn{width:100%}.mb51-live-controls{flex-direction:column;align-items:stretch}.mb51-live-nav{width:100%}.mb51-live-nav .mb51-btn{flex:1}}.gqf-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--green: #16a34a;--red: #dc2626;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--radius: 16px;--radius-sm: 12px;height:100%;width:100%;padding:16px 24px;background:var(--bg);color:var(--text)}.gqf-toolbar{display:grid;grid-template-columns:1fr 1.2fr auto auto auto;gap:10px;align-items:center;margin-bottom:10px}.gqf-title-wrap{min-width:0}.gqf-title{font-size:var(--fs-16);font-weight:900}.gqf-sub{margin-top:2px;color:var(--muted);font-size:var(--fs-13)}.gqf-search{position:relative;min-width:0}.gqf-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#6b7280}.gqf-search-input{width:100%;height:40px;border-radius:12px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px 0 38px;font-size:var(--fs-15);outline:none}.gqf-search-input:focus{background:#fff;border-color:var(--primary2)}.gqf-btn{height:40px;padding:0 14px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-weight:900;display:inline-flex;align-items:center;gap:8px}.gqf-btn:hover{background:#f1f5f9}.gqf-btn-primary{background:var(--soft);border-color:#7dd3fc;color:#075985}.gqf-btn-primary:hover{background:#bae6fd}.gqf-btn-soft{background:#fff}.gqf-btn-success{background:#ecfdf5;border-color:#86efac;color:#166534}.gqf-btn-success:hover{background:#d1fae5}.gqf-btn-danger{background:#fee2e2;border-color:#fecaca;color:#991b1b}.gqf-btn-danger:hover{background:#fecaca}.gqf-btn-mini{height:34px;padding:0 10px;border-radius:10px;font-size:var(--fs-13)}.gqf-stat{justify-self:end;text-align:right}.gqf-stat-label{font-size:var(--fs-12);color:var(--muted);font-weight:800}.gqf-stat-value{font-size:var(--fs-16);font-weight:900}.gqf-actions-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}.gqf-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.gqf-table-wrap{overflow:auto;max-height:calc(100vh - 210px)}.gqf-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.gqf-table th{position:sticky;top:0;z-index:1;background:#f8fafc;border-bottom:1px solid #e5e7eb;padding:10px;font-size:var(--fs-13);text-align:left;white-space:nowrap}.gqf-table td{border-bottom:1px solid #f1f5f9;padding:10px;font-size:var(--fs-14);white-space:nowrap}.gqf-td-actions{text-align:right}.num{text-align:right;font-variant-numeric:tabular-nums}.gqf-badge{display:inline-flex;align-items:center;justify-content:center;height:24px;min-width:36px;padding:0 10px;border-radius:999px;font-weight:900;font-size:var(--fs-13);border:1px solid transparent}.gqf-badge-red{background:#fee2e2;border-color:#fecaca;color:#991b1b}.gqf-loading,.gqf-empty{padding:16px;text-align:center;color:var(--muted)}@media(max-width:980px){.gqf-toolbar{grid-template-columns:1fr}.gqf-stat{justify-self:start;text-align:left}.gqf-table-wrap{max-height:calc(100vh - 280px)}}.sp-page{padding:16px 24px;height:100%;background:#f8fafc;color:#111827}.sp-mono{font-family:var(--pps-font-mono)}.sp-toolbar{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin-bottom:12px}.sp-search{position:relative;width:100%;max-width:560px;flex:1 1 360px}.sp-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65}.sp-search-input{width:100%;height:40px;padding:0 12px 0 40px;border-radius:10px;border:1px solid #9ca3af;background:#e8edf5;font-size:var(--fs-15);color:#111827}.sp-search-input:focus{outline:none;background:#fff;border-color:#0284c7;box-shadow:0 0 0 2px #7dd3fc73}.sp-btn{height:42px;width:120px;padding:0 16px;border-radius:12px;cursor:pointer;font-weight:700;font-size:var(--fs-14);display:inline-flex;align-items:center;justify-content:center;gap:10px;border:1px solid #e5e7eb;background:#fff;color:#111827;white-space:nowrap}.sp-btn:hover{transform:translateY(-1px)}.sp-btn-primary{border:1px solid #bae6fd;background:#e0f2fe;color:#0f172a}.sp-btn-primary:hover{background:#bae6fd;border-color:#7dd3fc}.sp-stat{min-width:120px;display:grid;gap:2px;justify-items:end;margin-left:auto}.sp-stat-label{font-size:var(--fs-12);color:#6b7280;font-weight:600}.sp-stat-value{font-size:var(--fs-18);font-weight:900}.sp-card{background:#fff;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f;max-height:calc(100vh - 230px);overflow:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.sp-card::-webkit-scrollbar{width:8px;height:8px}.sp-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}.sp-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sp-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.sp-table th{position:sticky;top:0;z-index:2;background:#f8fafc;font-size:var(--fs-14);font-weight:700;padding:10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;text-align:left;color:#111827}.sp-table td{padding:10px;border-bottom:1px solid #f1f5f9;white-space:nowrap;color:#111827}.sp-table tr:hover{background:#f8fafc}.sp-num{text-align:right;font-variant-numeric:tabular-nums}.sp-actions{display:flex;justify-content:flex-end;gap:10px;padding-right:6px}.sp-icon-btn{height:36px;min-width:110px;padding:0 12px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:var(--fs-13);color:#111827;white-space:nowrap}.sp-icon-btn:hover{background:#f8fafc;border-color:#cbd5e1}.sp-icon-btn.sp-print:hover{background:#e0f2fe;border-color:#7dd3fc}.sp-icon-btn:disabled{opacity:.55;cursor:not-allowed}.sp-loading{padding:12px;text-align:center;color:#6b7280;font-weight:700}.sp-empty{padding:12px;text-align:center;color:#6b7280;font-weight:600}@media(max-width:640px){.sp-page{padding:12px 14px}.sp-btn{width:100%}.sp-stat{width:100%;justify-items:start;margin-left:0}}.sv-page{padding:16px 24px;height:100%;background:#f8fafc;color:#111827;display:flex;flex-direction:column;gap:12px}.sv-card{background:#fff;border-radius:16px;padding:14px;box-shadow:0 10px 26px #0000000f;border:1px solid #eef2f7}.sv-toolbar{display:grid;gap:10px}.sv-title{display:flex;align-items:center;gap:10px;font-weight:900;font-size:var(--fs-16)}.sv-dot{width:10px;height:10px;border-radius:999px;background:#0284c7;box-shadow:0 0 0 4px #0284c726}.sv-sub{font-size:var(--fs-12);color:#64748b}.sv-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.sv-search{position:relative;flex:1 1 520px;min-width:280px}.sv-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65}.sv-input{width:100%;height:42px;border-radius:12px;border:1px solid #9ca3af;background:#e8edf5;padding:0 12px 0 40px;font-size:var(--fs-14);color:#111827}.sv-input:focus{outline:none;background:#fff;border-color:#0284c7;box-shadow:0 0 0 2px #7dd3fc73}.sv-btn{height:42px;padding:0 16px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:10px}.sv-btn-primary{border:1px solid #bae6fd;background:#e0f2fe}.sv-result{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.sv-badge{display:inline-flex;align-items:center;gap:8px;height:30px;padding:0 12px;border-radius:999px;font-weight:900;font-size:var(--fs-12);border:1px solid transparent}.sv-ok{background:#ecfdf5;border-color:#86efac;color:#166534}.sv-bad{background:#fef2f2;border-color:#fecaca;color:#991b1b}.sv-muted{font-size:var(--fs-12);color:#64748b}.sv-hd{font-weight:900;margin-bottom:10px}.sv-grid{display:grid;grid-template-columns:140px 1fr;gap:8px 12px;font-size:var(--fs-13)}.sv-k{color:#64748b;font-weight:800}.sv-v{color:#111827;font-weight:700}.sv-badtext{color:#991b1b}.sv-sep{height:1px;background:#eef2f7;margin:12px 0}.sv-table{display:grid;gap:10px}.sv-tr{display:grid;grid-template-columns:140px 1fr;gap:10px;align-items:center}.sv-td{font-size:var(--fs-13);font-weight:700}.sv-mono{font-family:var(--pps-font-mono);display:flex;gap:10px;align-items:center;flex-wrap:wrap}.sv-copy{border:1px solid #e5e7eb;background:#fff;border-radius:10px;height:30px;padding:0 10px;cursor:pointer;display:inline-flex;align-items:center}.sv-copy:hover{background:#f8fafc}@media(max-width:640px){.sv-page{padding:12px 14px}.sv-grid,.sv-tr{grid-template-columns:120px 1fr}}.srs-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--soft2: #bae6fd;--ok: #16a34a;--ok-soft: #ecfdf5;--warn: #b91c1c;--warn-soft: #fef2f2;--shadow: 0 10px 26px rgba(2, 6, 23, .06);--shadow-sm: 0 6px 16px rgba(2, 6, 23, .05);--radius: 18px;--radius-sm: 12px;padding:16px 24px;height:100%;background:var(--bg);color:var(--text);display:flex;flex-direction:column;gap:12px;overflow:hidden}.srs-toolbar,.srs-approve-card,.srs-card,.srs-modal{background:var(--card);border:1px solid rgba(226,232,240,.9);border-radius:var(--radius);box-shadow:var(--shadow)}.srs-card-head{padding:14px 16px 10px;border-bottom:1px solid var(--border2);display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}.srs-card-title{font-weight:900;font-size:var(--fs-14);letter-spacing:-.01em}.srs-card-sub{font-size:var(--fs-12);color:var(--muted);font-weight:700;margin-top:4px}.srs-card-head-right{display:flex;gap:10px;align-items:center;margin-left:auto}.srs-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;font-size:var(--fs-12);color:#334155;font-weight:800}.srs-toolbar{padding:12px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:flex-end}.srs-left{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;flex:1 1 auto}.srs-search{position:relative;min-width:260px;flex:1 1 420px}.srs-search-sm{flex:1 1 320px}.srs-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.65}.srs-input{width:100%;height:42px;border-radius:var(--radius-sm);border:1px solid #94a3b8;background:#e8edf5;padding:0 12px 0 40px;font-size:var(--fs-14);font-weight:800;color:var(--text);transition:all .15s ease}.srs-input:focus{outline:none;background:#fff;border-color:var(--primary2);box-shadow:0 0 0 2px #7dd3fc73}.srs-stat{min-width:120px;display:grid;gap:2px;justify-items:end;margin-left:auto}.srs-stat-label{font-size:var(--fs-12);color:var(--muted);font-weight:800}.srs-stat-value{font-size:var(--fs-18);font-weight:900}.srs-btn{height:42px;padding:0 14px;border-radius:var(--radius-sm);border:1px solid #e5e7eb;background:#fff;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;transition:all .15s ease}.srs-btn:hover{transform:translateY(-1px)}.srs-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.srs-btn-primary{border:1px solid var(--soft2);background:var(--soft);color:#075985}.srs-btn-ok{border:1px solid #86efac;background:var(--ok-soft);color:#166534}.srs-btn-warn{border:1px solid #fecaca;background:var(--warn-soft);color:#991b1b}.srs-btn-xs{height:36px;padding:0 12px;border-radius:12px;font-size:var(--fs-13)}.srs-pill{display:inline-flex;align-items:center;gap:8px;padding:4px 12px;border-radius:999px;font-size:var(--fs-11);font-weight:900;text-transform:uppercase;letter-spacing:-.01em;border:1px solid transparent}.srs-pill.ok{background:#dcfce7;color:#166534;border-color:#bbf7d0}.srs-pill.done{background:#e0f2fe;color:#075985;border-color:#bae6fd}.srs-pill.bad{background:#fee2e2;color:#991b1b;border-color:#fecaca}.srs-pill.warn{background:#fef9c3;color:#92400e;border-color:#fde68a}.srs-pill.muted{background:#e5e7eb;color:#374151;border-color:#cbd5e1}.srs-approve-card{padding:16px;display:grid;gap:12px;flex:0 0 auto;min-height:0;max-height:clamp(220px,44vh,560px);overflow:hidden}.srs-approve-title{display:flex;align-items:center;gap:10px;font-weight:900;font-size:var(--fs-15);color:#1e293b;padding:10px 12px;border-radius:14px;background:#f8fafc;border:1px solid var(--border2)}.srs-approve-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.srs-appr-input{height:42px;border-radius:var(--radius-sm);border:1px solid #94a3b8;background:#e8edf5;padding:0 12px;font-size:var(--fs-14);font-weight:800;min-width:170px}.srs-appr-input:focus{outline:none;background:#fff;border-color:var(--primary2);box-shadow:0 0 0 2px #7dd3fc59}.srs-reqinfo{border-top:1px solid var(--border2);padding-top:10px;min-height:0;max-height:clamp(120px,24vh,320px);overflow:auto;padding-right:6px}.srs-reqinfo::-webkit-scrollbar{width:8px;height:8px}.srs-reqinfo::-webkit-scrollbar-track{background:transparent}.srs-reqgrid{display:grid;grid-template-columns:160px 1fr;gap:10px 12px;font-size:var(--fs-13)}.srs-reqgrid .k{color:var(--muted);font-weight:900;letter-spacing:.01em}.srs-reqgrid .v{font-weight:800;min-width:0;overflow-wrap:anywhere}.copy.inline,.srs-reqgrid .copy{border:1px solid #e5e7eb;background:#fff;border-radius:10px;height:28px;padding:0 8px;cursor:pointer;margin-left:8px;transition:all .15s ease;display:inline-flex;align-items:center;justify-content:center}.copy.inline:hover,.srs-reqgrid .copy:hover{background:#f8fafc}.srs-card{padding:0;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.srs-card--list .srs-card-head{padding:12px 14px 10px}.srs-card-foot{border-top:1px solid var(--border2);padding:10px 12px;background:#fff}.srs-table-wrap{flex:1;width:100%;overflow:auto;border-radius:0 0 var(--radius) var(--radius);cursor:grab;scroll-behavior:auto}.srs-table-wrap.is-dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.srs-table-wrap::-webkit-scrollbar{width:8px;height:8px}.srs-table-wrap::-webkit-scrollbar-track{background:transparent}.srs-table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.srs-table-wrap::-webkit-scrollbar-thumb:hover{background:#94a3b8}.srs-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.srs-table th{position:sticky;top:0;z-index:5;background:#f8fafc;color:var(--muted);text-transform:uppercase;font-size:var(--fs-12);letter-spacing:.03em;padding:14px 16px;border-bottom:2px solid #f1f5f9;white-space:nowrap;text-align:left}.srs-table td{padding:14px 16px;font-size:var(--fs-14);color:#334155;border-bottom:1px solid #f1f5f9;white-space:nowrap;font-weight:800}.srs-table tr:nth-child(2n) td{background:#fafbfd}.srs-table tr:hover td{background:#f1f5f9!important}.act{display:flex;justify-content:flex-end;padding-right:10px}.srs-loading,.srs-empty{text-align:center;color:#64748b;font-weight:800}.srs-modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:10px;z-index:999}.srs-modal{width:100%;max-width:560px;padding:14px;display:flex;flex-direction:column;gap:12px;box-shadow:0 20px 60px #00000040;animation:srsFade .15s ease}@keyframes srsFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.srs-modal-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid var(--border2)}.srs-modal-head .t{font-weight:900;display:flex;align-items:center;gap:8px}.srs-modal-head .x{border:1px solid #e5e7eb;background:#fff;border-radius:12px;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.srs-modal-body{display:flex;flex-direction:column;gap:12px}.srs-modal-body .hint{font-size:var(--fs-12);color:var(--muted);font-weight:800}.srs-textarea{width:100%;border-radius:14px;border:1px solid #94a3b8;background:#f1f5f9;padding:12px;font-size:var(--fs-14);font-weight:700;resize:vertical;min-height:110px}.srs-textarea:focus{outline:none;border-color:var(--primary2);background:#fff;box-shadow:0 0 0 2px #7dd3fc59}.srs-modal-actions{display:flex;justify-content:flex-end;gap:10px}@media(max-width:900px){.srs-page{padding:12px 14px}.srs-stat{width:100%;justify-items:start;margin-left:0}}@media(max-width:640px){.srs-approve-row{gap:8px}.srs-appr-input{min-width:140px;flex:1 1 160px}.srs-btn{width:100%;justify-content:center}.srs-card-head-right{width:100%;justify-content:flex-start}.srs-reqgrid{grid-template-columns:120px 1fr}.srs-approve-card{max-height:clamp(200px,40vh,520px)}.srs-reqinfo{max-height:clamp(110px,22vh,260px)}}.app-content,.pps-content,.layout-content{height:100%;min-height:0;display:flex;flex-direction:column;overflow:hidden}.app-page,.route-page{flex:1;min-height:0;overflow:hidden}.srs-approve-card{max-height:clamp(190px,32vh,420px)}.srs-reqinfo{max-height:clamp(110px,18vh,220px);overflow:auto;background:#fbfdff;border:1px solid #eef2f7;border-radius:14px;padding:10px 12px;margin-top:8px}.srs-approve-row{background:#f8fafc;border:1px solid #eef2f7;border-radius:14px;padding:10px}.srs-appr-input,.srs-btn{height:40px}.srs-btn-xs{height:34px}.srs-reqgrid{grid-template-columns:140px 1fr;gap:8px 12px}.srs-reqinfo::-webkit-scrollbar{width:6px;height:6px}.srs-reqinfo::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.srs-reqinfo::-webkit-scrollbar-thumb:hover{background:#94a3b8}.srs-page{height:auto;min-height:100vh;overflow:auto}.srs-card{flex:0 0 auto;min-height:auto;overflow:visible}.srs-table-wrap{flex:none;overflow-x:auto;overflow-y:visible;max-height:none;cursor:default}.srs-table-wrap.is-dragging{-webkit-user-select:none;user-select:none}.srs-approve-card,.srs-reqinfo{max-height:none;overflow:visible}.srs-card-foot{position:static}.pns-page{--bg: #f8fafc;--card: #ffffff;--border: #cbd5e1;--border-soft: #e2e8f0;--text: #0f172a;--muted: #64748b;--muted-strong: #475569;--primary: #0369a1;--primary-soft: #e0f2fe;--primary-hover: #0284c7;--green: #166534;--green-soft: #ecfdf5;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--radius-sm: 12px;min-height:100%;height:100%;padding:16px;background:var(--bg);color:var(--text);display:flex;flex-direction:column;gap:12px;overflow:hidden;box-sizing:border-box}.pns-toolbar{display:grid;grid-template-columns:minmax(320px,1fr) auto auto auto auto;gap:12px;align-items:center}.pns-search{position:relative;min-width:0}.pns-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:var(--fs-15);pointer-events:none}.pns-search-input{width:100%;height:42px;border-radius:12px;border:1px solid var(--border);background:#e8edf5;color:var(--text);padding:0 14px 0 38px;font-size:var(--fs-15);font-weight:500;outline:none;transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.pns-search-input::placeholder{color:#7b8794}.pns-search-input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #0369a11a}.pns-btn{height:42px;min-width:110px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);padding:0 14px;font-size:var(--fs-14);font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;transition:background-color .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease,transform .08s ease;box-shadow:0 1px 2px #0f172a08}.pns-btn svg{font-size:var(--fs-15);flex:0 0 auto}.pns-btn:hover:not(:disabled){background:#f8fafc;border-color:#b8c5d3}.pns-btn:active:not(:disabled){transform:translateY(1px)}.pns-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.pns-btn-soft{background:#fff}.pns-btn-primary{background:var(--primary-soft);border-color:#7dd3fc;color:var(--primary)}.pns-btn-primary:hover:not(:disabled){background:#bae6fd;border-color:#38bdf8;color:#075985}.pns-stat{min-width:120px;height:42px;padding:6px 12px;border-radius:12px;background:#fff;border:1px solid var(--border-soft);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;justify-content:center;text-align:right;box-sizing:border-box}.pns-stat-label{font-size:var(--fs-11);line-height:1.1;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.03em}.pns-stat-value{font-size:var(--fs-16);line-height:1.15;font-weight:800;color:var(--text)}.pns-hint{margin-top:-2px;font-size:var(--fs-13);color:var(--muted-strong);font-weight:600;padding:0 2px}.pns-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border-soft)}.pns-card-scroll{flex:1;min-height:0;overflow:auto;position:relative}.pns-table{width:100%;min-width:980px;border-collapse:separate;border-spacing:0}.pns-table thead th{position:sticky;top:0;z-index:3;background:#f8fafc;color:var(--text);font-size:var(--fs-13);font-weight:800;text-align:left;padding:13px 14px;border-bottom:1px solid var(--border);white-space:nowrap}.pns-table thead th:first-child{border-top-left-radius:16px}.pns-table thead th:last-child{border-top-right-radius:16px}.pns-table tbody td{padding:12px 14px;border-bottom:1px solid #eef2f7;font-size:var(--fs-14);vertical-align:middle;color:var(--text);background:#fff}.pns-table tbody tr:last-child td{border-bottom:none}.pns-table tbody tr:hover td{background:#f8fbff}.pns-mono{font-family:var(--pps-font-mono)}.pns-strong{font-weight:800}.pns-number-chip{display:inline-flex;align-items:center;gap:8px;min-height:34px;max-width:100%;padding:0 12px;border-radius:999px;border:1px solid #bae6fd;background:#eff6ff;color:#075985;font-weight:700;box-sizing:border-box}.pns-number-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pns-loading,.pns-empty{padding:32px 20px;text-align:center;color:var(--muted);font-weight:700;font-size:var(--fs-14)}.pns-spin{animation:pns-spin 1s linear infinite}@keyframes pns-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1280px){.pns-toolbar{grid-template-columns:minmax(260px,1fr) auto auto auto}.pns-stat{grid-column:1 / -1;text-align:left;align-items:flex-start}}@media(max-width:1100px){.pns-toolbar{grid-template-columns:1fr 1fr 1fr}.pns-search{grid-column:1 / -1}.pns-stat{grid-column:1 / -1;text-align:left;align-items:flex-start}}@media(max-width:768px){.pns-page{padding:12px;gap:10px}.pns-toolbar{grid-template-columns:1fr 1fr}.pns-search{grid-column:1 / -1}.pns-btn,.pns-stat{width:100%;min-width:0}.pns-stat{grid-column:1 / -1}.pns-table{min-width:760px}}@media(max-width:640px){.pns-toolbar{grid-template-columns:1fr}.pns-search,.pns-stat{grid-column:auto}.pns-btn,.pns-stat{width:100%}}.pns-toolbar{display:grid;grid-template-columns:minmax(320px,1fr) auto auto auto auto auto;gap:12px;align-items:center}.pns-stat{min-width:124px;height:42px;padding:0 14px;border-radius:12px;background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid var(--border);box-shadow:0 1px 2px #0f172a0a;display:inline-flex;align-items:center;justify-content:center;gap:10px;text-align:left;box-sizing:border-box;white-space:nowrap}.pns-stat-label{font-size:var(--fs-11);line-height:1;color:var(--muted);font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin:0}.pns-stat-value{font-size:var(--fs-15);line-height:1;font-weight:800;color:var(--text);margin:0}@media(max-width:1280px){.pns-toolbar{grid-template-columns:minmax(260px,1fr) auto auto auto auto}.pns-stat{min-width:110px}}@media(max-width:1100px){.pns-toolbar{grid-template-columns:1fr 1fr 1fr}.pns-search{grid-column:1 / -1}.pns-stat{grid-column:auto;width:100%;justify-content:center}}@media(max-width:768px){.pns-toolbar{grid-template-columns:1fr 1fr}.pns-search{grid-column:1 / -1}.pns-btn,.pns-stat{width:100%;min-width:0}}@media(max-width:640px){.pns-toolbar{grid-template-columns:1fr}.pns-btn,.pns-stat{width:100%}}.gqd-page{height:100%;padding:16px 18px;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px}.gqd-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.gqd-title{display:flex;flex-direction:column;gap:6px}.gqd-h1{font-size:var(--fs-18);font-weight:900}.gqd-sub{font-size:var(--fs-13);color:#475569;line-height:1.4;display:flex;gap:10px;flex-wrap:wrap;align-items:center}.gqd-sub code{font-family:var(--pps-font-mono)}.gqd-danger{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid #fecaca;background:#fff1f2;color:#9f1239;font-weight:800}.gqd-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.gqd-btn{height:38px;padding:0 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;cursor:pointer;font-weight:800;display:inline-flex;align-items:center;gap:8px}.gqd-btn:hover{background:#f1f5f9}.gqd-btn:disabled{opacity:.55;cursor:not-allowed}.gqd-dangerBtn{border-color:#ef4444;background:#ef4444;color:#fff}.gqd-dangerBtn:hover{background:#dc2626}.gqd-ghost{background:#fff}.gqd-grid{display:grid;grid-template-columns:380px 1fr;gap:12px;align-items:start}.gqd-grid2{display:grid;grid-template-columns:1fr;gap:12px}.gqd-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:12px;box-shadow:0 10px 26px #0000000f}.gqd-card-h{font-weight:900;margin-bottom:10px}.gqd-form{display:flex;flex-direction:column;gap:10px}.gqd-form label{display:flex;flex-direction:column;gap:6px;font-size:var(--fs-13);color:#334155;font-weight:800}.gqd-inputWrap{height:40px;display:flex;align-items:center;gap:8px;border:1px solid #e2e8f0;border-radius:12px;padding:0 12px;background:#fff}.gqd-inputWrap:focus-within{border-color:#0284c7;box-shadow:0 0 0 3px #0284c726}.gqd-inputWrap input{flex:1;border:none;outline:none;background:transparent;font-size:var(--fs-14);color:#0f172a}.req{color:#ef4444;margin-left:4px}.gqd-hint{margin-top:12px;font-size:var(--fs-12);color:#64748b;line-height:1.45}.gqd-sql{margin-top:8px;padding:10px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc;color:#0f172a;overflow:auto;white-space:pre-wrap}.gqd-result{min-height:220px}.gqd-empty{padding:18px;border-radius:12px;border:1px dashed #cbd5e1;background:#f8fafc;color:#64748b}.gqd-kv{display:grid;grid-template-columns:180px 1fr;gap:8px 10px;font-size:var(--fs-13);margin-bottom:10px}.gqd-kv .k{color:#64748b}.gqd-kv .v{font-weight:900;color:#0f172a}.gqd-warn{margin-top:12px;padding:10px 12px;border-radius:12px;border:1px solid #fde68a;background:#fffbeb;color:#92400e;font-weight:900;font-size:var(--fs-13)}.gqd-tableWrap{max-height:360px;overflow:auto;border:1px solid #e2e8f0;border-radius:12px}.gqd-table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-12)}.gqd-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;border-bottom:1px solid #e2e8f0;text-align:left;padding:10px;font-weight:900;white-space:nowrap}.gqd-table tbody td{padding:9px 10px;border-bottom:1px solid #f1f5f9;white-space:nowrap}.gqd-table tbody tr:hover td{background:#f8fafc}@media(max-width:980px){.gqd-grid{grid-template-columns:1fr}.gqd-actions{justify-content:flex-start}}.gqd-jsonCell{margin:0;padding:8px 10px;border-radius:10px;background:#f8fafc;border:1px solid #e2e8f0;font-size:var(--fs-11);line-height:1.45;white-space:pre-wrap;word-break:break-word;min-width:180px;max-width:420px;overflow:auto}.gqd-muted{color:#94a3b8}.mms-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #111827;--muted: #6b7280;--primary: #0369a1;--primary-hover: #0284c7;--danger: #b42318;--danger-hover: #d92d20;--ok: #166534;--warn: #b45309;--shadow: 0 6px 16px rgba(0, 0, 0, .04);padding:16px;background:var(--bg);color:var(--text);min-height:100%}.mms-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:12px}.mms-title{margin:0;font-size:var(--fs-16);font-weight:900}.mms-sub{margin-top:4px;font-size:var(--fs-12);color:var(--muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.mms-role{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:800;font-size:var(--fs-11)}.mms-role.ok{border-color:#bbf7d0;background:#f0fdf4;color:var(--ok)}.mms-role.ro{border-color:#fde68a;background:#fffbeb;color:var(--warn)}.mms-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:12px;margin-bottom:12px;box-shadow:var(--shadow)}.mms-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.mms-card-title{font-size:var(--fs-13);font-weight:900}.mms-field{display:flex;flex-direction:column;gap:6px;margin-top:10px}.mms-field label{font-size:var(--fs-12);font-weight:800;color:#111827}.mms-field input{height:44px;border-radius:12px;border:1px solid var(--border);padding:0 12px;font-size:var(--fs-14);color:#111827;outline:none;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.mms-field input::placeholder{color:#9ca3af;font-weight:500}.mms-field input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f61f}.mms-field input:disabled{background:#f3f4f6;color:#9ca3af}.mms-hint{font-size:var(--fs-12);color:#111827}.mms-hint.ok{color:var(--ok)}.mms-hint.bad{color:var(--danger)}.mms-master{margin-top:6px;border:1px dashed #e5e7eb;background:#fafafa;border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:6px}.mms-master-row{display:flex;justify-content:space-between;gap:10px;font-size:var(--fs-13)}.mms-master-row .k{color:var(--muted);font-weight:800}.mms-master-row .v{font-weight:900;text-align:right;overflow-wrap:anywhere}.mms-current{display:flex;flex-direction:column;gap:8px}.mms-current-row{display:flex;justify-content:space-between;gap:10px;font-size:var(--fs-13)}.mms-current-row .k{color:var(--muted);font-weight:800}.mms-current-row .v{font-weight:900;text-align:right;overflow-wrap:anywhere}.mms-pill{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;border:1px solid #bae6fd;background:#e0f2fe;color:#075985}.mms-empty{padding:10px;color:var(--muted);font-size:var(--fs-13)}.mms-history{display:flex;flex-direction:column;gap:10px}.mms-hrow{display:flex;gap:10px;align-items:flex-start;padding:10px;border:1px dashed #e5e7eb;border-radius:12px;background:#fafafa}.mms-badge{min-width:70px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:var(--fs-12);font-weight:900;border:1px solid var(--border);background:#fff}.mms-badge.ok{border-color:#bbf7d0;background:#f0fdf4;color:var(--ok)}.mms-badge.warn{border-color:#fde68a;background:#fffbeb;color:var(--warn)}.mms-hmeta{flex:1;min-width:0}.mms-hcode{font-size:var(--fs-13);font-weight:900;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.mms-hcode .arrow{color:var(--muted)}.mms-htime{margin-top:2px;font-size:var(--fs-12);color:var(--muted);overflow-wrap:anywhere}.mms-htime .note{color:#374151}.mms-btn{height:40px;width:200px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:transform .06s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease,opacity .15s ease}.mms-btn:hover:not(:disabled){box-shadow:0 10px 22px #0000000f}.mms-btn:active:not(:disabled){transform:translateY(1px)}.mms-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.mms-btn-sm{height:36px;padding:0 10px;border-radius:11px;font-size:var(--fs-13)}.mms-btn-lg{height:44px;padding:0 14px;border-radius:12px;font-size:var(--fs-14)}.mms-btn-ghost{background:#fff}.mms-btn-ghost:hover:not(:disabled){background:#f8fafc}.mms-btn-primary{border-color:var(--primary);background:var(--primary);color:#fff}.mms-btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.mms-btn-danger{border-color:var(--danger);background:var(--danger);color:#fff}.mms-btn-danger:hover:not(:disabled){background:var(--danger-hover);border-color:var(--danger-hover)}.mms-icon-btn{height:36px;width:36px;border-radius:10px;border:1px solid var(--border);background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,box-shadow .15s ease,border-color .15s ease}.mms-icon-btn:hover{background:#f8fafc;box-shadow:0 10px 22px #0000000f}.mms-card-head .mms-btn{height:36px;padding:0 12px;border-radius:12px;font-size:var(--fs-13);justify-content:center}.mms-actionbar{position:sticky;bottom:10px;display:flex;gap:10px;justify-content:space-between;padding:10px;background:#f8fafce6;border:1px solid var(--border);border-radius:14px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 12px 26px #00000014}.mms-actionbar .mms-btn{flex:1;height:44px;justify-content:center}.mms-backdrop{position:fixed;inset:0;background:#0f172a8c;z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}.mms-modal{width:min(520px,100%);background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--border);box-shadow:0 20px 60px #00000040}.mms-modal-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:#f8fafc;border-bottom:1px solid var(--border)}.mms-modal-title{font-size:var(--fs-13);font-weight:900;display:inline-flex;align-items:center;gap:8px}.mms-modal-body{padding:12px}.mms-qr-region{width:100%;border-radius:14px;overflow:hidden;border:1px dashed #cbd5e1;background:#0b1220}.mms-modal-hint{margin-top:10px;font-size:var(--fs-12);color:var(--muted)}@media(max-width:420px){.mms-page,.mms-card{padding:12px}.mms-actionbar{gap:8px;padding:10px}}.wr-page{padding:16px 24px;height:100%;background:#f8fafc;font-size:var(--fs-16);font-weight:400;color:#111827}.wr-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}.wr-title h2{margin:0;font-size:var(--fs-16);font-weight:800;color:#111827}.wr-sub{display:inline-block;margin-top:6px;font-size:var(--fs-13);color:#6b7280}.wr-actions{display:flex;flex-direction:column;gap:10px;min-width:520px}.wr-search{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:10px 12px;transition:border-color .15s ease,box-shadow .15s ease}.wr-search:focus-within{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f626}.wr-search svg{color:#6b7280;font-size:var(--fs-18);flex:0 0 auto}.wr-search input{border:0;outline:none;width:100%;font-size:var(--fs-14);color:#111827;background:transparent}.wr-filters{display:flex;align-items:center;gap:10px;justify-content:flex-end}.wr-filters label{font-size:var(--fs-13);color:#6b7280;font-weight:700}.wr-filters select{height:40px;padding:0 12px;border:1px solid #e5e7eb;border-radius:12px;background:#fff;font-size:var(--fs-14);color:#111827;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.wr-filters select:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f626}.wr-loading{padding:10px 0;font-size:var(--fs-14);color:#6b7280}.wr-empty{padding:18px;background:#fff;border:1px dashed #e5e7eb;border-radius:14px;color:#6b7280}.wr-list{display:flex;flex-direction:column;gap:12px}.wr-card{display:flex;justify-content:space-between;gap:16px;background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:14px;box-shadow:0 1px 4px #1118270f;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.wr-card:hover{border-color:#d1d5db;box-shadow:0 6px 16px #11182714;transform:translateY(-1px)}.wr-card.is-taken{opacity:.9}.wr-card-left{flex:1;min-width:0}.wr-code{font-size:var(--fs-15);font-weight:900;color:#111827;word-break:break-word}.wr-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;margin-bottom:8px}.pill{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;border:1px solid #e5e7eb;background:#f9fafb;font-size:var(--fs-12);color:#374151;font-weight:700;white-space:nowrap}.pill-ok{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.pill-wait{background:#fffbeb;border-color:#fde68a;color:#92400e}.wr-desc{font-size:var(--fs-14);font-weight:700;color:#111827;line-height:1.4;margin-bottom:8px;word-break:break-word}.wr-extra{font-size:var(--fs-13);color:#374151;display:grid;gap:4px}.wr-open,.wr-taken{margin-top:10px;display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800}.wr-open{color:#065f46}.wr-taken{color:#991b1b}.wr-card-right{width:220px;display:flex;flex-direction:column;gap:10px;align-items:stretch}.wr-img-btn{padding:0;border:0;background:transparent;cursor:pointer;border-radius:14px}.wr-img-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #3b82f62e}.wr-thumb{width:220px;height:120px;border-radius:14px;object-fit:cover;border:1px solid #e5e7eb;transition:transform .12s ease,box-shadow .12s ease}.wr-img-btn:hover .wr-thumb{transform:scale(1.01);box-shadow:0 6px 16px #1118271a}.wr-noimg{width:220px;height:120px;border-radius:14px;border:1px dashed #e5e7eb;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-weight:800;font-size:var(--fs-12)}.wr-btn{height:42px;padding:0 16px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-size:var(--fs-14);font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:transform .08s ease,box-shadow .12s ease,opacity .12s ease}.wr-btn:active{transform:translateY(1px)}.wr-btn-primary{background:#2563eb;color:#fff}.wr-btn-primary:hover{box-shadow:0 8px 18px #2563eb2e}.wr-btn-primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.wr-btn-ghost{background:#fff;border:1px solid #e5e7eb;color:#111827}.wr-btn-ghost:hover{background:#f9fafb}.wr-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #3b82f62e}.wr-wo{font-size:var(--fs-13);color:#111827;display:flex;align-items:center;gap:8px;justify-content:flex-end}.wr-modal{position:fixed;inset:0;background:#11182799;display:flex;align-items:center;justify-content:center;padding:18px;z-index:9999}.wr-modal-box{width:min(980px,96vw);background:#fff;border-radius:18px;border:1px solid #e5e7eb;padding:14px;box-shadow:0 10px 30px #00000040}.wr-modal-title{font-size:var(--fs-14);font-weight:900;color:#111827;margin-bottom:10px;word-break:break-word}.wr-modal-img{width:100%;border-radius:14px;border:1px solid #e5e7eb;object-fit:contain;max-height:72vh}.wr-modal-actions{display:flex;justify-content:flex-end;margin-top:10px;gap:10px}@media(max-width:980px){.wr-header{flex-direction:column;align-items:stretch}.wr-actions{min-width:0}}@media(max-width:860px){.wr-card{flex-direction:column}.wr-card-right{width:100%;flex-direction:row;align-items:center;justify-content:space-between}.wr-thumb,.wr-noimg{width:160px;height:96px}}@media(max-width:520px){.wr-page{padding:14px}.wr-card-right{gap:8px}.wr-thumb,.wr-noimg{width:140px;height:86px}.wr-btn{height:40px;font-size:var(--fs-13);padding:0 14px}}.wr-page{min-height:100dvh;height:auto;-webkit-text-size-adjust:100%}.wr-actions{min-width:0}.wr-search input{font-size:var(--fs-16)}.wr-search{min-height:48px;padding:12px}.wr-filters select{height:44px;font-size:var(--fs-16)}.wr-btn{min-height:44px}.wr-img-btn{min-height:44px;-webkit-tap-highlight-color:transparent}@media(max-width:520px){.wr-header{gap:12px}.wr-filters{justify-content:flex-start;width:100%;flex-wrap:wrap}.wr-filters label,.wr-filters select{width:100%}.wr-card{padding:12px;border-radius:16px}.wr-card-right{flex-direction:column;align-items:stretch}.wr-thumb,.wr-noimg{width:100%;height:160px}.wr-wo{justify-content:flex-start}}.wr-modal{padding-top:calc(18px + env(safe-area-inset-top));padding-bottom:calc(18px + env(safe-area-inset-bottom))}.pill-type{display:inline-flex;align-items:center;gap:6px}.wr-accept-box{max-width:560px;width:min(92vw,560px)}.wr-accept-content{display:grid;gap:14px}.wr-accept-desc{padding:12px 14px;border:1px solid var(--border, #dbe2ea);border-radius:12px;background:var(--card-soft, #f8fafc);color:var(--text, #0f172a)}.wr-accept-field{display:grid;gap:8px}.wr-accept-field label{font-weight:600}.wr-accept-field select{width:100%;min-height:42px;border-radius:12px;border:1px solid var(--border, #dbe2ea);background:#fff;padding:0 12px;font:inherit}.wr-accept-hint{font-size:var(--fs-13);color:var(--muted, #64748b)}.wo-close-page{display:flex;height:calc(100vh - 64px);gap:12px;padding:12px;background:#f6f7fb;box-sizing:border-box}.wo-sidebar{width:360px;min-width:320px;max-width:420px;display:flex;flex-direction:column;background:#fff;border:1px solid rgba(20,20,20,.08);border-radius:14px;box-shadow:0 6px 18px #1414140a;overflow:hidden}.wo-detail{flex:1;min-width:0;background:#fff;border:1px solid rgba(20,20,20,.08);border-radius:14px;box-shadow:0 6px 18px #1414140a;overflow:hidden;display:flex}.wo-sidebar-head{padding:14px 14px 10px;border-bottom:1px solid rgba(20,20,20,.06);background:linear-gradient(180deg,#fff,#fbfcff)}.wo-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.wo-title-row h2{margin:0;font-size:var(--fs-18);letter-spacing:.2px}.wo-title-row button{height:34px;width:34px;border-radius:10px;border:1px solid rgba(20,20,20,.1);background:#fff;cursor:pointer;display:grid;place-items:center;transition:transform .15s ease,box-shadow .15s ease}.wo-title-row button:hover{box-shadow:0 6px 16px #14141414;transform:translateY(-1px)}.spin{animation:woSpin .9s linear infinite}@keyframes woSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.wo-search-wrap{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(20,20,20,.1);background:#fff}.wo-search-wrap input{border:none;outline:none;background:transparent;width:100%;font-size:var(--fs-14)}.wo-filter-bar{margin-top:10px}.wo-chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:7px 10px;border-radius:999px;border:1px solid rgba(20,20,20,.12);background:#fff;cursor:pointer;font-size:var(--fs-12);transition:background .15s ease,transform .15s ease,box-shadow .15s ease}.chip:hover{box-shadow:0 6px 14px #14141414;transform:translateY(-1px)}.chip.active{background:#3b82f61a;border-color:#3b82f659;color:#1d4ed8;font-weight:700}.wo-list{flex:1;overflow:auto;padding:10px}.wo-item{padding:10px;border-radius:12px;border:1px solid rgba(20,20,20,.06);background:#fff;cursor:pointer;margin-bottom:10px;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.wo-item:hover{transform:translateY(-1px);box-shadow:0 10px 20px #1414140f;border-color:#1414141f}.wo-item.active{background:#10b98112;border-color:#10b98159}.wo-item-top{display:flex;justify-content:space-between;gap:10px;align-items:baseline}.wo-item-top b{font-size:var(--fs-14)}.wo-item-top span{font-size:var(--fs-12);opacity:.75}.wo-item-desc{margin-top:6px;font-size:var(--fs-12);opacity:.85}.wo-tags{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}.tag{font-size:var(--fs-11);padding:4px 8px;border-radius:999px;background:#1414140f;border:1px solid rgba(20,20,20,.08)}.wo-sidebar-foot{padding:10px 14px;border-top:1px solid rgba(20,20,20,.06);background:#fbfcff;font-size:var(--fs-12);opacity:.85}.wo-empty-state{margin:auto;display:grid;place-items:center;gap:10px;opacity:.7;padding:24px}.wo-empty-state p{margin:0}.wo-workspace{width:100%;display:flex;flex-direction:column;min-width:0}.fade-in{animation:woFadeIn .18s ease-out}@keyframes woFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.wo-workspace-header{padding:14px 16px;border-bottom:1px solid rgba(20,20,20,.06);display:flex;justify-content:space-between;align-items:center;gap:12px;background:linear-gradient(180deg,#fff,#fbfcff)}.wo-workspace-header h1{margin:0;font-size:var(--fs-18);letter-spacing:.2px}.wo-workspace-header h1 small{margin-left:8px;font-size:var(--fs-12);opacity:.65}.wo-workspace-body{flex:1;overflow:auto;padding:14px 16px 20px}.wo-stepper{display:flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none}.wo-stepper .dot{width:26px;height:26px;border-radius:999px;display:grid;place-items:center;font-size:var(--fs-12);font-weight:800;border:1px solid rgba(20,20,20,.14);background:#fff}.wo-stepper .line{width:36px;height:2px;border-radius:99px;background:#1414141f}.wo-stepper .dot.active{background:#3b82f61f;border-color:#3b82f659;color:#1d4ed8}.wo-stepper .dot.done{background:#10b9811f;border-color:#10b98159;color:#047857}.wo-stepper .dot.pending{opacity:.7}.wo-stepper .line.done{background:#10b98159}.wo-stepper .line.pending{background:#1414141f}.telegram-card{border-radius:14px;border:1px solid rgba(20,20,20,.08);background:#fff;box-shadow:0 10px 20px #1414140a;overflow:hidden;margin-bottom:12px}.tg-header{padding:12px 14px;background:#3b82f614;border-bottom:1px solid rgba(20,20,20,.06);display:flex;align-items:center;gap:10px;font-size:var(--fs-14)}.tg-icon{font-size:var(--fs-18)}.tg-wocode{font-weight:800;color:#1d4ed8}.tg-body-text{padding:12px 14px 14px;font-size:var(--fs-13)}.tg-row{display:flex;gap:10px;align-items:flex-start;margin-top:8px}.tg-row:first-child{margin-top:0}.tg-emoji{width:22px;display:inline-flex;justify-content:center;opacity:.9;padding-top:1px}.tg-sep{opacity:.5;margin:0 8px}.tg-divider{height:1px;background:#14141414;margin:12px 0 10px}.tg-row.highlight{padding:10px;border-radius:12px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.22)}.wo-action-box{margin-top:12px;border-radius:14px;border:1px solid rgba(20,20,20,.08);background:#fff;box-shadow:0 10px 20px #1414140a;overflow:hidden}.wo-action-box h3{margin:0;padding:12px 14px;display:flex;align-items:center;gap:10px;font-size:var(--fs-14);background:#10b98114;border-bottom:1px solid rgba(20,20,20,.06)}.wo-textarea{width:calc(100% - 28px);margin:12px 14px 0;min-height:140px;border-radius:12px;border:1px solid rgba(20,20,20,.12);padding:10px 12px;font-size:var(--fs-13);resize:vertical;outline:none;background:#fff}.wo-textarea.short{min-height:120px}.wo-input{width:100%;height:36px;border-radius:10px;border:1px solid rgba(20,20,20,.12);padding:0 10px;font-size:var(--fs-13);outline:none}.wo-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:12px 14px 0}.wo-grid-3 label{display:block;font-size:var(--fs-12);opacity:.75;margin-bottom:6px}.wo-btns{display:flex;gap:10px;padding:12px 14px 14px;flex-wrap:wrap}.btn-primary,.btn-success,.btn-ghost{height:38px;padding:0 14px;border-radius:12px;border:1px solid rgba(20,20,20,.14);background:#fff;cursor:pointer;font-size:var(--fs-13);font-weight:700;display:inline-flex;align-items:center;gap:8px;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.btn-primary{background:#3b82f61a;border-color:#3b82f659;color:#1d4ed8}.btn-success{background:#10b9811f;border-color:#10b98159;color:#047857}.btn-ghost{background:#1414140a}.btn-primary:hover,.btn-success:hover,.btn-ghost:hover{transform:translateY(-1px);box-shadow:0 10px 20px #1414140f}.btn-primary:disabled,.btn-success:disabled,.btn-ghost:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.wo-photo-grid{padding:12px 14px 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.photo-item{border-radius:14px;border:1px solid rgba(20,20,20,.12);overflow:hidden;background:#fff;position:relative}.photo-item img{width:100%;height:160px;object-fit:cover;display:block}.photo-item button{position:absolute;top:8px;right:8px;height:34px;width:34px;border-radius:12px;border:1px solid rgba(20,20,20,.14);background:#ffffffeb;cursor:pointer;display:grid;place-items:center;transition:transform .12s ease,box-shadow .12s ease}.photo-item button:hover{transform:translateY(-1px);box-shadow:0 10px 16px #1414141a}.photo-add{height:160px;border-radius:14px;border:1px dashed rgba(20,20,20,.25);background:#14141405;display:grid;place-items:center;gap:8px;cursor:pointer;font-weight:700;font-size:var(--fs-13);color:#141414cc}.photo-add input{display:none}.status-alert{margin:12px 14px 0;padding:10px 12px;border-radius:12px;border:1px solid rgba(20,20,20,.1);background:#1414140a;font-size:var(--fs-13)}.status-alert.warn{background:#f59e0b1a;border-color:#f59e0b40}.status-alert.ok{background:#10b9811a;border-color:#10b98140}.done-view{margin-top:18px;padding:18px;border-radius:14px;border:1px solid rgba(16,185,129,.25);background:#10b9810f;display:grid;place-items:center;text-align:center;gap:10px}.done-view h2{margin:0;font-size:var(--fs-18)}.done-view p{margin:0;opacity:.8}@media(max-width:1024px){.wo-close-page{flex-direction:column;height:auto;min-height:calc(100vh - 64px)}.wo-sidebar{width:100%;max-width:none;min-width:0;height:380px}.wo-detail{width:100%;min-height:520px}}@media(max-width:640px){.wo-grid-3{grid-template-columns:1fr}.wo-stepper .line{width:22px}.wo-sidebar{height:360px}}.wo-close-page{min-height:calc(100dvh - 64px);height:auto;padding-top:calc(12px + env(safe-area-inset-top));padding-bottom:calc(12px + env(safe-area-inset-bottom));-webkit-text-size-adjust:100%}.wo-title-row button,.chip,.btn-primary,.btn-success,.btn-ghost,.photo-item button{-webkit-tap-highlight-color:transparent}.wo-title-row button:focus-visible,.chip:focus-visible,.btn-primary:focus-visible,.btn-success:focus-visible,.btn-ghost:focus-visible,.wo-input:focus-visible,.wo-textarea:focus-visible,.wo-search-wrap:focus-within{outline:none;box-shadow:0 0 0 3px #3b82f62e}.wo-search-wrap input,.wo-input,.wo-textarea{font-size:var(--fs-16)}@media(max-width:640px){.wo-close-page{flex-direction:column;gap:10px;padding:10px}.wo-sidebar{width:100%;min-width:0;max-width:none;height:42dvh;min-height:280px;max-height:420px}.wo-detail{width:100%;min-height:calc(58dvh - 104px);border-radius:14px}.wo-sidebar-head{padding:12px 12px 10px}.wo-workspace-header{padding:12px;flex-wrap:wrap;align-items:flex-start;gap:10px}.wo-title-row h2,.wo-workspace-header h1{font-size:var(--fs-16)}.wo-search-wrap{padding:10px 12px;border-radius:14px}.wo-search-wrap input{font-size:var(--fs-16)}.chip{padding:9px 12px;font-size:var(--fs-12)}.wo-list{padding:10px}.wo-item{padding:12px;border-radius:14px}.wo-item-top b{font-size:var(--fs-14)}.wo-item-desc{font-size:var(--fs-13)}.wo-stepper .dot{width:24px;height:24px;font-size:var(--fs-12)}.wo-stepper .line{width:18px}.wo-grid-3{gap:12px;padding:12px 12px 0}.wo-grid-3 label{font-size:var(--fs-12)}.wo-input{height:44px;border-radius:12px;padding:0 12px}.wo-textarea{width:calc(100% - 24px);margin:12px 12px 0;border-radius:12px;padding:12px;min-height:140px}.btn-primary,.btn-success,.btn-ghost{height:44px;border-radius:14px;font-size:var(--fs-14);padding:0 14px}.wo-btns{padding:12px 12px 14px;gap:10px}.wo-photo-grid{padding:12px 12px 0;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.photo-item img,.photo-add{height:140px}.photo-item button{height:36px;width:36px}.status-alert{margin:12px 12px 0;font-size:var(--fs-14)}.done-view{padding:16px}.done-view h2{font-size:var(--fs-16)}}@media(max-width:380px){.wo-photo-grid{grid-template-columns:1fr}}.wo-close-page{color:#0f172a}.wo-close-page input,.wo-close-page textarea{color:#0f172a;-webkit-text-fill-color:#0f172a;caret-color:#0f172a}.wo-close-page button,.wo-close-page .chip,.wo-close-page .btn-primary,.wo-close-page .btn-success,.wo-close-page .btn-ghost,.wo-close-page .photo-item button{color:#0f172a;-webkit-text-fill-color:currentColor}.wo-close-page button svg,.wo-close-page .chip svg,.wo-close-page .btn-primary svg,.wo-close-page .btn-success svg,.wo-close-page .btn-ghost svg,.wo-close-page .photo-item button svg{color:currentColor}.wo-close-page .btn-primary{color:#1d4ed8}.wo-close-page .btn-success{color:#047857}.wo-close-page .btn-ghost{color:#111827}.wo-close-page .wo-title-row button{background:#fff;border-color:#1414141a;color:#111827}.wo-close-page .chip{background:#fff;border-color:#1414141f}.wo-close-page .chip.active{color:#1d4ed8}@media(forced-colors:active){.wo-close-page{forced-color-adjust:auto}.wo-close-page .wo-sidebar,.wo-close-page .wo-detail,.wo-close-page .telegram-card,.wo-close-page .wo-action-box,.wo-close-page .wo-item,.wo-close-page .photo-item,.wo-close-page .done-view{border:1px solid ButtonText;background:Canvas;color:CanvasText}.wo-close-page button,.wo-close-page .chip,.wo-close-page .btn-primary,.wo-close-page .btn-success,.wo-close-page .btn-ghost,.wo-close-page .photo-item button{border:1px solid ButtonText;background:ButtonFace;color:ButtonText}.wo-close-page input,.wo-close-page textarea,.wo-close-page .wo-search-wrap{border:1px solid ButtonText;background:Field;color:FieldText;-webkit-text-fill-color:FieldText}}.wom-page{--bg-color: #f3f4f6;--card-bg: #ffffff;--text-main: #1f2937;--text-muted: #6b7280;--border-color: #e5e7eb;--primary: #2563eb;--primary-hover: #1d4ed8;--success-bg: #d1fae5;--success-text: #065f46;--warn-bg: #fef3c7;--warn-text: #92400e;--danger-bg: #fee2e2;--danger-text: #b91c1c;height:100%;display:flex;flex-direction:column;background-color:var(--bg-color);color:var(--text-main);font-family:var(--pps-font-main);overflow:hidden}.wom-page .wom-header{flex:0 0 auto;background-color:var(--card-bg);border-bottom:1px solid var(--border-color);padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 2px #0000000d}.wom-page .wom-title h2{margin:0;font-size:var(--fs-20);font-weight:600;display:flex;align-items:center;gap:.5rem}.wom-page .wom-subtitle{font-size:var(--fs-14);color:var(--text-muted);margin-top:.25rem}.wom-page .wom-controls{display:flex;gap:.75rem;align-items:center}.wom-page .wom-search-box{position:relative;display:flex;align-items:center}.wom-page .wom-search-icon{position:absolute;left:.75rem;color:var(--text-muted)}.wom-page .wom-input{padding:.5rem 1rem .5rem 2.25rem;border:1px solid var(--border-color);border-radius:6px;font-size:var(--fs-14);min-width:220px;outline:none}.wom-page .wom-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #2563eb1a}.wom-page .wom-select{padding:.5rem 2rem .5rem 1rem;border:1px solid var(--border-color);border-radius:6px;font-size:var(--fs-14);background-color:var(--card-bg);cursor:pointer}.wom-page .wom-btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);cursor:pointer;color:var(--text-main);transition:all .2s}.wom-page .wom-btn-icon:hover:not(:disabled){background-color:var(--bg-color)}.wom-page .wom-checkbox-label{font-size:var(--fs-14);display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.wom-page .wom-content{flex:1;padding:1.5rem;overflow:hidden}.wom-page .wom-table-card{background:var(--card-bg);border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color);height:100%;display:flex;flex-direction:column}.wom-page .wom-table-scroll{flex:1;overflow-y:auto}.wom-page .wom-table{width:100%;border-collapse:collapse;font-size:var(--fs-14)}.wom-page .wom-table th{position:sticky;top:0;background-color:#f9fafb;color:var(--text-muted);font-weight:600;text-transform:uppercase;font-size:var(--fs-12);padding:.75rem 1rem;border-bottom:1px solid var(--border-color);text-align:left;z-index:5}.wom-page .wom-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);color:var(--text-main);vertical-align:middle}.wom-page .wom-table tbody tr:hover{background-color:#eff6ff;cursor:pointer}.wom-page .status-badge{display:inline-flex;align-items:center;padding:.15rem .6rem;border-radius:9999px;font-size:var(--fs-12);font-weight:600;text-transform:uppercase}.wom-page .status-badge.closed{background-color:var(--success-bg);color:var(--success-text)}.wom-page .status-badge.pending{background-color:var(--danger-bg);color:var(--danger-text)}.wom-page .wom-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:50;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.wom-page .wom-modal{background:var(--card-bg);width:100%;max-width:650px;max-height:90vh;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.wom-page .wom-modal-head{padding:1.25rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.wom-page .wom-modal-head h3{margin:0;font-size:var(--fs-18);color:var(--text-main)}.wom-page .wom-modal-close{background:none;border:none;font-size:var(--fs-24);color:var(--text-muted);cursor:pointer}.wom-page .wom-modal-body{padding:1.5rem;overflow-y:auto}.wom-page .wom-row{margin-bottom:1rem}.wom-page .wom-label{display:block;font-size:var(--fs-12);color:var(--text-muted);margin-bottom:.25rem;font-weight:600;text-transform:uppercase}.wom-page .wom-value{font-size:var(--fs-15);color:var(--text-main);line-height:1.5}.wom-page .wom-note-box{background:#f9fafb;border:1px solid var(--border-color);padding:.75rem;border-radius:6px;white-space:pre-wrap;font-family:var(--pps-font-mono)}.wom-page .loading-spinner{animation:spin 1s linear infinite}@media(max-width:768px){.wom-page .wom-header{flex-direction:column;align-items:flex-start;gap:1rem}.wom-page .wom-controls{width:100%;flex-wrap:wrap}.wom-page .wom-input{flex:1}}.wom-page{min-height:100dvh;height:auto;overflow:hidden;-webkit-text-size-adjust:100%}.wom-page .wom-content{flex:1;overflow:hidden;padding:1rem}.wom-page .wom-table-scroll{overflow:auto;-webkit-overflow-scrolling:touch}.wom-page .wom-input,.wom-page .wom-select{font-size:var(--fs-16);height:44px;border-radius:10px}.wom-page .wom-input{min-width:0;width:100%;padding:0 12px 0 44px}.wom-page .wom-search-icon{left:14px}.wom-page .wom-btn-icon{width:44px;height:44px;border-radius:10px;-webkit-tap-highlight-color:transparent}.wom-page .wom-checkbox-label{min-height:44px}.wom-page .wom-input:focus,.wom-page .wom-select:focus,.wom-page .wom-btn-icon:focus-visible{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb2e}.wom-page .wom-table{min-width:920px}.wom-page .wom-table th,.wom-page .wom-table td{white-space:nowrap}@media(max-width:768px){.wom-page .wom-header{padding:12px;gap:10px}.wom-page .wom-title h2{font-size:var(--fs-17)}.wom-page .wom-controls{width:100%;gap:10px;align-items:stretch}.wom-page .wom-search-box,.wom-page .wom-select{width:100%}.wom-page .wom-btn-icon{flex:0 0 auto}}@media(max-width:420px){.wom-page .wom-header{padding:10px}.wom-page .wom-subtitle{font-size:var(--fs-14);line-height:1.25}.wom-page .wom-content{padding:10px}}@media(max-width:640px){.wom-page .wom-modal-overlay{padding:10px;padding-top:calc(10px + env(safe-area-inset-top));padding-bottom:calc(10px + env(safe-area-inset-bottom))}.wom-page .wom-modal{max-width:100%;max-height:100dvh;border-radius:14px}.wom-page .wom-modal-head{padding:14px 14px 12px}.wom-page .wom-modal-body{padding:14px}}:root{--pps-font-main: "Inter", "Noto Sans Thai", "Sarabun", system-ui, sans-serif;--pps-bg: #f8fafc;--pps-card: #ffffff;--pps-border: #e5e7eb;--pps-border-strong: #cbd5e1;--pps-text: #0f172a;--pps-text-soft: #334155;--pps-muted: #64748b;--pps-primary: #0369a1;--pps-radius-sm: 10px;--pps-radius-md: 14px;--pps-radius-lg: 18px;--pps-shadow: 0 4px 16px rgba(15, 23, 42, .05);--pps-text-xs: 12px;--pps-text-sm: 13px;--pps-text-md: 14px;--pps-text-lg: 16px}.mbe-page{min-height:100%;width:100%;max-width:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);color-scheme:light;font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:16px;overflow-x:hidden;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}.mbe-page *{min-width:0}.mbe-page input,.mbe-page select,.mbe-page textarea,.mbe-page button{font:inherit;color:inherit;font-family:inherit}.mbe-page input,.mbe-page select,.mbe-page textarea,.mbe-page .mbe-in,.mbe-page .mbe-search input{color:var(--pps-text)!important;-webkit-text-fill-color:var(--pps-text)!important;caret-color:var(--pps-text)!important;background-clip:padding-box;text-shadow:none!important}.mbe-page input::placeholder,.mbe-page textarea::placeholder,.mbe-page .mbe-search input::placeholder{color:#94a3b8!important;-webkit-text-fill-color:#94a3b8!important}.mbe-topbar,.mbe-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);box-shadow:var(--pps-shadow)}.mbe-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:16px;flex-wrap:wrap}.mbe-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.3;color:var(--pps-text)}.mbe-sub{margin-top:4px;font-size:var(--pps-text-sm);font-weight:500;color:var(--pps-muted);line-height:1.45}.mbe-changed{color:#92400e;font-weight:700}.mbe-actions{display:flex;gap:8px;flex-wrap:wrap}.mbe-btn,.mbe-btn-primary{min-height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border-strong);background:#fff;color:var(--pps-text);-webkit-text-fill-color:currentColor!important;cursor:pointer;font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.mbe-btn:hover,.mbe-btn-primary:hover{transform:translateY(-1px)}.mbe-btn:hover{background:#f8fafc}.mbe-btn-primary{border:none;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff!important;-webkit-text-fill-color:#ffffff!important;box-shadow:0 6px 14px #0284c72e}.mbe-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985)}.mbe-btn:disabled,.mbe-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.mbe-card{padding:16px}.mbe-filters{display:grid;gap:12px}.mbe-tabs{display:flex;gap:8px;flex-wrap:wrap}.mbe-tab{min-height:36px;padding:0 12px;border-radius:999px;border:1px solid var(--pps-border);background:#f8fafc;color:var(--pps-text);cursor:pointer;font-size:var(--pps-text-sm);font-weight:800;font-family:var(--pps-font-main);display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.mbe-tab.on{background:#e0f2fe;border-color:#7dd3fc;color:#075985}.mbe-tab:disabled{opacity:.6;cursor:not-allowed}.mbe-grid{display:grid;grid-template-columns:220px 280px minmax(0,1fr);gap:12px;align-items:start}.mbe-field label{display:block;margin-bottom:6px;font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.mbe-field select,.mbe-field input[type=month],.mbe-search{width:100%;min-height:40px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border-strong);background:#f8fafc}.mbe-field select,.mbe-field input[type=month]{padding:0 12px;outline:none;font-size:var(--pps-text-md);font-weight:600}.mbe-field select:focus,.mbe-field input[type=month]:focus,.mbe-search:focus-within,.mbe-in:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f;outline:none}.mbe-help{margin-top:6px;font-size:var(--pps-text-xs);font-weight:500;color:var(--pps-muted);line-height:1.45}.mbe-search{display:flex;align-items:center;gap:8px;padding:0 12px;color:var(--pps-muted)}.mbe-search input{width:100%;height:38px;border:none;outline:none;background:transparent!important;font-weight:600}.mbe-table-wrap{overflow:auto;border-radius:var(--pps-radius-md);border:1px solid var(--pps-border);background:#fff;-webkit-overflow-scrolling:touch}.mbe-table{width:100%;min-width:960px;border-collapse:separate;border-spacing:0}.mbe-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);border-bottom:1px solid var(--pps-border);padding:12px;font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap}.mbe-table td{border-bottom:1px solid #f1f5f9;padding:12px;vertical-align:middle;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);color:var(--pps-text);line-height:1.5}.mbe-table tbody tr:nth-child(2n){background:#fafafa}.mbe-table tbody tr:hover{background:#f1f5f9}.mbe-empty{padding:24px!important;text-align:center;color:var(--pps-muted);font-size:var(--pps-text-md);font-weight:600}.mbe-in{width:100%;min-height:38px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border-strong);padding:0 10px;background:#f8fafc!important;font-size:var(--pps-text-md);font-weight:600}.mbe-foot{margin-top:10px}.mbe-muted{color:var(--pps-muted)!important;-webkit-text-fill-color:var(--pps-muted)!important;font-size:var(--pps-text-xs);font-weight:500;line-height:1.45}@media(max-width:980px){.mbe-topbar{align-items:flex-start}.mbe-actions{width:100%}.mbe-btn,.mbe-btn-primary{flex:1 1 auto}.mbe-grid{grid-template-columns:1fr}}@media(max-width:640px){.mbe-page{padding:12px;gap:12px}.mbe-topbar,.mbe-card{padding:12px;border-radius:14px}.mbe-title{font-size:var(--fs-15)}.mbe-actions{flex-direction:column;align-items:stretch}.mbe-btn,.mbe-btn-primary{width:100%}.mbe-tabs{flex-direction:column}.mbe-tab{width:100%;justify-content:center}.mbe-table{min-width:860px}.mbe-table thead th{font-size:var(--fs-12);padding:10px 8px}.mbe-table td{font-size:var(--fs-13);padding:10px 8px}.mbe-in{min-height:36px;font-size:var(--fs-13)}}@media(forced-colors:active){.mbe-page{forced-color-adjust:auto}.mbe-page input,.mbe-page select,.mbe-page textarea,.mbe-page .mbe-in,.mbe-page .mbe-search{border:1px solid ButtonText!important;background:Field!important;color:FieldText!important;-webkit-text-fill-color:FieldText!important}.mbe-page .mbe-btn,.mbe-page .mbe-btn-primary{border:1px solid ButtonText!important;background:ButtonFace!important;color:ButtonText!important;-webkit-text-fill-color:ButtonText!important}}.prpo-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.prpo-title{display:flex;flex-direction:column;gap:4px}.prpo-h1{font-size:var(--fs-18);font-weight:800;letter-spacing:.2px}.prpo-sub{font-size:var(--fs-13);color:#475569}.prpo-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.prpo-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#0f172a;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .05s ease,box-shadow .15s ease,background .15s ease}.prpo-btn--ghost:hover{background:#f8fafc}.prpo-btn--primary{background:#0369a1;border-color:#0369a1;color:#fff}.prpo-filters{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;padding:12px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.prpo-field{display:flex;flex-direction:column;gap:6px;min-width:160px}.prpo-field label{font-size:var(--fs-12);color:#64748b}.prpo-field input,.prpo-field select{height:38px;border-radius:12px;border:1px solid #e2e8f0;padding:0 10px;background:#fff;color:#0f172a;outline:none}.prpo-field input:focus,.prpo-field select:focus{border-color:#94a3b8;box-shadow:0 0 0 3px #94a3b840}.prpo-field--search{flex:1;min-width:260px;position:relative}.prpo-field--search input{padding-left:34px}.prpo-ico{position:absolute;left:10px;top:34px;transform:translateY(-50%);color:#64748b}.prpo-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;min-height:240px}.prpo-table-wrap{position:relative;overflow:auto;max-height:calc(100vh - 260px)}.prpo-table thead th{position:sticky;top:0;background:#f8fafc;z-index:2;text-align:left;font-weight:800;color:#0f172a;padding:12px;border-bottom:1px solid #e2e8f0}.prpo-table tbody td{padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.prpo-empty{text-align:center;padding:28px 12px!important;color:#64748b}.prpo-clip{max-width:420px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prpo-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-weight:800;font-size:var(--fs-12);border:1px solid transparent}.prpo-badge--muted{background:#f1f5f9;color:#334155;border-color:#e2e8f0}.prpo-badge--info{background:#e0f2fe;color:#075985;border-color:#bae6fd}.prpo-badge--warning{background:#fef9c3;color:#854d0e;border-color:#fde68a}.prpo-badge--danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}.prpo-badge--ok{background:#dcfce7;color:#166534;border-color:#bbf7d0}.prpo-badge--primary{background:#e0f2fe;color:#0369a1;border-color:#bae6fd}.prpo-badge--ok2{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.prpo-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:10px;background:#ffffffb8;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);font-weight:800;color:#0f172a}.prpo-spinner{width:18px;height:18px;border-radius:999px;border:3px solid #e2e8f0;border-top-color:#0ea5e9;animation:prpoSpin 1s linear infinite}@keyframes prpoSpin{to{transform:rotate(360deg)}}.prpo-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;border-top:1px solid #e2e8f0;background:#fff}.prpo-footer-left,.prpo-footer-right{display:flex;align-items:center;gap:10px}.prpo-muted{color:#64748b;font-size:var(--fs-13)}.prpo-page-indicator{color:#334155;font-size:var(--fs-13)}.prpo-footer select{height:36px;border-radius:12px;border:1px solid #e2e8f0;padding:0 10px}.plc-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--primary-soft: #e0f2fe;--danger: #ef4444;--danger-soft: #fee2e2;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--tap: 40px;padding:14px;background:var(--bg);min-height:calc(100vh - 56px);color:var(--text)}.plc-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:12px}.plc-title{min-width:0}.plc-h1{font-size:var(--fs-20);font-weight:900;letter-spacing:.2px;line-height:1.2}.plc-sub{margin-top:2px;font-size:var(--fs-12);color:var(--muted)}.plc-actions{display:flex;align-items:center;gap:10px;flex-wrap:nowrap}.plc-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:12px;overflow:hidden}.plc-card-title,.plc-card-title--row{padding:12px 14px;font-weight:900;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.plc-form-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:12px;padding:12px 14px}@media(max-width:980px){.plc-form-grid{grid-template-columns:1fr}}.plc-field label{display:block;font-size:var(--fs-13);font-weight:800;margin-bottom:6px}.plc-field .req{color:var(--danger);margin-left:2px}.plc-field select,.plc-field textarea,.plc-in{width:100%;border:1px solid var(--border);border-radius:12px;background:#fff;outline:none}.plc-field select{height:40px;padding:0 10px}.plc-field textarea{padding:10px;resize:vertical;min-height:78px}.plc-field--remark{align-self:stretch}.plc-hint{margin-top:6px;font-size:var(--fs-12);color:var(--muted)}.plc-btn{height:var(--tap);padding:0 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:800;display:inline-flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.plc-btn:disabled{opacity:.6;cursor:not-allowed}.plc-btn--ghost{background:#fff}.plc-btn--primary{border-color:#93c5fd;background:var(--primary);color:#fff}.plc-btn--primary:hover{filter:brightness(1.02)}.plc-btn--danger{border-color:#fecaca;background:#fff;color:#b91c1c}.plc-btn--sm{height:34px;padding:0 10px;border-radius:12px;font-size:var(--fs-13)}.plc-table-wrap{width:100%;overflow:auto}.plc-table{width:100%;border-collapse:separate;border-spacing:0;min-width:980px}.plc-table thead th{position:sticky;top:0;z-index:2;background:#f1f5f9;border-bottom:1px solid var(--border);font-size:var(--fs-12);font-weight:900;color:#334155;padding:10px;text-align:left;white-space:nowrap}.plc-table tbody td{border-bottom:1px solid var(--border);padding:10px;vertical-align:middle;background:#fff}.plc-table tbody tr:hover td{background:#f8fafc}.plc-table tfoot td{padding:10px;background:#fff;border-top:1px solid var(--border)}.plc-center{text-align:center}.plc-right{text-align:right}.plc-mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.plc-foot-label,.plc-foot-total{font-weight:900;color:#0f172a}.plc-footnote{padding:10px 14px 14px;font-size:var(--fs-12);color:var(--muted)}.plc-in{height:36px;padding:0 10px;border-radius:10px}.plc-in--num{text-align:right;font-variant-numeric:tabular-nums}.plc-mp{position:relative}.plc-mp-btn{width:100%;height:36px;border-radius:10px;border:1px solid var(--border);background:#fff;display:flex;align-items:center;gap:8px;padding:0 10px;cursor:pointer;-webkit-user-select:none;user-select:none}.plc-mp-btn:disabled{opacity:.6;cursor:not-allowed}.plc-mp-text{flex:1;min-width:0;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#0f172a;font-weight:700}.plc-mp-text.is-empty{color:var(--muted);font-weight:700}.plc-mp-caret{opacity:.8}.plc-mp-panel{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:50;border:1px solid var(--border);border-radius:14px;background:#fff;box-shadow:0 14px 32px #02061726;overflow:hidden}.plc-mp-top{display:flex;align-items:center;gap:8px;padding:10px;border-bottom:1px solid var(--border);background:#fff}.plc-mp-inputwrap{position:relative;flex:1;min-width:0}.plc-mp-top input{width:100%;height:36px;border:1px solid var(--border);border-radius:12px;padding:0 34px 0 10px;outline:none}.plc-mp-x{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:transparent;cursor:pointer;color:#64748b;display:inline-flex;padding:4px;border-radius:8px}.plc-mp-x:hover{background:#f1f5f9}.plc-mp-list{max-height:360px;overflow:auto}.plc-mp-loading,.plc-mp-empty{padding:14px;font-size:var(--fs-13);color:var(--muted)}.plc-mp-item{width:100%;text-align:left;border:none;background:#fff;cursor:pointer;padding:10px;display:grid;grid-template-columns:1fr;gap:6px;border-bottom:1px solid #f1f5f9}.plc-mp-item:hover{background:#f8fafc}.plc-mp-item .a{display:flex;gap:10px;align-items:baseline;min-width:0}.plc-mp-item .code{font-weight:900;color:#0f172a;white-space:nowrap}.plc-mp-item .name{flex:1;min-width:0;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plc-mp-item .b{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}.plc-mp-item .meta{font-size:var(--fs-12);color:#64748b}@media(max-width:640px){.plc-page{padding:10px}.plc-topbar{flex-direction:column;align-items:stretch}.plc-actions{justify-content:flex-end}.plc-table{min-width:860px}}.prpo-page{--bg: #f5f7fb;--card: #ffffff;--border: #dfe7f3;--border2: #e9effa;--text: #0f172a;--muted: #6b7280;--primary: #0b63ce;--primary-soft: #eaf3ff;--primary-bd: #cfe3ff;--ok: #16a34a;--ok-soft: #eafaf0;--ok-bd: #c9f3d6;--warn: #f59e0b;--warn-soft: #fff7e6;--warn-bd: #ffe4b3;--danger: #ef4444;--danger-soft: #fff1f1;--danger-bd: #ffd1d1;--shadow: 0 6px 18px rgba(16, 24, 40, .04);--radius: 18px;--tabs-h: 56px;--tab-h: 40px;--p-card: 16px;--p-card-tight-hd: 18px;--p-card-tight-body: 18px;padding:16px;min-height:calc(100vh - 56px);background:var(--bg);color:var(--text);font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:14px;isolation:isolate}.prpo-muted{color:var(--muted)}.prpo-mono{font-family:var(--pps-font-mono);font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.prpo-amt{font-size:var(--fs-18);font-weight:900;letter-spacing:.2px}.prpo-center{text-align:center}.prpo-right{text-align:right}.prpo-page :where(button,a,input,select,textarea,[tabindex]):focus-visible{outline:none;box-shadow:0 0 0 3px #0b63ce2e;border-color:#9cc6ff}.prpo-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.prpo-title{min-width:0;display:flex;flex-direction:column;gap:4px}.prpo-h1{font-size:var(--fs-20);font-weight:900;letter-spacing:.2px;line-height:1.2;display:flex;align-items:baseline;gap:8px}.prpo-sub{font-size:var(--fs-13);color:var(--muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.prpo-actions{display:flex;gap:10px;align-items:center;flex-wrap:nowrap}.prpo-btn{height:40px;padding:0 14px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:900;display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:transform .05s ease,background .15s ease,border-color .15s ease,filter .15s ease}.prpo-btn svg{font-size:var(--fs-16)}.prpo-btn:active{transform:translateY(1px)}.prpo-btn:disabled{opacity:.6;cursor:not-allowed}.prpo-btn--ghost:hover{background:#f8fbff;border-color:#cfe0f8}.prpo-btn--primary{background:var(--primary);border-color:#0b63ce;color:#fff}.prpo-btn--primary:hover{filter:brightness(1.03)}.prpo-btn--ok{background:var(--ok);border-color:var(--ok);color:#fff}.prpo-btn--ok:hover{filter:brightness(1.03)}.prpo-btn--danger{background:#fff;border-color:var(--danger-bd);color:#b91c1c}.prpo-btn--danger:hover{background:#fff7f7;border-color:#ffb3b3}.prpo-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.prpo-card:not(.prpo-card--tight){padding:var(--p-card)}.prpo-card--tight{padding:0}.prpo-card-title{padding:14px 16px;font-weight:900;border-bottom:1px solid var(--border2);color:#0b1220;font-size:var(--fs-16);line-height:1.25}.prpo-card-title--row{display:flex;align-items:center;justify-content:space-between;gap:12px}.prpo-card-title--row .prpo-muted{font-size:var(--fs-13);white-space:nowrap}.prpo-card--tight .prpo-card-title{padding:var(--p-card-tight-hd)}.prpo-grid-4{display:grid;grid-template-columns:1fr;gap:12px;padding:var(--p-card-tight-body)}@media(min-width:900px){.prpo-grid-4{grid-template-columns:1.2fr .9fr 1.2fr .8fr;align-items:center;gap:16px}}.prpo-kv{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:start;min-width:0}.prpo-kv .k{font-size:var(--fs-13);color:#64748b;padding-top:2px}.prpo-kv .v{min-width:0;font-weight:900;font-size:var(--fs-14);color:#0b1220;overflow-wrap:anywhere}.prpo-remark{padding:14px var(--p-card-tight-body) 16px var(--p-card-tight-body);border-top:1px solid var(--border2);display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:start}.prpo-remark .k{font-size:var(--fs-13);color:#64748b;padding-top:2px}.prpo-remark .v{font-size:var(--fs-13);font-weight:700;white-space:pre-wrap;color:#0f172a;overflow-wrap:anywhere}.prpo-actions-hub{padding:16px var(--p-card-tight-body) 20px var(--p-card-tight-body);display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-height:68px}.prpo-tabs{display:flex;align-items:center;gap:10px;min-height:var(--tabs-h);padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;position:sticky;top:10px;z-index:5;-webkit-backdrop-filter:saturate(1);backdrop-filter:saturate(1)}.prpo-tabs::-webkit-scrollbar{height:8px}.prpo-tabs::-webkit-scrollbar-thumb{background:#dbe7fb;border-radius:999px}.prpo-tab{height:var(--tab-h);padding:0 14px;border-radius:14px;border:1px solid var(--border);background:#fff;color:#0f172a;font-weight:900;display:inline-flex;align-items:center;gap:10px;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease,color .15s ease,filter .15s ease}.prpo-tab:hover{background:#f7fbff;border-color:#cfe3ff}.prpo-tab.is-active{background:var(--primary-soft);border-color:var(--primary-bd);color:#0b63ce}.prpo-table-wrap{border:1px solid var(--border2);border-radius:16px;overflow:auto;background:#fff;margin-top:12px}.prpo-table-wrap::-webkit-scrollbar,.prpo-timeline::-webkit-scrollbar{height:10px;width:10px}.prpo-table-wrap::-webkit-scrollbar-thumb,.prpo-timeline::-webkit-scrollbar-thumb{background:#dbe7fb;border-radius:999px}.prpo-table-wrap::-webkit-scrollbar-track,.prpo-timeline::-webkit-scrollbar-track{background:#f6f8ff;border-radius:999px}.prpo-table{width:100%;min-width:920px;border-collapse:separate;border-spacing:0;font-size:var(--fs-14)}.prpo-table thead th{position:sticky;top:0;z-index:2;background:#f7faff;color:#475569;font-weight:900;text-align:left;padding:14px;border-bottom:1px solid var(--border2);white-space:nowrap}.prpo-table tbody td{padding:14px;border-bottom:1px solid #eef4ff;vertical-align:middle;background:#fff}.prpo-table tbody tr:hover td{background:#fbfdff}.prpo-table tfoot td{padding:14px;background:#f7faff;border-top:1px solid var(--border2)}.prpo-foot-label,.prpo-foot-total{font-weight:900;color:#0b1220}.prpo-loading{position:sticky;left:0;right:0;bottom:0;padding:12px 14px;display:inline-flex;align-items:center;gap:10px;font-weight:900;color:#334155;background:#ffffffeb;border-top:1px solid var(--border2)}.prpo-spinner{width:18px;height:18px;border-radius:999px;border:2px solid #cbd5e1;border-top-color:var(--primary);animation:prpo-spin 1s linear infinite}.prpo-meta-line{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:10px;color:#64748b;font-size:var(--fs-14);flex-wrap:wrap}.prpo-badge{display:inline-flex;align-items:center;justify-content:center;height:30px;padding:0 14px;border-radius:999px;font-weight:900;font-size:var(--fs-13);border:1px solid transparent;white-space:nowrap}.prpo-badge--muted{background:#f1f5f9;border-color:#e5e7eb;color:#475569}.prpo-badge--info{background:var(--primary-soft);border-color:var(--primary-bd);color:#0b63ce}.prpo-badge--warning{background:var(--warn-soft);border-color:var(--warn-bd);color:#92400e}.prpo-badge--danger{background:var(--danger-soft);border-color:var(--danger-bd);color:#991b1b}.prpo-badge--ok{background:var(--ok-soft);border-color:var(--ok-bd);color:#166534}.prpo-badge--ok2{background:#eef2ff;border-color:#dbeafe;color:#1e40af}.prpo-badge--primary{background:var(--primary-soft);border-color:var(--primary-bd);color:#0b63ce}.prpo-empty{text-align:center;color:var(--muted);padding:18px 10px}.prpo-flow{display:grid;grid-template-columns:1fr;gap:12px;padding-top:12px}@media(min-width:1100px){.prpo-flow{grid-template-columns:420px 1fr;align-items:start}}.prpo-flow-left,.prpo-flow-right{border:1px solid var(--border2);border-radius:16px;padding:12px;background:#fff;min-width:0}.prpo-flow-step{display:flex;gap:10px;align-items:flex-start;padding:10px 8px;border-bottom:1px dashed #eef4ff}.prpo-flow-step:last-child{border-bottom:none}.prpo-flow-step .dot{width:12px;height:12px;border-radius:999px;margin-top:5px;background:#cbd5e1;flex:0 0 auto}.prpo-flow-step .dot.is-on{background:var(--primary);box-shadow:0 0 0 4px #0b63ce1f}.prpo-flow-step .txt .t{font-weight:900;color:#0b1220}.prpo-flow-step .txt .d{margin-top:2px;font-size:var(--fs-12);color:#64748b}.prpo-timeline{max-height:420px;overflow:auto;display:flex;flex-direction:column;gap:10px}.prpo-tl-item{border:1px solid var(--border2);border-radius:16px;padding:10px 12px;background:#fff;display:grid;grid-template-columns:150px 1fr;gap:10px;align-items:start}@media(max-width:640px){.prpo-tl-item{grid-template-columns:1fr}}.prpo-tl-item .ts{font-size:var(--fs-12);color:#64748b;white-space:nowrap}.prpo-tl-item .title{font-weight:900;color:#0b1220}.prpo-tl-item .desc{margin-top:4px;font-size:var(--fs-12);color:#475569;white-space:pre-wrap;overflow-wrap:anywhere}.prpo-tl-item--ok{border-color:var(--ok-bd);background:#f3fdf7}.prpo-tl-item--danger{border-color:var(--danger-bd);background:#fff7f7}.prpo-tl-item--warning{border-color:var(--warn-bd);background:#fffaf0}.prpo-tl-item--info{border-color:var(--primary-bd);background:#f3f8ff}.prpo-tl-item--system{border-color:var(--border2);background:#f8fafc}.prpo-tl-item--muted{border-color:var(--border2);background:#fff}.prpo-tl-hint{margin-top:10px;font-size:var(--fs-12);color:#64748b}@media(prefers-reduced-motion:reduce){.prpo-btn,.prpo-tab{transition:none!important}.prpo-spinner{animation:none!important}}@media(max-width:900px){.prpo-clip{max-width:100%}}@media(max-width:640px){.prpo-page{padding:12px;gap:12px}.prpo-topbar{flex-direction:column;align-items:stretch}.prpo-actions{justify-content:flex-end;flex-wrap:wrap}.prpo-kv,.prpo-remark{grid-template-columns:105px 1fr}.prpo-actions-hub{gap:10px}.prpo-actions-hub .prpo-btn{flex:0 0 auto}.prpo-card:not(.prpo-card--tight){padding:12px}.prpo-card-title{padding:14px}.prpo-card--tight .prpo-card-title,.prpo-grid-4{padding:16px 14px}.prpo-remark{padding:12px 14px 14px}.prpo-actions-hub{padding:14px 14px 16px}.prpo-table{min-width:820px}.prpo-tabs{top:8px}}.prpo-page{padding:16px 18px;height:100%;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px}.prpo-topbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.prpo-title{display:flex;flex-direction:column;gap:2px}.prpo-h1{font-size:var(--fs-18);font-weight:800}.prpo-sub{font-size:var(--fs-12);color:#64748b}.prpo-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.prpo-btn{border:1px solid #e2e8f0;background:#fff;color:#0f172a;border-radius:12px;padding:10px 12px;font-weight:700;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.prpo-btn:disabled{opacity:.55;cursor:not-allowed}.prpo-btn--ghost{background:#fff}.prpo-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 10px 26px #0000000f;overflow:hidden;min-height:0;position:relative}.prpo-table-wrap{overflow:auto;max-height:calc(100vh - 210px)}.prpo-table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-13)}.prpo-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:10px;text-align:left;color:#475569;font-weight:900}.prpo-table tbody td{border-bottom:1px solid #f1f5f9;padding:10px;vertical-align:middle;color:#0f172a}.prpo-row{cursor:pointer}.prpo-row:hover{background:#f8fafc}.prpo-mono{font-family:var(--pps-font-mono)}.prpo-clip{max-width:520px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prpo-empty{padding:18px!important;text-align:center;color:#64748b!important}.prpo-loading{position:absolute;inset:0;background:#ffffffb3;display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:center;font-weight:800;color:#0f172a}.prpo-spinner{width:26px;height:26px;border-radius:999px;border:3px solid #e2e8f0;border-top-color:#0284c7;animation:prpo-spin .9s linear infinite}@keyframes prpo-spin{to{transform:rotate(360deg)}}.mp-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--primary-soft: #e0f2fe;--primary-soft2: #bae6fd;--green-soft: #ecfdf5;--red-soft: #fee2e2;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--radius-sm: 12px;--tap: 48px;padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom));padding-top:calc(12px + env(safe-area-inset-top));background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;width:100%;min-height:100dvh;height:100dvh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior-y:contain}.mp-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px}.mp-card-title{font-size:var(--fs-14);font-weight:1000;display:flex;align-items:center;gap:8px;margin-bottom:10px}.mp-muted{color:var(--muted)}.mp-header{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.mp-title{font-size:var(--fs-18);font-weight:1000;letter-spacing:.2px}.mp-sub{margin-top:2px;font-size:var(--fs-12);color:var(--muted)}.mp-who{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.mp-pill{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:900;font-size:var(--fs-13);line-height:1.1}.mp-pill.on{background:var(--green-soft);border-color:#86efac;color:#14532d}.mp-pill.off{background:#fff;border-color:var(--border);color:#334155}.mp-hero{padding:14px}.mp-hero-top{display:flex;gap:12px;justify-content:space-between;flex-wrap:wrap}.mp-machine-left{flex:1;min-width:0}.mp-machine-label{font-size:var(--fs-12);font-weight:900;color:var(--muted);display:inline-flex;align-items:center;gap:6px}.mp-machine-uid{margin-top:6px;font-size:var(--fs-22);font-weight:1000;letter-spacing:1px}.mp-hero-name{margin-top:8px;font-size:var(--fs-16);font-weight:1000;color:#0f172a;line-height:1.25;word-break:break-word}.mp-hero-sub{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.mp-chip{display:inline-flex;align-items:center;gap:6px;min-height:28px;padding:6px 10px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;color:#0f172a;font-size:var(--fs-12);font-weight:800;max-width:100%}.mp-chip b{font-weight:1000}.mp-hero-sub2{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:var(--fs-12)}.mp-dot{color:#cbd5e1}.mp-ready{display:inline-flex;align-items:center;gap:6px;min-height:28px;padding:6px 10px;border-radius:999px;border:1px solid #e2e8f0;font-weight:1000}.mp-ready.on{background:var(--green-soft);border-color:#86efac;color:#14532d}.mp-ready.off{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.mp-hero-right{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:10px;align-content:start}.mp-status{grid-column:1 / -1;min-height:36px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-weight:1000;font-size:var(--fs-12);border:1px solid var(--border)}.mp-status.on{background:var(--green-soft);border-color:#86efac;color:#14532d}.mp-status.off{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.mp-hero-mini{background:#fff;border:1px solid var(--border);border-radius:14px;padding:10px 12px;box-shadow:var(--shadow-sm);min-height:56px}.mp-mini-k{color:var(--muted);font-size:var(--fs-12);font-weight:900}.mp-mini-v{margin-top:2px;font-size:var(--fs-16);font-weight:1000;color:#0f172a}.mp-grid-login{display:grid;gap:12px}.mp-field label{display:block;font-size:var(--fs-13);font-weight:1000;margin-bottom:6px}.mp-input-wrap{position:relative}.mp-input-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.mp-input-wrap input{width:100%;height:var(--tap);border-radius:14px;border:1px solid #94a3b8;background:#e8edf5;padding:0 12px 0 38px;font-size:var(--fs-18);font-weight:700;outline:none;letter-spacing:.5px}.mp-input-wrap input:focus{background:#fff;border-color:var(--primary2);box-shadow:0 0 0 3px #0284c724}.mp-input-wrap input:disabled{opacity:.85}.mp-help{margin-top:6px;font-size:var(--fs-12);color:var(--muted)}.mp-actions{display:grid;gap:10px}.mp-actions .mp-btn{width:100%}.mp-alert{margin-top:10px;padding:10px 12px;border-radius:12px;background:var(--red-soft);border:1px solid #fecaca;color:#7f1d1d;font-weight:900;font-size:var(--fs-13)}.mp-btn{min-height:var(--tap);border-radius:14px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;font-weight:1000;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 14px;-webkit-user-select:none;user-select:none}.mp-btn:active{transform:translateY(1px)}.mp-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.mp-btn-primary{border:none;background:linear-gradient(135deg,var(--primary2),var(--primary));color:#fff}.mp-btn-soft{border:1px solid var(--primary-soft2);background:var(--primary-soft);color:#075985}.mp-btn-ghost{background:#fff}.mp-btn:focus-visible,.mp-tile:focus-visible,.mp-input-wrap input:focus-visible{outline:none;box-shadow:0 0 0 3px #0284c729}.mp-welcome .mp-welcome-sub{color:var(--muted);font-size:var(--fs-13);font-weight:700}.mp-welcome-meta{margin-top:10px;display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.mp-badge{height:28px;padding:0 10px;border-radius:999px;background:var(--primary-soft);border:1px solid var(--primary-soft2);color:#075985;font-weight:1000;font-size:var(--fs-12)}.mp-menu{margin-top:2px}.mp-menu-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin:10px 0}.mp-menu-title{font-size:var(--fs-14);font-weight:1000}.mp-menu-sub{font-size:var(--fs-12);color:var(--muted)}.mp-menu-grid{display:grid;grid-template-columns:1fr;gap:10px}.mp-tile{text-decoration:none;color:inherit;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm);transition:border-color .12s,box-shadow .12s}.mp-tile:active{transform:translateY(1px)}.mp-tile.disabled{opacity:.72;filter:grayscale(.15)}.mp-tile.soon{border-style:dashed}.mp-tile-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.mp-ico{width:46px;height:46px;border-radius:16px;background:var(--primary-soft);border:1px solid var(--primary-soft2);display:flex;align-items:center;justify-content:center;color:#075985;font-size:var(--fs-20)}.mp-badges{display:inline-flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.mp-pill2{min-height:26px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:var(--fs-12);font-weight:1000;color:#334155;display:inline-flex;align-items:center;gap:6px}.mp-pill2.lock{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.mp-pill2.soon{background:#f1f5f9;border-color:#cbd5e1;color:#334155}.mp-tile-title{font-size:var(--fs-16);font-weight:1000;color:#0f172a;line-height:1.15}.mp-tile-desc{margin-top:6px;font-size:var(--fs-13);color:var(--muted);font-weight:700;line-height:1.25}.mp-footer{margin-top:8px;padding:6px 2px;font-size:var(--fs-12);color:var(--muted)}@media(min-width:640px){.mp-page{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom));padding-top:calc(16px + env(safe-area-inset-top))}.mp-header{flex-direction:row;align-items:flex-end;justify-content:space-between}.mp-menu-grid,.mp-actions{grid-template-columns:1fr 1fr}.mp-hero-right{width:220px;grid-template-columns:1fr}.mp-status{grid-column:auto}}@media(min-width:1024px){.mp-page{padding:16px 24px;padding-bottom:calc(16px + env(safe-area-inset-bottom));padding-top:calc(16px + env(safe-area-inset-top))}.mp-menu-grid{grid-template-columns:repeat(3,1fr)}}@media(hover:hover)and (pointer:fine){.mp-btn:hover{background:#f1f5f9}.mp-btn-primary:hover{background:linear-gradient(135deg,var(--primary),#075985)}.mp-btn-soft:hover{background:var(--primary-soft2)}.mp-tile:hover{border-color:#7dd3fc;box-shadow:var(--shadow)}}.mp-input-wrap input{color:#0f172a;caret-color:#0f172a;-webkit-text-fill-color:#0f172a}.mp-input-wrap input::placeholder{color:#94a3b8;opacity:1}.mp-input-wrap input:focus{color:#0f172a;-webkit-text-fill-color:#0f172a}.mp-tile.done{border-color:#86efac!important;background:linear-gradient(180deg,#ecfdf5,#fff)!important}.mp-tile.done{border-color:#86efac;background:#ecfdf5}.mp-tile.done .mp-tile-desc{color:#166534}.mp-pill2.ok{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-weight:900;font-size:var(--fs-12);color:#14532d;background:#dcfce7;border:1px solid #86efac}.mp-tile.done{background:#ecfdf5;border-color:#86efac}.mp-tile.done .mp-tile-title{color:#14532d}.mp-pill2.ok{background:#dcfce7;border:1px solid #86efac;color:#14532d}.mp-tile.not-required{opacity:.72;cursor:not-allowed}.mp-tile.daily-off{background:#fffbeb;border-color:#facc15}.mp-tile.daily-ok{background:#ecfdf5;border-color:#22c55e}.mp-tile.daily-ng{background:#fef2f2;border-color:#ef4444}.mp-pill2.daily-pill-off{background:#fef3c7;color:#92400e;border-color:#facc15}.mp-pill2.daily-pill-ok{background:#dcfce7;color:#166534;border-color:#22c55e}.mp-pill2.daily-pill-ng{background:#fee2e2;color:#991b1b;border-color:#ef4444}.mpr-textarea{width:100%;border:1px solid #94a3b8;background:#e8edf5;border-radius:14px;padding:12px;font-size:var(--fs-16);font-weight:700;outline:none;color:#0f172a;-webkit-text-fill-color:#0f172a}.mpr-form{display:grid;gap:10px}.mpr-label{font-weight:1000;font-size:var(--fs-13);color:#0f172a}.mpr-textarea{width:100%;border:1px solid #94a3b8;background:#e8edf5;border-radius:14px;padding:12px;font-size:var(--fs-16);font-weight:700;outline:none;color:#0f172a;-webkit-text-fill-color:#0f172a;resize:vertical;min-height:120px}.mpr-textarea:focus{background:#fff;border-color:var(--primary2);box-shadow:0 0 0 3px #0284c724}.mpr-upload-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.mpr-upload-btn{position:relative;overflow:hidden}.mpr-file{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer}.mpr-clear{background:#fff}.mpr-preview{border:1px solid #e5e7eb;background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}.mpr-preview img{width:100%;display:block;max-height:320px;object-fit:cover}.mpr-preview-meta{padding:10px 12px}.mpr-fn{font-weight:1000;font-size:var(--fs-13);color:#0f172a;word-break:break-word}.mpr-hint{font-size:var(--fs-12);color:var(--muted);font-weight:700}.mpr-actions{display:grid;gap:10px}.mpr-section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.mpr-loaded-at{margin-top:6px;font-size:var(--fs-12);font-weight:700;color:#64748b}.mpr-empty{margin-top:10px;border:1px dashed #cbd5e1;border-radius:14px;background:#f8fafc;padding:14px;font-size:var(--fs-13);font-weight:700;color:#475569}.mpr-wr-list{display:grid;gap:12px;margin-top:12px}.mpr-wr-item{border:1px solid #e2e8f0;background:#fff;border-radius:16px;padding:12px;display:grid;gap:10px}.mpr-wr-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}.mpr-wr-code{display:inline-flex;align-items:center;gap:8px;font-weight:1000;color:#0f172a}.mpr-wr-status{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:900;border:1px solid transparent}.mpr-wr-status.ok{color:#166534;background:#dcfce7;border-color:#86efac}.mpr-wr-status.wait{color:#92400e;background:#fef3c7;border-color:#fcd34d}.mpr-wr-status.progress{color:#0c4a6e;background:#e0f2fe;border-color:#7dd3fc}.mpr-wr-status.neutral{color:#334155;background:#f1f5f9;border-color:#cbd5e1}.mpr-wr-desc{font-size:var(--fs-15);line-height:1.5;font-weight:800;color:#0f172a;word-break:break-word}.mpr-wr-meta,.mpr-wr-submeta{display:flex;flex-wrap:wrap;gap:8px 14px;font-size:var(--fs-12);color:#475569;font-weight:700}.mpr-wr-actions{display:flex;justify-content:flex-end}.spin{animation:mprSpin .9s linear infinite}@keyframes mprSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(min-width:640px){.mpr-actions{grid-template-columns:1fr 1fr}}.pmh-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--primary-soft: #e0f2fe;--primary-soft2: #bae6fd;--danger: #ef4444;--danger-soft: #fee2e2;--warn: #f97316;--warn-soft: #ffedd5;--info: #3b82f6;--info-soft: #dbeafe;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--tap: 48px;width:100%;min-height:100dvh;background:var(--bg);color:var(--text);padding:12px;padding-top:calc(12px + env(safe-area-inset-top));padding-bottom:calc(12px + env(safe-area-inset-bottom));height:100dvh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y}.pmh-muted{color:var(--muted)}.pmh-topbar{display:flex;gap:10px;align-items:center;margin-bottom:12px}.pmh-titlewrap{min-width:0}.pmh-title{font-size:var(--fs-16);font-weight:1000;line-height:1.1}.pmh-sub{margin-top:4px;font-size:var(--fs-12);color:var(--muted);word-break:break-word}.pmh-back{width:var(--tap);height:var(--tap);min-width:var(--tap);border-radius:14px;border:1px solid var(--border);background:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-18);color:#0f172a;box-shadow:0 6px 14px #0f172a14;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease}.pmh-back svg{stroke-width:2.5}.pmh-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px}.pmh-summary{display:grid;gap:10px}.pmh-sum-row{display:flex;justify-content:space-between;gap:10px;align-items:baseline}.pmh-sum-k{font-size:var(--fs-12);font-weight:1000;color:var(--muted)}.pmh-sum-v{font-size:var(--fs-14);font-weight:900;text-align:right;word-break:break-word}.pmh-badge{display:inline-flex;align-items:center;justify-content:center;height:26px;padding:0 10px;border-radius:999px;background:var(--primary-soft);border:1px solid var(--primary-soft2);color:#075985;font-weight:1000}.pmh-filters{display:grid;gap:10px}.pmh-search{position:relative}.pmh-search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.pmh-search input{width:100%;height:var(--tap);border-radius:14px;border:1px solid #94a3b8;background:#e8edf5;padding:0 12px 0 38px;font-size:var(--fs-16);font-weight:700;outline:none;color:#0f172a;-webkit-text-fill-color:#0f172a}.pmh-search input::placeholder{color:#64748b}.pmh-search input:focus{background:#fff;border-color:var(--primary2);box-shadow:0 0 0 3px #0284c724}.pmh-chips{display:flex;gap:8px;flex-wrap:wrap}.pmh-chip{min-height:36px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:1000;font-size:var(--fs-12);display:inline-flex;align-items:center;gap:6px;cursor:pointer}.pmh-chip.active{background:var(--primary-soft);border-color:var(--primary-soft2);color:#075985}.pmh-list{display:grid;gap:12px}.pmh-empty{padding:14px;text-align:center;color:var(--muted);font-weight:800}.pmh-item-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}.pmh-type{display:inline-flex;align-items:center;gap:6px;min-height:26px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:1000;font-size:var(--fs-12)}.pmh-type.danger{background:var(--danger-soft);border-color:#fecaca;color:#7f1d1d}.pmh-type.warn{background:var(--warn-soft);border-color:#fed7aa;color:#9a3412}.pmh-type.info{background:var(--info-soft);border-color:#bfdbfe;color:#1d4ed8}.pmh-dt{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:var(--fs-12);font-weight:900}.pmh-wo{font-size:var(--fs-16);font-weight:1000;letter-spacing:.3px}.pmh-machine{margin-top:2px;font-size:var(--fs-13);color:#0f172a;font-weight:800;line-height:1.25}.pmh-prob{margin-top:10px;padding-top:10px;border-top:1px dashed #e2e8f0}.pmh-prob-k{font-size:var(--fs-12);font-weight:1000;color:var(--muted)}.pmh-prob-v{margin-top:4px;font-size:var(--fs-13);font-weight:800;color:#0f172a;line-height:1.3;word-break:break-word}.pmh-status{margin-top:10px;font-size:var(--fs-12);color:var(--muted);font-weight:800}.pmh-footer{margin-top:8px;padding:6px 2px;font-size:var(--fs-12);color:var(--muted)}@media(min-width:640px){.pmh-page{padding:16px;padding-top:calc(16px + env(safe-area-inset-top));padding-bottom:calc(16px + env(safe-area-inset-bottom))}}.pmh-back{width:44px;height:44px;min-width:44px;border-radius:14px;border:1px solid var(--border);background:#fff;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:0;color:#0f172a;box-shadow:0 6px 14px #0f172a14;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease}.pmh-back svg{width:22px;height:22px;display:block;stroke-width:2.6}@media(hover:hover)and (pointer:fine){.pmh-back:hover{background:#f1f5f9;box-shadow:0 10px 20px #0f172a1f}}.pmh-back:active{transform:translateY(1px) scale(.98);box-shadow:0 4px 10px #0f172a1f}.pmh-back:focus-visible{outline:none;box-shadow:0 0 0 3px #0284c759}.pmp-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--primary-soft: #e0f2fe;--primary-soft2: #bae6fd;--danger: #ef4444;--danger-soft: #fee2e2;--warn: #f97316;--warn-soft: #ffedd5;--info: #3b82f6;--info-soft: #dbeafe;--success-soft: #dcfce7;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--tap: 48px;width:100%;height:100dvh;min-height:100dvh;padding:12px;padding-top:calc(12px + env(safe-area-inset-top));padding-bottom:calc(12px + env(safe-area-inset-bottom));overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y;background:var(--bg);color:var(--text)}.pmp-muted{color:var(--muted)}.pmp-topbar{display:flex;gap:10px;align-items:center;margin-bottom:12px}.pmp-titlewrap{min-width:0}.pmp-title{font-size:var(--fs-16);font-weight:1000;line-height:1.1}.pmp-sub{margin-top:4px;font-size:var(--fs-12);color:var(--muted);word-break:break-word}.pmp-back{width:46px;height:46px;min-width:46px;padding:0;border-radius:14px;border:1.5px solid #cbd5e1;background:linear-gradient(180deg,#fff,#f8fafc);color:#0f172a;display:inline-flex;align-items:center;justify-content:center;line-height:0;box-shadow:0 4px 10px #0f172a1f,inset 0 1px #ffffffe6;cursor:pointer;-webkit-tap-highlight-color:transparent}.pmp-back svg{width:22px;height:22px;display:block;stroke-width:2.6}.pmp-back:active{transform:translateY(1px) scale(.97)}.pmp-back:focus-visible{outline:none;box-shadow:0 0 0 3px #0284c759,0 4px 12px #0f172a1f}.pmp-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px}.pmp-summary{display:grid;gap:10px}.pmp-sum-row{display:flex;justify-content:space-between;gap:10px;align-items:baseline}.pmp-sum-k,.pmp-k{font-size:var(--fs-12);font-weight:1000;color:var(--muted)}.pmp-sum-v{font-size:var(--fs-14);font-weight:900;text-align:right;word-break:break-word}.pmp-sum-grid,.pmp-sum-grid-single{margin-top:4px;display:grid;grid-template-columns:1fr 1fr;gap:10px}.pmp-mini{border:1px solid var(--border);border-radius:14px;background:#fff;padding:10px 12px;box-shadow:var(--shadow-sm)}.pmp-mini.warn{background:var(--warn-soft);border-color:#fed7aa}.pmp-mini.info{background:var(--info-soft);border-color:#bfdbfe}.pmp-mini.success{background:var(--success-soft);border-color:#bbf7d0}.pmp-mini.danger{background:var(--danger-soft);border-color:#fecaca}.pmp-mini.muted{background:#f1f5f9;border-color:#cbd5e1}.pmp-mini-k{font-size:var(--fs-12);font-weight:1000;color:#334155}.pmp-mini-v{margin-top:2px;font-size:var(--fs-18);font-weight:1000;color:#0f172a}.pmp-filters{display:grid;gap:10px}.pmp-search{position:relative}.pmp-search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.pmp-search input{width:100%;height:var(--tap);border-radius:14px;border:1px solid #94a3b8;background:#e8edf5;padding:0 12px 0 38px;font-size:var(--fs-16);font-weight:700;outline:none;color:#0f172a;-webkit-text-fill-color:#0f172a}.pmp-search input::placeholder{color:#64748b}.pmp-search input:focus{background:#fff;border-color:var(--primary2);box-shadow:0 0 0 3px #0284c724}.pmp-chips{display:flex;gap:8px;flex-wrap:wrap}.pmp-chip{min-height:36px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:1000;font-size:var(--fs-12);display:inline-flex;align-items:center;gap:6px}.pmp-chip.active{background:var(--primary-soft);border-color:var(--primary-soft2);color:#075985}.pmp-chip-n{margin-left:2px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);background:#fff;color:#334155;font-weight:1000}.pmp-list{display:grid;gap:12px}.pmp-empty{padding:14px;text-align:center;color:var(--muted);font-weight:800}.pmp-item-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}.pmp-badge{display:inline-flex;align-items:center;gap:6px;min-height:26px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:1000;font-size:var(--fs-12)}.pmp-badge.warn{background:var(--warn-soft);border-color:#fed7aa;color:#9a3412}.pmp-badge.info{background:var(--info-soft);border-color:#bfdbfe;color:#1d4ed8}.pmp-badge.success{background:var(--success-soft);border-color:#bbf7d0;color:#166534}.pmp-badge.danger{background:var(--danger-soft);border-color:#fecaca;color:#7f1d1d}.pmp-badge.muted{background:#f1f5f9;border-color:#cbd5e1;color:#475569}.pmp-dt{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:var(--fs-12);font-weight:900}.pmp-code{font-size:var(--fs-16);font-weight:1000;letter-spacing:.3px}.pmp-name{margin-top:2px;font-size:var(--fs-13);color:#0f172a;font-weight:800;line-height:1.25;word-break:break-word}.pmp-grid{margin-top:10px;padding-top:10px;border-top:1px dashed #e2e8f0;display:grid;gap:10px}.pmp-kv{display:flex;justify-content:space-between;gap:10px}.pmp-v{font-size:var(--fs-12);font-weight:900;text-align:right;word-break:break-word}.pmp-v svg{vertical-align:-2px;margin-right:4px}.pmp-worktime{margin-top:10px;padding-top:10px;border-top:1px dashed #e2e8f0}.pmp-worktime-text{margin-top:4px;font-size:var(--fs-12);font-weight:800;color:#334155;line-height:1.4;word-break:break-word;white-space:pre-wrap}.pmp-upload{margin-top:12px;padding-top:12px;border-top:1px dashed #e2e8f0;display:grid;gap:10px}.pmp-upload-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:1000;color:#0f172a}.pmp-upload-note{width:100%;min-height:72px;resize:vertical;border-radius:14px;border:1px solid #cbd5e1;background:#f8fafc;padding:10px 12px;font-size:var(--fs-14);font-weight:700;color:#0f172a;-webkit-text-fill-color:#0f172a;outline:none}.pmp-upload-note:focus{background:#fff;border-color:var(--primary2);box-shadow:0 0 0 3px #0284c724}.pmp-upload-row{display:flex;flex-wrap:wrap;gap:8px}.pmp-upload-btn,.pmp-upload-submit{min-height:42px;border-radius:14px;border:1px solid #cbd5e1;padding:8px 12px;font-weight:1000;font-size:var(--fs-13);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;-webkit-tap-highlight-color:transparent}.pmp-upload-btn{background:#f8fafc;color:#0f172a}.pmp-upload-submit{background:var(--primary);border-color:var(--primary);color:#fff}.pmp-upload-submit:disabled,.pmp-upload-btn:disabled{opacity:.55;cursor:not-allowed}.pmp-upload-preview{border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;background:#fff}.pmp-upload-preview img{width:100%;max-height:260px;object-fit:cover;display:block}.pmp-upload-meta{padding:8px 10px;font-size:var(--fs-12);color:#64748b;font-weight:800;word-break:break-word}.pmp-upload-hint{font-size:var(--fs-12);color:#64748b;font-weight:800}.pmp-footer{margin-top:8px;padding:6px 2px;font-size:var(--fs-12);color:var(--muted)}@media(min-width:640px){.pmp-page{padding:16px;padding-top:calc(16px + env(safe-area-inset-top));padding-bottom:calc(16px + env(safe-area-inset-bottom))}.pmp-sum-grid{grid-template-columns:repeat(4,1fr)}.pmp-sum-grid-single{grid-template-columns:1fr 1fr}.pmp-grid{grid-template-columns:1fr 1fr 1fr}}@media(hover:hover)and (pointer:fine){.pmp-back:hover,.pmp-upload-btn:hover{background:#f1f5f9}.pmp-upload-submit:hover{background:#075985;border-color:#075985}}.pmp-images{margin-top:12px;padding-top:12px;border-top:1px dashed #e2e8f0;display:grid;gap:10px}.pmp-images-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:1000;color:#0f172a}.pmp-images-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.pmp-image-card{display:block;overflow:hidden;border:1px solid #e2e8f0;border-radius:14px;background:#fff;color:inherit;text-decoration:none}.pmp-image-card img{width:100%;height:120px;display:block;object-fit:cover;background:#f1f5f9}.pmp-image-meta{padding:8px;font-size:var(--fs-11);font-weight:800;color:#64748b;line-height:1.35;word-break:break-word}@media(min-width:640px){.pmp-images-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.pmp-image-card img{height:140px}}.pmp-image-loading{width:100%;height:120px;display:grid;place-items:center;background:#f1f5f9;color:#64748b;font-size:var(--fs-12);font-weight:900}.ppj-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--primary-soft: #e0f2fe;--primary-soft2: #bae6fd;--danger: #ef4444;--danger-soft: #fee2e2;--warn: #f97316;--warn-soft: #ffedd5;--info: #3b82f6;--info-soft: #dbeafe;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--tap: 48px;width:100%;min-height:100dvh;background:var(--bg);color:var(--text);padding:12px;padding-top:calc(12px + env(safe-area-inset-top));padding-bottom:calc(12px + env(safe-area-inset-bottom));height:100dvh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y}.ppj-muted{color:var(--muted)}.ppj-topbar{display:flex;gap:10px;align-items:center;margin-bottom:12px}.ppj-titlewrap{min-width:0}.ppj-title{font-size:var(--fs-16);font-weight:1000;line-height:1.1}.ppj-sub{margin-top:4px;font-size:var(--fs-12);color:var(--muted);word-break:break-word}.ppj-back{width:var(--tap);height:var(--tap);min-width:var(--tap);border-radius:14px;border:1px solid var(--border);background:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-18);color:#0f172a;box-shadow:0 6px 14px #0f172a14;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease}.ppj-back svg{stroke-width:2.5}.ppj-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px}.ppj-summary{display:grid;gap:10px}.ppj-sum-row{display:flex;justify-content:space-between;gap:10px;align-items:baseline}.ppj-sum-k{font-size:var(--fs-12);font-weight:1000;color:var(--muted)}.ppj-sum-v{font-size:var(--fs-14);font-weight:900;text-align:right;word-break:break-word}.ppj-badge{display:inline-flex;align-items:center;justify-content:center;height:26px;padding:0 10px;border-radius:999px;background:var(--primary-soft);border:1px solid var(--primary-soft2);color:#075985;font-weight:1000}.ppj-filters{display:grid;gap:10px}.ppj-search{position:relative}.ppj-search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.ppj-search input{width:100%;height:var(--tap);border-radius:14px;border:1px solid #94a3b8;background:#e8edf5;padding:0 12px 0 38px;font-size:var(--fs-16);font-weight:700;outline:none;color:#0f172a;-webkit-text-fill-color:#0f172a}.ppj-search input::placeholder{color:#64748b}.ppj-search input:focus{background:#fff;border-color:var(--primary2);box-shadow:0 0 0 3px #0284c724}.ppj-chips{display:flex;gap:8px;flex-wrap:wrap}.ppj-chip{min-height:36px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:1000;font-size:var(--fs-12);display:inline-flex;align-items:center;gap:6px;cursor:pointer}.ppj-chip.active{background:var(--primary-soft);border-color:var(--primary-soft2);color:#075985}.ppj-list{display:grid;gap:12px}.ppj-empty{padding:14px;text-align:center;color:var(--muted);font-weight:800}.ppj-item-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}.ppj-type{display:inline-flex;align-items:center;gap:6px;min-height:26px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:1000;font-size:var(--fs-12)}.ppj-type.danger{background:var(--danger-soft);border-color:#fecaca;color:#7f1d1d}.ppj-type.warn{background:var(--warn-soft);border-color:#fed7aa;color:#9a3412}.ppj-type.info{background:var(--info-soft);border-color:#bfdbfe;color:#1d4ed8}.ppj-dt{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:var(--fs-12);font-weight:900}.ppj-wo{font-size:var(--fs-16);font-weight:1000;letter-spacing:.3px}.ppj-machine{margin-top:2px;font-size:var(--fs-13);color:#0f172a;font-weight:800;line-height:1.25}.ppj-prob{margin-top:10px;padding-top:10px;border-top:1px dashed #e2e8f0}.ppj-prob-k{font-size:var(--fs-12);font-weight:1000;color:var(--muted)}.ppj-prob-v{margin-top:4px;font-size:var(--fs-13);font-weight:800;color:#0f172a;line-height:1.3;word-break:break-word}.ppj-status{margin-top:10px;font-size:var(--fs-12);color:var(--muted);font-weight:800}.ppj-footer{margin-top:8px;padding:6px 2px;font-size:var(--fs-12);color:var(--muted)}@media(min-width:640px){.ppj-page{padding:16px;padding-top:calc(16px + env(safe-area-inset-top));padding-bottom:calc(16px + env(safe-area-inset-bottom))}}.ppj-back{width:44px;height:44px;min-width:44px;border-radius:14px;border:1px solid var(--border);background:#fff;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:0;color:#0f172a;box-shadow:0 6px 14px #0f172a14;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease}.ppj-back svg{width:22px;height:22px;display:block;stroke-width:2.6}@media(hover:hover)and (pointer:fine){.ppj-back:hover{background:#f1f5f9;box-shadow:0 10px 20px #0f172a1f}}.ppj-back:active{transform:translateY(1px) scale(.98);box-shadow:0 4px 10px #0f172a1f}.ppj-back:focus-visible{outline:none;box-shadow:0 0 0 3px #0284c759}.pdc-page{--bg: #f8fafc;--card: #ffffff;--border: #d1d5db;--text: #0b1220;--muted: #475569;--primary: #0284c7;--primary-2: #0369a1;--primary-soft: #e0f2fe;--ok: #16a34a;--ok-soft: #dcfce7;--ng: #ef4444;--ng-soft: #fee2e2;--na: #64748b;--na-soft: #f1f5f9;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--tap: 48px;width:100%;min-height:100dvh;background:var(--bg);color:var(--text);padding:12px;padding-top:calc(12px + env(safe-area-inset-top));padding-bottom:calc(16px + env(safe-area-inset-bottom));overflow-x:hidden}.pdc-muted{color:var(--muted);font-weight:800}.pdc-topbar{display:flex;gap:10px;align-items:center;margin-bottom:12px}.pdc-back{width:46px;height:46px;min-width:46px;border-radius:14px;border:1.5px solid #94a3b8;background:linear-gradient(180deg,#fff,#f8fafc);display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:0;color:var(--text);box-shadow:0 4px 10px #0f172a1f,inset 0 1px #ffffffe6;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease}.pdc-back svg{width:22px;height:22px;display:block;stroke-width:2.6}.pdc-back:active{transform:translateY(1px) scale(.97);box-shadow:0 3px 8px #0f172a2e,inset 0 2px 4px #0f172a26}.pdc-titlewrap{min-width:0}.pdc-title{font-size:var(--fs-17);font-weight:1000;line-height:1.1}.pdc-sub{margin-top:4px;font-size:var(--fs-13);color:var(--muted);word-break:break-word;font-weight:800}.pdc-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px}.pdc-alert{padding:10px 12px;border-radius:12px;background:var(--ng-soft);border:1px solid #fecaca;color:#7f1d1d;font-weight:1000}.pdc-submit-alert{margin-top:12px}.pdc-machine .pdc-m-row,.pdc-card .pdc-m-row{display:flex;justify-content:space-between;gap:10px;align-items:baseline;padding:6px 0;border-bottom:1px dashed #e2e8f0}.pdc-machine .pdc-m-row:last-child,.pdc-card .pdc-m-row:last-child{border-bottom:none}.pdc-m-k{font-size:var(--fs-13);font-weight:1000;color:var(--muted)}.pdc-m-v{font-size:var(--fs-14);font-weight:1000;text-align:right;color:var(--text)}.pdc-group-title{font-size:var(--fs-15);font-weight:1000;margin-bottom:10px}.pdc-list{display:grid;gap:12px}.pdc-item{border:1px solid #e2e8f0;border-radius:14px;padding:12px;background:#fff}.pdc-item-top{display:flex;gap:10px;justify-content:space-between;align-items:flex-start;flex-wrap:wrap}.pdc-item-title{font-weight:1000;font-size:var(--fs-15);line-height:1.25;width:100%}.pdc-item-desc{margin-top:8px;font-size:var(--fs-15);font-weight:800;color:#334155;line-height:1.4}.pdc-item-std{margin-top:8px;font-size:var(--fs-15);font-weight:800;color:var(--text);line-height:1.4;padding-top:8px;border-top:1px dashed #e2e8f0}.pdc-refimg-wrap{margin-top:10px;margin-bottom:12px;width:100%;border-radius:16px;border:1px solid #e5e7eb;background:linear-gradient(45deg,#f1f5f9 25%,transparent 25%),linear-gradient(-45deg,#f1f5f9 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f1f5f9 75%),linear-gradient(-45deg,transparent 75%,#f1f5f9 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px;height:220px;display:flex;align-items:center;justify-content:center;overflow:hidden}.pdc-refimg{width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;object-position:center;display:block}.pdc-actions{margin-top:10px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.pdc-btn{min-height:44px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;font-weight:1000;font-size:var(--fs-13);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;-webkit-tap-highlight-color:transparent}.pdc-btn.active.ok{background:var(--ok-soft);border-color:#86efac;color:#0f3d22}.pdc-btn.active.ng{background:var(--ng-soft);border-color:#fecaca;color:#6b1010}.pdc-btn.active.na{background:var(--na-soft);border-color:#cbd5e1;color:#0f172a}.pdc-ngbox{margin-top:10px;padding-top:10px;border-top:1px dashed #e2e8f0}.pdc-note-label{display:block;font-size:var(--fs-12);font-weight:1000;color:#334155;margin-bottom:6px}.pdc-note{width:100%;border-radius:12px;border:1px solid #94a3b8;background:#e8edf5;padding:10px 12px;font-size:var(--fs-14);font-weight:700;outline:none;color:var(--text);-webkit-text-fill-color:var(--text);resize:vertical}.pdc-note:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px #0284c724}.pdc-btn-wr{margin-top:10px;width:100%;min-height:52px;border-radius:14px;border:none;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;font-weight:1000;font-size:var(--fs-15);letter-spacing:.2px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px}.pdc-bottom{margin-top:12px;padding-bottom:calc(8px + env(safe-area-inset-bottom))}.pdc-submit{width:100%;min-height:54px;border-radius:16px;border:none;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:1000;font-size:var(--fs-15);letter-spacing:.2px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px}.pdc-bottom-hint{margin-top:8px;font-size:var(--fs-12);line-height:1.4;text-align:center;color:var(--muted);font-weight:800}.pdc-back:focus-visible,.pdc-btn:focus-visible,.pdc-btn-wr:focus-visible,.pdc-submit:focus-visible,.pdc-note:focus-visible{outline:none;box-shadow:0 0 0 3px #0284c738}@media(min-width:640px){.pdc-page{max-width:860px;margin:0 auto}.pdc-refimg-wrap{height:260px}.pdc-actions{max-width:420px}}@media(max-width:420px){.pdc-actions{grid-template-columns:1fr}.pdc-btn{justify-content:space-between;padding:0 12px}.pdc-title{font-size:var(--fs-16)}.pdc-item-title{font-size:var(--fs-14)}}.pdc-bottom{margin-top:12px;padding-bottom:calc(8px + env(safe-area-inset-bottom));display:grid;gap:12px}.pdc-submit{width:100%;min-height:54px;border-radius:16px;border:none;background:linear-gradient(135deg,#78add3,#6aa1ca);color:#fff;font-weight:1000;font-size:var(--fs-15);letter-spacing:.2px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px}.pdc-submit:disabled{opacity:.55;cursor:not-allowed}.pdc-back-portal{width:100%;min-height:54px;border-radius:16px;border:1.5px solid #cbd5e1;background:#f8fafc;color:#0f172a;font-weight:1000;font-size:var(--fs-15);letter-spacing:.2px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px}.pdc-back-portal:disabled{opacity:.55;cursor:not-allowed}.pdc-bottom-hint{margin-top:-2px;font-size:var(--fs-12);line-height:1.4;text-align:center;color:#475569;font-weight:800}.pdc-location{border-width:1.5px}.pdc-location-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.pdc-location-msg{line-height:1.4}.pdc-location-icon{width:28px;height:28px;min-width:28px;color:#0369a1}.pdc-location-pass{border-color:#86efac;background:linear-gradient(180deg,#fff,#f0fdf4)}.pdc-location-warning,.pdc-location-checking{border-color:#facc15;background:linear-gradient(180deg,#fff,#fefce8)}.pdc-location-failed,.pdc-location-not_available,.pdc-location-not_configured{border-color:#fecaca;background:linear-gradient(180deg,#fff,#fef2f2)}.pdc-location-retry{margin-top:12px;width:100%;min-height:48px;border-radius:14px;border:1.5px solid #7dd3fc;background:#f0f9ff;color:#075985;font-weight:1000;font-size:var(--fs-14);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.pdc-location-retry:disabled{opacity:.55;cursor:not-allowed}.pdc-panel{padding:16px 18px;height:100%;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px}.pdc-topbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.pdc-topbar-left{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.pdc-topbar-right{display:flex;align-items:center;gap:8px}.pdc-field{display:flex;flex-direction:column;gap:6px}.pdc-field label{font-size:var(--fs-12);color:#64748b}.pdc-field input,.pdc-field select,.pdc-field textarea{border:1px solid #e2e8f0;border-radius:12px;padding:9px 10px;background:#fff;outline:none;min-width:150px}.pdc-field textarea{resize:vertical}.pdc-seg{display:flex;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#fff}.pdc-seg button{border:0;background:transparent;padding:9px 12px;cursor:pointer;font-size:var(--fs-13);color:#334155}.pdc-seg button.active{background:#0ea5e9;color:#fff}.pdc-search{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;min-width:320px}.pdc-search input{border:0;outline:none;width:320px;background:transparent}.pdc-iconbtn{border:0;background:transparent;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center}.pdc-btn{border:1px solid #e2e8f0;background:#fff;border-radius:12px;padding:10px 12px;cursor:pointer;font-size:var(--fs-13);display:inline-flex;align-items:center;gap:8px}.pdc-btn.primary{background:#0ea5e9;border-color:#0ea5e9;color:#fff}.pdc-btn.ghost{background:#fff}.pdc-btn.danger{background:#fff;border-color:#fecaca;color:#b91c1c}.pdc-btn:disabled,.pdc-btn.disabled{opacity:.55;cursor:not-allowed}.pdc-body{flex:1;display:grid;grid-template-columns:220px 220px 1fr;gap:12px;min-height:0}.pdc-col{background:#fff;border:1px solid #e2e8f0;border-radius:14px;display:flex;flex-direction:column;min-height:0}.pdc-col-header{padding:12px 12px 10px;border-bottom:1px solid #eef2f7;display:flex;align-items:baseline;justify-content:space-between;gap:10px}.pdc-col-title{font-size:var(--fs-14);font-weight:700;display:flex;align-items:center;gap:8px}.pdc-col-title-hint{font-size:var(--fs-12);color:#64748b;font-weight:500;display:inline-flex;align-items:center;gap:6px}.pdc-col-sub{font-size:var(--fs-12);color:#64748b}.pdc-deptlist{padding:10px;overflow:auto;min-height:0;display:flex;flex-direction:column;gap:10px}.pdc-deptitem{border:1px solid #eef2f7;background:#fff;border-radius:14px;padding:10px;text-align:left;cursor:pointer}.pdc-deptitem.active{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91f}.pdc-deptrow{display:flex;justify-content:space-between;align-items:center;gap:10px}.pdc-deptname{font-weight:700;font-size:var(--fs-13);color:#0f172a}.pdc-badge{font-size:var(--fs-12);padding:2px 8px;border-radius:999px;background:#e0f2fe;color:#0369a1}.pdc-bar{height:7px;background:#f1f5f9;border-radius:999px;overflow:hidden;margin-top:8px}.pdc-barfill{height:100%;background:#0ea5e9}.pdc-deptmeta{margin-top:8px;font-size:var(--fs-12);color:#64748b}.pdc-machinelist{padding:10px;overflow:auto;min-height:0;display:flex;flex-direction:column;gap:10px}.pdc-machineitem{border:1px solid #eef2f7;background:#fff;border-radius:14px;padding:10px;text-align:left;cursor:pointer}.pdc-machineitem.active{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91f}.pdc-machineitem.missing{border-left:6px solid #fb923c}.pdc-machineitem.ok{border-left:6px solid #22c55e}.pdc-machinetop{display:flex;align-items:center;justify-content:space-between;gap:10px}.pdc-mcode{font-weight:800;letter-spacing:.2px;font-size:var(--fs-13)}.pdc-pill{font-size:var(--fs-11);padding:3px 8px;border-radius:999px;border:1px solid #e2e8f0}.pdc-pill.ok{background:#dcfce7;border-color:#bbf7d0;color:#166534}.pdc-pill.missing{background:#ffedd5;border-color:#fed7aa;color:#9a3412}.pdc-mname{margin-top:6px;font-size:var(--fs-13);color:#334155}.pdc-mmeta{margin-top:6px;display:flex;gap:10px;flex-wrap:wrap;font-size:var(--fs-12);color:#64748b}.pdc-loadmore{padding:6px 0 2px;display:flex;justify-content:center}.pdc-empty{padding:18px 10px;color:#64748b;font-size:var(--fs-13);text-align:center}.pdc-right-actions{padding:10px 10px 0;display:flex;gap:8px}.pdc-masterlist{padding:10px;overflow:auto;min-height:0;display:flex;flex-direction:column;gap:10px}.pdc-mastercard{border:1px solid #eef2f7;border-radius:14px;padding:10px;background:#fff}.pdc-mastercard.inactive{opacity:.72}.pdc-masterhead{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.pdc-mastertitle{font-weight:800;font-size:var(--fs-13)}.pdc-masterbadges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.pdc-tag{font-size:var(--fs-11);padding:2px 8px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;color:#475569}.pdc-tag.ok{background:#dcfce7;border-color:#bbf7d0;color:#166534}.pdc-tag.off{background:#fee2e2;border-color:#fecaca;color:#991b1b}.pdc-tag.subtle{background:#f1f5f9}.pdc-mastermeta{margin-top:8px;font-size:var(--fs-12);color:#64748b;display:flex;gap:10px;flex-wrap:wrap}.pdc-masterdesc{margin-top:8px;font-size:var(--fs-13);color:#334155;white-space:pre-wrap}.pdc-masterimg{margin-top:10px;border:1px solid #eef2f7;border-radius:14px;overflow:hidden;background:#f8fafc}.pdc-masterimg img{width:100%;display:block;max-height:220px;object-fit:cover}.pdc-masteractions{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}.pdc-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;z-index:50;padding:18px}.pdc-modal{width:min(860px,96vw);max-height:min(86vh,900px);background:#fff;border-radius:16px;border:1px solid #e2e8f0;display:flex;flex-direction:column;overflow:hidden}.pdc-modal-header{padding:12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #eef2f7}.pdc-modal-title{font-weight:800}.pdc-modal-body{padding:12px;overflow:auto;min-height:0}.pdc-modal-footer{padding:12px;display:flex;justify-content:flex-end;gap:8px;border-top:1px solid #eef2f7}.pdc-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pdc-field-wide{grid-column:1 / -1}.pdc-row{display:flex;align-items:center;gap:10px}.pdc-inline{display:flex;align-items:center;gap:10px;font-size:var(--fs-13)}.pdc-imgrow{display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap}.pdc-preview{width:240px;height:140px;border:1px solid #eef2f7;border-radius:14px;overflow:hidden;background:#f8fafc}.pdc-preview img{width:100%;height:100%;object-fit:cover;display:block}.pdc-preview.empty{display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:var(--fs-13)}@media(max-width:1200px){.pdc-body{grid-template-columns:320px 1fr}.pdc-right{grid-column:1 / -1}}@media(max-width:820px){.pdc-body{grid-template-columns:1fr}.pdc-search input{width:220px}}.pdc-preview{display:flex;flex-direction:column;gap:8px}.pdc-preview img{width:100%;max-height:220px;object-fit:contain;border-radius:12px;border:1px solid #e5e7eb;background:#fff}.pdc-preview-error{font-size:var(--fs-12);font-weight:700;color:#b91c1c;background:#fee2e2;border:1px solid #fecaca;padding:8px 10px;border-radius:10px}.pdc-panel{color:#0f172a}.pdc-panel input,.pdc-panel select,.pdc-panel textarea{color:#0f172a;-webkit-text-fill-color:#0f172a;caret-color:#0f172a}.pdc-panel .pdc-btn,.pdc-panel .pdc-iconbtn,.pdc-panel .pdc-seg button,.pdc-panel .pdc-deptitem,.pdc-panel .pdc-machineitem{color:#0f172a;-webkit-text-fill-color:currentColor}.pdc-panel .pdc-btn svg,.pdc-panel .pdc-iconbtn svg,.pdc-panel .pdc-seg button svg{color:currentColor}.pdc-panel .pdc-btn.primary{color:#fff;-webkit-text-fill-color:#ffffff}.pdc-panel .pdc-btn.danger{color:#b91c1c}.pdc-panel .pdc-seg button{color:#334155}.pdc-panel .pdc-seg button.active{color:#fff;-webkit-text-fill-color:#ffffff}.pdc-panel .pdc-search input{color:#0f172a;-webkit-text-fill-color:#0f172a}@media(forced-colors:active){.pdc-panel{forced-color-adjust:auto}.pdc-panel .pdc-topbar,.pdc-panel .pdc-col,.pdc-panel .pdc-deptitem,.pdc-panel .pdc-machineitem,.pdc-panel .pdc-mastercard,.pdc-panel .pdc-modal{border:1px solid ButtonText;background:Canvas;color:CanvasText}.pdc-panel .pdc-btn,.pdc-panel .pdc-iconbtn,.pdc-panel .pdc-seg,.pdc-panel .pdc-seg button{border:1px solid ButtonText;background:ButtonFace;color:ButtonText}.pdc-panel input,.pdc-panel select,.pdc-panel textarea,.pdc-panel .pdc-search{border:1px solid ButtonText;background:Field;color:FieldText;-webkit-text-fill-color:FieldText}.pdc-panel .pdc-badge,.pdc-panel .pdc-pill,.pdc-panel .pdc-tag{border:1px solid ButtonText;background:ButtonFace;color:ButtonText}}.pdc-search-hint{margin:8px 0 12px;padding:10px 12px;border-radius:10px;background:#fff7ed;border:1px solid #fdba74;color:#9a3412;font-size:var(--fs-13)}.pdc-topbar-left{display:flex;align-items:end;gap:12px;flex-wrap:wrap}.pdc-search{min-width:320px}.pdcmi-page{--bg: #f8fafc;--card: #ffffff;--card-2: #f9fbfd;--border: #dbe3ea;--border-strong: #c4d0db;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0f766e;--primary-hover: #115e59;--primary-soft: #ccfbf1;--danger: #b91c1c;--danger-soft: #fee2e2;--warn: #b45309;--warn-soft: #ffedd5;--ok: #166534;--ok-soft: #dcfce7;--shadow: 0 10px 30px rgba(15, 23, 42, .06);min-height:100%;padding:16px;background:var(--bg);color:var(--text);display:flex;flex-direction:column;gap:16px;font-family:var(--pps-font-main)}.pdcmi-topbar,.pdcmi-header{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.pdcmi-topbar{padding:14px;display:flex;gap:12px;align-items:flex-end;justify-content:space-between;flex-wrap:wrap}.pdcmi-topbar-left,.pdcmi-topbar-right{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.pdcmi-header{padding:18px 20px}.pdcmi-header h1{margin:0 0 4px;font-size:var(--fs-19);line-height:1.3;font-weight:700;letter-spacing:.01em}.pdcmi-header p{margin:0;color:var(--text-soft);font-size:var(--fs-15);line-height:1.55}.pdcmi-field{min-width:150px;display:flex;flex-direction:column;gap:6px}.pdcmi-field label{font-size:var(--fs-13);font-weight:600;color:var(--text-soft)}.pdcmi-field input,.pdcmi-field select,.pdcmi-search input{width:100%;height:40px;border:1px solid var(--border);background:#fff;color:var(--text);border-radius:10px;padding:0 12px;outline:none;font-size:var(--fs-15)}.pdcmi-field input:focus,.pdcmi-field select:focus,.pdcmi-search input:focus{border-color:#94a3b8}.pdcmi-search{min-width:320px;flex:1 1 360px;display:flex;align-items:center;gap:8px;height:40px;border:1px solid var(--border);background:#fff;border-radius:10px;padding:0 10px}.pdcmi-search svg{color:var(--text-muted);flex:0 0 auto}.pdcmi-search input{border:0;background:transparent;padding:0;height:auto}.pdcmi-iconbtn,.pdcmi-textbtn,.pdcmi-btn{-webkit-appearance:none;appearance:none;border:1px solid var(--border);background:#fff;color:var(--text);border-radius:10px;cursor:pointer;transition:.18s ease;font-weight:600}.pdcmi-iconbtn{width:30px;height:30px;display:inline-grid;place-items:center}.pdcmi-textbtn{background:transparent;border:0;color:var(--danger);padding:0}.pdcmi-btn{height:40px;padding:0 14px;display:inline-flex;align-items:center;gap:8px}.pdcmi-btn:hover:not(:disabled),.pdcmi-iconbtn:hover:not(:disabled){border-color:var(--border-strong);transform:translateY(-1px)}.pdcmi-btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.pdcmi-btn.primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.pdcmi-btn.ghost{background:#fff}.pdcmi-btn:disabled,.pdcmi-iconbtn:disabled,.pdcmi-textbtn:disabled{opacity:.6;cursor:not-allowed;transform:none}.pdcmi-stat{height:40px;min-width:150px;padding:0 12px;border:1px solid var(--border);border-radius:10px;background:var(--warn-soft);display:flex;align-items:center;justify-content:space-between;gap:12px}.pdcmi-stat .label{font-size:var(--fs-14);color:var(--warn);font-weight:700}.pdcmi-stat .value{font-size:var(--fs-16);font-weight:800;color:var(--text)}.pdcmi-list{display:flex;flex-direction:column;gap:14px}.pdcmi-card{background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);overflow:hidden;display:grid;grid-template-columns:minmax(0,1fr) 320px}.pdcmi-card-main{padding:18px;display:flex;flex-direction:column;gap:14px}.pdcmi-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.pdcmi-title-wrap{min-width:0}.pdcmi-title{font-size:var(--fs-16);font-weight:700;line-height:1.4;color:var(--text);word-break:break-word}.pdcmi-subtitle{margin-top:4px;font-size:var(--fs-13);color:var(--text-muted)}.pdcmi-badges{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.pdcmi-tag{height:28px;padding:0 10px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-12);font-weight:700;border:1px solid transparent;white-space:nowrap}.pdcmi-tag.warn{color:var(--warn);background:var(--warn-soft);border-color:#fed7aa}.pdcmi-tag.ok{color:var(--ok);background:var(--ok-soft);border-color:#bbf7d0}.pdcmi-tag.off{color:#64748b;background:#e2e8f0;border-color:#cbd5e1}.pdcmi-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 14px}.pdcmi-meta-grid>div{min-width:0;background:var(--card-2);border:1px solid var(--border);border-radius:12px;padding:10px 12px}.pdcmi-meta-grid span{display:block;margin-bottom:4px;font-size:var(--fs-12);color:var(--text-muted);font-weight:600}.pdcmi-meta-grid strong{display:block;font-size:var(--fs-15);color:var(--text);font-weight:700;word-break:break-word}.pdcmi-desc,.pdcmi-standard{border:1px solid var(--border);border-radius:12px;padding:12px 14px;background:#fff;color:var(--text-soft);line-height:1.55;white-space:pre-wrap;word-break:break-word}.pdcmi-standard{background:#fcfcfd}.pdcmi-upload-panel{border-left:1px solid var(--border);background:linear-gradient(180deg,#fcfffe,#f8fbfb);padding:18px;display:flex;flex-direction:column;gap:12px}.pdcmi-upload-title{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--text)}.pdcmi-preview{width:100%;aspect-ratio:4 / 3;border:1px dashed var(--border-strong);border-radius:14px;background:#fff;overflow:hidden;display:grid;place-items:center}.pdcmi-preview.empty{background:#f8fafc}.pdcmi-preview img{width:100%;height:100%;object-fit:cover;display:block}.pdcmi-preview-placeholder{color:var(--text-muted);font-size:var(--fs-14);text-align:center;padding:12px}.pdcmi-fileline{min-height:24px;display:flex;align-items:center;justify-content:space-between;gap:8px}.pdcmi-fileline .name{font-size:var(--fs-14);color:var(--text-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pdcmi-fileline .muted{font-size:var(--fs-13);color:var(--text-muted)}.pdcmi-actions{display:flex;gap:10px;flex-wrap:wrap}.pdcmi-empty{border:1px dashed var(--border-strong);border-radius:16px;background:#fff;padding:30px 18px;text-align:center;color:var(--text-muted)}.pdcmi-loadmore{padding:4px 0 10px;display:flex;justify-content:center}@media(max-width:1100px){.pdcmi-card{grid-template-columns:1fr}.pdcmi-upload-panel{border-left:0;border-top:1px solid var(--border)}.pdcmi-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.pdcmi-page,.pdcmi-topbar{padding:12px}.pdcmi-search,.pdcmi-field{min-width:100%}.pdcmi-topbar-left,.pdcmi-topbar-right{width:100%}.pdcmi-topbar-right{justify-content:space-between}.pdcmi-card-main,.pdcmi-upload-panel{padding:14px}.pdcmi-card-top{flex-direction:column}.pdcmi-badges{justify-content:flex-start}.pdcmi-meta-grid{grid-template-columns:1fr}.pdcmi-actions{flex-direction:column}.pdcmi-actions .pdcmi-btn{width:100%;justify-content:center}}.dc-page{--dc-bg: #f8fafc;--dc-card: #ffffff;--dc-border: #e2e8f0;--dc-text: #0b1220;--dc-muted: #475569;--dc-primary: #2563eb;--dc-primary-soft: #dbeafe;--dc-ok: #16a34a;--dc-ok-soft: #dcfce7;--dc-ng: #dc2626;--dc-ng-soft: #fee2e2;--dc-pending: #f59e0b;--dc-pending-soft: #fef3c7;min-height:100dvh;padding:14px;background:var(--dc-bg);color:var(--dc-text);font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px;-webkit-text-size-adjust:100%}.dc-page,.dc-page *{box-sizing:border-box}.dc-topbar{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}.dc-title-main{font-size:var(--fs-22);font-weight:800;line-height:1.15;color:var(--dc-text)}.dc-title-sub{margin-top:4px;font-size:var(--fs-13);color:var(--dc-muted);line-height:1.4}.dc-topbar-side{display:flex;align-items:center;gap:8px}.dc-live-hint{min-height:38px;padding:0 12px;border:1px solid var(--dc-border);background:#fff;border-radius:12px;display:inline-flex;align-items:center;font-size:var(--fs-13);font-weight:700;color:var(--dc-muted)}.dc-filter-card{background:var(--dc-card);border:1px solid var(--dc-border);border-radius:16px;padding:12px;box-shadow:0 6px 16px #0f172a0a}.dc-filter-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.dc-filter-head-title{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-14);font-weight:800}.dc-filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.dc-filter{display:flex;flex-direction:column;gap:4px;min-width:120px;font-size:var(--fs-12)}.dc-filter label{font-weight:700;font-size:var(--fs-12);color:var(--dc-muted)}.dc-input,.dc-select{height:44px;padding:0 12px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;font-size:var(--fs-16);color:var(--dc-text);-webkit-text-fill-color:var(--dc-text)}.dc-input:focus,.dc-select:focus,.dc-searchbox:focus-within{outline:none;border-color:var(--dc-primary);box-shadow:0 0 0 3px #2563eb29}.dc-filter-search{min-width:260px;flex:1 1 260px}.dc-searchbox{min-height:44px;display:flex;align-items:center;gap:8px;padding:0 10px;border-radius:12px;border:1px solid #cbd5e1;background:#fff}.dc-input-search{border:none;height:42px;padding:0;width:100%;font-size:var(--fs-16);color:var(--dc-text);-webkit-text-fill-color:var(--dc-text);background:transparent}.dc-input-search:focus{outline:none;box-shadow:none}.dc-btn-icon{width:30px;height:30px;min-width:30px;border:none;background:transparent;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:var(--dc-muted);cursor:pointer}.dc-btn{height:44px;padding:0 14px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;color:var(--dc-text);-webkit-text-fill-color:var(--dc-text);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-14);font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.dc-btn:hover{background:#f1f5f9}.dc-btn:active{transform:translateY(1px) scale(.99)}.dc-btn:disabled{opacity:.6;cursor:not-allowed}.dc-btn-primary{background:linear-gradient(180deg,#fff,#f8fbff);border-color:#93c5fd}.dc-btn-reset{background:#f8fafc}.dc-btn-ghost{border:none;background:transparent}.dc-btn-sm{height:38px;font-size:var(--fs-13);padding:0 12px}.dc-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.dc-kpi{background:var(--dc-card);border:1px solid var(--dc-border);border-radius:16px;padding:14px;text-align:left;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.dc-kpi:hover{background:#f8fbff;transform:translateY(-1px)}.dc-kpi.is-active{border-color:#7dd3fc;box-shadow:0 0 0 4px #0284c71f}.dc-kpi-top{display:flex;align-items:center;gap:8px}.dc-kpi-icon{width:30px;height:30px;border-radius:10px;background:#eff6ff;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center}.dc-kpi-label{font-size:var(--fs-12);color:var(--dc-muted);font-weight:700}.dc-kpi-value{margin-top:10px;font-size:var(--fs-24);font-weight:900;color:var(--dc-text)}.dc-main{flex:1;min-height:0;display:grid;grid-template-columns:280px 1fr;gap:12px}.dc-left,.dc-right{min-height:0}.dc-card{background:var(--dc-card);border:1px solid var(--dc-border);border-radius:16px;height:100%;display:flex;flex-direction:column;overflow:hidden}.dc-card-header{padding:12px 14px;border-bottom:1px solid var(--dc-border);display:flex;justify-content:space-between;align-items:center;gap:10px}.dc-card-title{font-weight:800;display:flex;flex-direction:column;gap:2px}.dc-card-title-sub{margin-top:2px}.dc-muted{color:var(--dc-muted);font-size:var(--fs-12)}.dc-pager{display:flex;gap:8px;align-items:center}.dc-dept-list{flex:1;overflow:auto;padding:8px}.dc-dept-row{width:100%;border:1px solid transparent;border-radius:12px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;background:#fff;color:var(--dc-text);-webkit-text-fill-color:var(--dc-text)}.dc-dept-row:hover{background:#f1f5f9}.dc-dept-row.is-active{background:var(--dc-primary-soft);border-color:var(--dc-primary)}.dc-dept-name{display:flex;gap:8px;align-items:center;font-size:var(--fs-13);font-weight:700}.dc-dept-icon{font-size:var(--fs-12)}.dc-dept-metrics{display:flex;gap:6px}.dc-chip{font-size:var(--fs-11);padding:3px 7px;border-radius:999px;background:#e5e7eb;font-weight:800;color:#374151}.dc-chip.is-issue{background:var(--dc-ng-soft);color:var(--dc-ng)}.dc-table-wrap{flex:1;overflow:auto}.dc-table{width:100%;border-collapse:collapse;font-size:var(--fs-13)}.dc-table thead th{position:sticky;top:0;background:#f8fafc;z-index:1;border-bottom:1px solid var(--dc-border);padding:12px 10px;text-align:left;white-space:nowrap}.dc-table tbody td{border-bottom:1px solid var(--dc-border);padding:10px;vertical-align:top}.dc-table tbody tr:hover{background:#f9fafb}.dc-machine-name{font-weight:700;color:var(--dc-text)}.dc-empty-row,.dc-empty{padding:20px;text-align:center;color:var(--dc-muted)}.dc-footnote{padding:10px 14px;border-top:1px solid var(--dc-border);font-size:var(--fs-12);color:var(--dc-muted)}.dc-badge{font-size:var(--fs-11);padding:5px 8px;border-radius:999px;font-weight:800}.dc-badge-done{background:var(--dc-ok-soft);color:var(--dc-ok)}.dc-badge-issue{background:var(--dc-ng-soft);color:var(--dc-ng)}.dc-badge-pending{background:var(--dc-pending-soft);color:var(--dc-pending)}.dc-drawer-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;justify-content:flex-end;z-index:1000}.dc-drawer{width:440px;max-width:100%;height:100%;background:#fff;display:flex;flex-direction:column}.dc-drawer-header{padding:14px;border-bottom:1px solid var(--dc-border);display:flex;justify-content:space-between;gap:10px}.dc-drawer-title{font-weight:800;font-size:var(--fs-16)}.dc-drawer-body{flex:1;overflow:auto;padding:14px}.dc-section{margin-bottom:16px}.dc-section-title{font-weight:800;margin-bottom:10px}.dc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 12px}.dc-k{font-size:var(--fs-11);color:var(--dc-muted)}.dc-v{font-weight:600;color:var(--dc-text)}.dc-items{display:flex;flex-direction:column;gap:10px}.dc-item{border:1px solid var(--dc-border);border-radius:14px;padding:12px;background:#fff}.dc-item-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.dc-item-title{display:flex;gap:6px;flex-wrap:wrap;font-size:var(--fs-13);font-weight:800;color:var(--dc-text)}.dc-item-desc{font-size:var(--fs-12);color:var(--dc-muted);margin-top:6px;line-height:1.4}.dc-item-note{font-size:var(--fs-13);margin-top:8px;color:var(--dc-text);line-height:1.4}.dc-item-ref{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;color:#075985;text-decoration:none;background:#e0f2fe;border:1px solid #7dd3fc;border-radius:999px;padding:8px 12px}.dc-item-ref a{color:inherit;text-decoration:none}.dc-pill{font-size:var(--fs-11);padding:4px 8px;border-radius:999px;font-weight:800}.dc-pill-ok{background:var(--dc-ok-soft);color:var(--dc-ok)}.dc-pill-ng{background:var(--dc-ng-soft);color:var(--dc-ng)}.dc-pill-na{background:#e5e7eb;color:#374151}.dc-card-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.dc-card-audit{margin-top:10px}.dc-card-actions{margin-top:12px;display:flex;justify-content:flex-end}.dc-machine-subline{font-weight:600;color:var(--dc-text)}.dc-refimg{width:100%;max-width:520px;border-radius:12px;border:1px solid #e2e8f0;display:block;margin-top:8px}.dc-page,.dc-page *{color:inherit}.dc-page{color:var(--dc-text)}.dc-page .dc-input,.dc-page .dc-select,.dc-page .dc-input-search{color:var(--dc-text);-webkit-text-fill-color:var(--dc-text);caret-color:var(--dc-text)}.dc-page .dc-btn,.dc-page .dc-btn-sm,.dc-page .dc-btn-ghost{color:var(--dc-text);-webkit-text-fill-color:var(--dc-text)}.dc-page .dc-btn svg,.dc-page .dc-btn-sm svg,.dc-page .dc-btn-ghost svg{color:currentColor}@media(max-width:900px){.dc-main{grid-template-columns:1fr}.dc-left{display:none}.dc-card-header{flex-wrap:wrap;align-items:flex-start}.dc-pager{width:100%;justify-content:flex-end}}@media(max-width:640px){.dc-page{padding:12px}.dc-title-main{font-size:var(--fs-18)}.dc-kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.dc-kpi{padding:12px}.dc-filters{gap:8px;align-items:stretch}.dc-filter{width:100%}.dc-filter-search{min-width:100%}.dc-pager{width:100%;justify-content:space-between;gap:10px}.dc-btn-sm{min-width:96px;height:40px}.dc-drawer{width:100%;max-width:100%}.dc-drawer-header{padding-top:calc(14px + env(safe-area-inset-top))}.dc-drawer-body{padding:12px;padding-bottom:calc(14px + env(safe-area-inset-bottom))}.dc-item{padding:12px}.dc-item-title{font-size:var(--fs-14);line-height:1.3}.dc-item-desc,.dc-item-note{font-size:var(--fs-13)}.dc-refimg{width:100%;max-width:100%}}@media(forced-colors:active){.dc-page{forced-color-adjust:auto}.dc-page .dc-btn,.dc-page .dc-btn-sm,.dc-page .dc-btn-ghost,.dc-page .dc-dept-row,.dc-page .dc-kpi,.dc-page .dc-card{border:1px solid ButtonText;background:ButtonFace;color:ButtonText}.dc-page .dc-input,.dc-page .dc-select,.dc-page .dc-searchbox,.dc-page .dc-input-search{border:1px solid ButtonText;background:Field;color:FieldText;-webkit-text-fill-color:FieldText}.dc-page .dc-badge,.dc-page .dc-pill,.dc-page .dc-chip{border:1px solid ButtonText;background:ButtonFace;color:ButtonText}}.dc-card-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.dc-badge-shift1{background:#dbeafe;color:#1d4ed8}.dc-badge-shift3{background:#ede9fe;color:#6d28d9}.dc-badge-shift-all{background:#e5e7eb;color:#374151}.dc2-page{--dc2-bg: #f8fafc;--dc2-card: #ffffff;--dc2-border: #e2e8f0;--dc2-text: #0b1220;--dc2-muted: #475569;--dc2-primary: #2563eb;--dc2-primary-soft: #dbeafe;--dc2-ok: #16a34a;--dc2-ok-soft: #dcfce7;--dc2-ng: #dc2626;--dc2-ng-soft: #fee2e2;--dc2-pending: #f59e0b;--dc2-pending-soft: #fef3c7;min-height:100dvh;padding:14px;background:var(--dc2-bg);color:var(--dc2-text);font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px;-webkit-text-size-adjust:100%}.dc2-page,.dc2-page *{box-sizing:border-box}.dc2-topbar{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}.dc2-title-main{font-size:var(--fs-22);font-weight:800;line-height:1.15;color:var(--dc2-text)}.dc2-title-sub{margin-top:4px;font-size:var(--fs-13);color:var(--dc2-muted);line-height:1.4}.dc2-topbar-side{display:flex;align-items:center;gap:8px}.dc2-live-hint{min-height:38px;padding:0 12px;border:1px solid var(--dc2-border);background:#fff;border-radius:12px;display:inline-flex;align-items:center;font-size:var(--fs-13);font-weight:700;color:var(--dc2-muted)}.dc2-filter-card{background:var(--dc2-card);border:1px solid var(--dc2-border);border-radius:16px;padding:12px;box-shadow:0 6px 16px #0f172a0a}.dc2-filter-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.dc2-filter-head-title{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-14);font-weight:800}.dc2-filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.dc2-filter{display:flex;flex-direction:column;gap:4px;min-width:120px;font-size:var(--fs-12)}.dc2-filter label{font-weight:700;font-size:var(--fs-12);color:var(--dc2-muted)}.dc2-input,.dc2-select{height:44px;padding:0 12px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;font-size:var(--fs-16);color:var(--dc2-text);-webkit-text-fill-color:var(--dc2-text)}.dc2-input:focus,.dc2-select:focus,.dc2-searchbox:focus-within{outline:none;border-color:var(--dc2-primary);box-shadow:0 0 0 3px #2563eb29}.dc2-filter-search{min-width:260px;flex:1 1 260px}.dc2-searchbox{min-height:44px;display:flex;align-items:center;gap:8px;padding:0 10px;border-radius:12px;border:1px solid #cbd5e1;background:#fff}.dc2-input-search{border:none;height:42px;padding:0;width:100%;font-size:var(--fs-16);color:var(--dc2-text);-webkit-text-fill-color:var(--dc2-text);background:transparent}.dc2-input-search:focus{outline:none;box-shadow:none}.dc2-btn-icon{width:30px;height:30px;min-width:30px;border:none;background:transparent;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:var(--dc2-muted);cursor:pointer}.dc2-btn{height:44px;padding:0 14px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;color:var(--dc2-text);-webkit-text-fill-color:var(--dc2-text);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-14);font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.dc2-btn:hover{background:#f1f5f9}.dc2-btn:active{transform:translateY(1px) scale(.99)}.dc2-btn:disabled{opacity:.6;cursor:not-allowed}.dc2-btn-primary{background:linear-gradient(180deg,#fff,#f8fbff);border-color:#93c5fd}.dc2-btn-reset{background:#f8fafc}.dc2-btn-ghost{border:none;background:transparent}.dc2-btn-sm{height:38px;font-size:var(--fs-13);padding:0 12px}.dc2-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.dc2-kpi{background:var(--dc2-card);border:1px solid var(--dc2-border);border-radius:16px;padding:14px;text-align:left;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.dc2-kpi:hover{background:#f8fbff;transform:translateY(-1px)}.dc2-kpi.is-active{border-color:#7dd3fc;box-shadow:0 0 0 4px #0284c71f}.dc2-kpi-top{display:flex;align-items:center;gap:8px}.dc2-kpi-icon{width:30px;height:30px;border-radius:10px;background:#eff6ff;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center}.dc2-kpi-label{font-size:var(--fs-12);color:var(--dc2-muted);font-weight:700}.dc2-kpi-value{margin-top:10px;font-size:var(--fs-24);font-weight:900;color:var(--dc2-text)}.dc2-main{flex:1;min-height:0;display:grid;grid-template-columns:280px 1fr;gap:12px}.dc2-left,.dc2-right{min-height:0}.dc2-card{background:var(--dc2-card);border:1px solid var(--dc2-border);border-radius:16px;height:100%;display:flex;flex-direction:column;overflow:hidden}.dc2-card-header{padding:12px 14px;border-bottom:1px solid var(--dc2-border);display:flex;justify-content:space-between;align-items:center;gap:10px}.dc2-card-title{font-weight:800;display:flex;flex-direction:column;gap:2px}.dc2-card-title-sub{margin-top:2px}.dc2-muted{color:var(--dc2-muted);font-size:var(--fs-12)}.dc2-pager{display:flex;gap:8px;align-items:center}.dc2-dept-list{flex:1;overflow:auto;padding:8px}.dc2-dept-row{width:100%;border:1px solid transparent;border-radius:12px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;background:#fff;color:var(--dc2-text);-webkit-text-fill-color:var(--dc2-text)}.dc2-dept-row:hover{background:#f1f5f9}.dc2-dept-row.is-active{background:var(--dc2-primary-soft);border-color:var(--dc2-primary)}.dc2-dept-name{display:flex;gap:8px;align-items:center;font-size:var(--fs-13);font-weight:700}.dc2-dept-icon{font-size:var(--fs-12)}.dc2-dept-metrics{display:flex;gap:6px}.dc2-chip{font-size:var(--fs-11);padding:3px 7px;border-radius:999px;background:#e5e7eb;font-weight:800;color:#374151}.dc2-chip.is-issue{background:var(--dc2-ng-soft);color:var(--dc2-ng)}.dc2-table-wrap{flex:1;overflow:auto}.dc2-table{width:100%;border-collapse:collapse;font-size:var(--fs-13)}.dc2-table thead th{position:sticky;top:0;background:#f8fafc;z-index:1;border-bottom:1px solid var(--dc2-border);padding:12px 10px;text-align:left;white-space:nowrap}.dc2-table tbody td{border-bottom:1px solid var(--dc2-border);padding:10px;vertical-align:top}.dc2-table tbody tr:hover{background:#f9fafb}.dc2-machine-name{font-weight:700;color:var(--dc2-text)}.dc2-empty-row,.dc2-empty{padding:20px;text-align:center;color:var(--dc2-muted)}.dc2-footnote{padding:10px 14px;border-top:1px solid var(--dc2-border);font-size:var(--fs-12);color:var(--dc2-muted)}.dc2-badge{font-size:var(--fs-11);padding:5px 8px;border-radius:999px;font-weight:800}.dc2-badge-done{background:var(--dc2-ok-soft);color:var(--dc2-ok)}.dc2-badge-issue{background:var(--dc2-ng-soft);color:var(--dc2-ng)}.dc2-badge-pending{background:var(--dc2-pending-soft);color:var(--dc2-pending)}.dc2-badge-shift1{background:#dbeafe;color:#1d4ed8}.dc2-badge-shift3{background:#ede9fe;color:#6d28d9}.dc2-badge-shift-all{background:#e5e7eb;color:#374151}.dc2-card-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.dc2-drawer-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;justify-content:flex-end;z-index:1000}.dc2-drawer{width:440px;max-width:100%;height:100%;background:#fff;display:flex;flex-direction:column}.dc2-drawer-header{padding:14px;border-bottom:1px solid var(--dc2-border);display:flex;justify-content:space-between;gap:10px}.dc2-drawer-title{font-weight:800;font-size:var(--fs-16)}.dc2-drawer-body{flex:1;overflow:auto;padding:14px}.dc2-section{margin-bottom:16px}.dc2-section-title{font-weight:800;margin-bottom:10px}.dc2-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 12px}.dc2-k{font-size:var(--fs-11);color:var(--dc2-muted)}.dc2-v{font-weight:600;color:var(--dc2-text)}.dc2-items{display:flex;flex-direction:column;gap:10px}.dc2-item{border:1px solid var(--dc2-border);border-radius:14px;padding:12px;background:#fff}.dc2-item-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.dc2-item-title{display:flex;gap:6px;flex-wrap:wrap;font-size:var(--fs-13);font-weight:800;color:var(--dc2-text)}.dc2-item-desc{font-size:var(--fs-12);color:var(--dc2-muted);margin-top:6px;line-height:1.4}.dc2-item-note{font-size:var(--fs-13);margin-top:8px;color:var(--dc2-text);line-height:1.4}.dc2-item-ref{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;color:#075985;text-decoration:none;background:#e0f2fe;border:1px solid #7dd3fc;border-radius:999px;padding:8px 12px}.dc2-item-ref a{color:inherit;text-decoration:none}.dc2-pill{font-size:var(--fs-11);padding:4px 8px;border-radius:999px;font-weight:800}.dc2-pill-ok{background:var(--dc2-ok-soft);color:var(--dc2-ok)}.dc2-pill-ng{background:var(--dc2-ng-soft);color:var(--dc2-ng)}.dc2-pill-na{background:#e5e7eb;color:#374151}.dc2-card-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.dc2-card-audit{margin-top:10px}.dc2-card-actions{margin-top:12px;display:flex;justify-content:flex-end}.dc2-machine-subline{font-weight:600;color:var(--dc2-text)}.dc2-refimg{width:100%;max-width:520px;border-radius:12px;border:1px solid #e2e8f0;display:block;margin-top:8px}@media(max-width:900px){.dc2-main{grid-template-columns:1fr}.dc2-left{display:none}.dc2-card-header{flex-wrap:wrap;align-items:flex-start}.dc2-pager{width:100%;justify-content:flex-end}}@media(max-width:640px){.dc2-page{padding:12px}.dc2-title-main{font-size:var(--fs-18)}.dc2-kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.dc2-kpi{padding:12px}.dc2-filters{gap:8px;align-items:stretch}.dc2-filter{width:100%}.dc2-filter-search{min-width:100%}.dc2-pager{width:100%;justify-content:space-between;gap:10px}.dc2-btn-sm{min-width:96px;height:40px}.dc2-drawer{width:100%;max-width:100%}.dc2-drawer-header{padding-top:calc(14px + env(safe-area-inset-top))}.dc2-drawer-body{padding:12px;padding-bottom:calc(14px + env(safe-area-inset-bottom))}}.dc3-page{--dc3-bg: #f8fafc;--dc3-card: #ffffff;--dc3-border: #dbe3ef;--dc3-text: #0f172a;--dc3-muted: #475569;--dc3-primary: #2563eb;--dc3-primary-soft: #dbeafe;--dc3-ok: #16a34a;--dc3-ok-soft: #dcfce7;--dc3-ng: #dc2626;--dc3-ng-soft: #fee2e2;--dc3-pending: #94a3b8;--dc3-pending-soft: #f1f5f9;--dc3-off: #64748b;--dc3-off-soft: #e2e8f0;min-height:100dvh;padding:14px;background:var(--dc3-bg);color:var(--dc3-text);font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px;-webkit-text-size-adjust:100%}.dc3-page,.dc3-page *{box-sizing:border-box}.dc3-topbar{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}.dc3-title{font-size:var(--fs-24);font-weight:900;line-height:1.15;color:var(--dc3-text)}.dc3-subtitle{margin-top:4px;font-size:var(--fs-13);color:var(--dc3-muted);line-height:1.4}.dc3-live-hint{min-height:40px;padding:0 12px;border-radius:12px;border:1px solid var(--dc3-border);background:#fff;display:inline-flex;align-items:center;font-size:var(--fs-13);font-weight:800;color:var(--dc3-muted)}.dc3-card{background:var(--dc3-card);border:1px solid var(--dc3-border);border-radius:18px;box-shadow:0 8px 24px #0f172a0d}.dc3-filter-card,.dc3-legend-card{padding:12px}.dc3-filter-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.dc3-filter-title{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-14);font-weight:900}.dc3-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.dc3-field{display:flex;flex-direction:column;gap:4px;min-width:120px}.dc3-field label{font-size:var(--fs-12);font-weight:800;color:var(--dc3-muted)}.dc3-field-search{min-width:260px;flex:1 1 260px}.dc3-select,.dc3-input{width:100%;height:44px;padding:0 12px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;color:var(--dc3-text);font-size:var(--fs-16);-webkit-text-fill-color:var(--dc3-text)}.dc3-select:focus,.dc3-input:focus,.dc3-searchbox:focus-within{outline:none;border-color:var(--dc3-primary);box-shadow:0 0 0 3px #2563eb24}.dc3-searchbox{min-height:44px;padding:0 10px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;display:flex;align-items:center;gap:8px}.dc3-searchbox .dc3-input{border:none;box-shadow:none;padding:0;background:transparent}.dc3-btn{height:44px;padding:0 14px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;color:var(--dc3-text);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-14);font-weight:800;cursor:pointer;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.dc3-btn:hover{background:#f8fafc}.dc3-btn:active{transform:translateY(1px) scale(.99)}.dc3-btn:disabled{opacity:.6;cursor:not-allowed}.dc3-btn-primary{border-color:#93c5fd;background:linear-gradient(180deg,#fff,#f8fbff)}.dc3-btn-reset{background:#f8fafc}.dc3-btn-sm{height:38px;padding:0 12px;font-size:var(--fs-13)}.dc3-btn-ghost{border:none;background:transparent}.dc3-btn-icon{width:30px;height:30px;border:none;background:transparent;border-radius:999px;color:var(--dc3-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.dc3-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.dc3-kpi{background:#fff;border:1px solid var(--dc3-border);border-radius:18px;padding:14px}.dc3-kpi-top{display:flex;align-items:center;gap:8px}.dc3-kpi-icon{width:32px;height:32px;border-radius:10px;background:#eff6ff;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center}.dc3-kpi-label{font-size:var(--fs-12);font-weight:800;color:var(--dc3-muted)}.dc3-kpi-value{margin-top:10px;font-size:var(--fs-24);font-weight:900}.dc3-legend{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.dc3-legend-item{display:inline-flex;gap:8px;align-items:center;font-size:var(--fs-13);font-weight:700}.dc3-legend-note{font-size:var(--fs-12);color:var(--dc3-muted)}.dc3-dot,.dc3-cell{width:28px;height:28px;border-radius:999px;border:1.5px solid #94a3b8;background:#fff;color:#475569;font-size:var(--fs-14);font-weight:900;display:inline-flex;align-items:center;justify-content:center}.dc3-cell{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.dc3-cell:hover:not(:disabled){transform:scale(1.08);box-shadow:0 0 0 3px #2563eb1f}.dc3-cell:disabled{cursor:default;opacity:.35}.dc3-dot.is-done,.dc3-cell.is-done{background:var(--dc3-ok-soft);border-color:#86efac;color:var(--dc3-ok)}.dc3-dot.is-issue,.dc3-cell.is-issue{background:var(--dc3-ng-soft);border-color:#fca5a5;color:var(--dc3-ng)}.dc3-dot.is-off,.dc3-cell.is-off{background:var(--dc3-off-soft);border-color:#94a3b8;color:var(--dc3-off)}.dc3-dot.is-pending,.dc3-cell.is-pending{background:#fff;border-color:#94a3b8;color:#475569}.dc3-table-headbar{padding:12px 14px;border-bottom:1px solid var(--dc3-border);display:flex;justify-content:space-between;gap:10px;align-items:center}.dc3-table-title{font-weight:900}.dc3-pager{display:flex;gap:8px;align-items:center}.dc3-table-wrap{overflow:auto;max-width:100%}.dc3-table thead th{position:sticky;top:0;z-index:5;background:#f8fafc;border-bottom:1px solid var(--dc3-border);padding:10px 8px;white-space:nowrap;text-align:center;font-weight:900}.dc3-day-head{min-width:38px;width:38px}.dc3-day-week{font-size:var(--fs-10);font-weight:700;color:var(--dc3-muted);margin-top:2px}.dc3-table tbody td{border-bottom:1px solid #eef2f7;padding:6px;background:#fff}.dc3-table tbody tr:hover td{background:#fcfdff}.sticky-col{position:sticky;background:#fff!important;z-index:4}.dc3-table thead .sticky-col{background:#f8fafc!important;z-index:6}.dc3-machine-name{font-weight:800;color:var(--dc3-text)}.dc3-machine-sub{margin-top:4px;font-size:var(--fs-11);color:var(--dc3-muted);line-height:1.35}.dc3-cell-td{text-align:center}.dc3-footnote{padding:10px 14px;border-top:1px solid var(--dc3-border);font-size:var(--fs-12);color:var(--dc3-muted)}.dc3-empty{padding:20px;text-align:center;color:var(--dc3-muted)}.dc3-error{padding:12px 14px;border-radius:14px;background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;font-weight:800}.dc3-drawer-backdrop{position:fixed;inset:0;background:#0f172a70;z-index:1000;display:flex;justify-content:flex-end}.dc3-drawer{width:460px;max-width:100%;height:100%;background:#fff;display:flex;flex-direction:column}.dc3-drawer-header{padding:14px;border-bottom:1px solid var(--dc3-border);display:flex;justify-content:space-between;gap:10px}.dc3-drawer-title{font-size:var(--fs-16);font-weight:900}.dc3-drawer-body{flex:1;overflow:auto;padding:14px}.dc3-section{margin-bottom:16px}.dc3-section-title{font-weight:900;margin-bottom:10px}.dc3-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}.dc3-k{font-size:var(--fs-11);color:var(--dc3-muted)}.dc3-v{font-weight:700;color:var(--dc3-text)}.dc3-items{display:flex;flex-direction:column;gap:10px}.dc3-item{border:1px solid var(--dc3-border);border-radius:14px;padding:12px;background:#fff}.dc3-item-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}.dc3-item-title{display:flex;flex-wrap:wrap;gap:6px;font-size:var(--fs-13);font-weight:800}.dc3-item-desc{margin-top:6px;font-size:var(--fs-12);color:var(--dc3-muted);line-height:1.4}.dc3-item-note{margin-top:8px;font-size:var(--fs-13);color:var(--dc3-text)}.dc3-item-ref{margin-top:8px;display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:8px 12px;background:#e0f2fe;color:#075985;border:1px solid #7dd3fc;font-size:var(--fs-13);font-weight:800}.dc3-item-ref a{color:inherit;text-decoration:none}.dc3-pill-ok,.dc3-pill-ng,.dc3-pill-na,.dc3-pill-pending{font-size:var(--fs-11);padding:4px 8px;border-radius:999px;font-weight:900}.dc3-pill-ok{background:var(--dc3-ok-soft);color:var(--dc3-ok)}.dc3-pill-ng{background:var(--dc3-ng-soft);color:var(--dc3-ng)}.dc3-pill-na{background:var(--dc3-off-soft);color:var(--dc3-off)}.dc3-pill-pending{background:var(--dc3-pending-soft);color:#64748b}.dc3-refimg{width:100%;max-width:520px;display:block;margin-top:8px;border-radius:12px;border:1px solid #e2e8f0}.dc3-muted{color:var(--dc3-muted);font-size:var(--fs-12)}.spin{animation:dc3-spin .8s linear infinite}@keyframes dc3-spin{to{transform:rotate(360deg)}}@media(max-width:900px){.dc3-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.sticky-col-2{min-width:220px;width:220px}.dc3-grid{grid-template-columns:1fr}}@media(max-width:640px){.dc3-page{padding:12px}.dc3-title{font-size:var(--fs-19)}.dc3-field,.dc3-field-search{width:100%;min-width:100%}.dc3-kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.sticky-col-1{min-width:95px;width:95px}.sticky-col-2{left:95px;min-width:190px;width:190px}.dc3-drawer{width:100%;max-width:100%}.dc3-drawer-header{padding-top:calc(14px + env(safe-area-inset-top))}.dc3-drawer-body{padding-bottom:calc(14px + env(safe-area-inset-bottom))}}.dc3-day-head.is-today{background:#fef3c7!important;color:#92400e;box-shadow:inset 0 -3px #f59e0b}.dc3-cell-td.is-today{background:#fffbeb!important}.dc3-table tbody tr:hover .dc3-cell-td.is-today{background:#fef3c7!important}.dc3-table-card{overflow:hidden}.dc3-table-wrap{overflow:auto;max-width:100%;max-height:60vh;background:#fff;border-top:1px solid var(--dc3-border);-webkit-overflow-scrolling:touch}.dc3-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-13)}.dc3-table thead th{position:sticky;top:0;z-index:20;background:#f8fafc;border-bottom:1px solid var(--dc3-border);box-shadow:0 2px 6px #0f172a14;padding:10px 8px;white-space:nowrap;text-align:center;font-weight:900}.dc3-table thead .sticky-col{background:#f8fafc!important;z-index:25}.md-page{min-height:100dvh;background:#f8fafc;padding:12px;color:#0f172a;font-family:var(--pps-font-main)}.md-header{margin-bottom:12px}.md-title{font-size:var(--fs-22);font-weight:800}.md-subtitle{font-size:var(--fs-12);color:#64748b;margin-top:4px}.md-filter-card,.md-list-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:12px;margin-bottom:12px}.md-filter-grid{display:grid;gap:10px}.md-field{display:grid;gap:4px}.md-field label{font-size:var(--fs-12);font-weight:700;color:#64748b}.md-input{height:42px;border:1px solid #cbd5e1;border-radius:12px;padding:0 12px;background:#fff;font-size:var(--fs-15)}.md-field-search{min-width:0}.md-search{height:42px;border:1px solid #cbd5e1;border-radius:12px;display:flex;align-items:center;gap:8px;padding:0 12px}.md-search-input{border:none;outline:none;width:100%;font-size:var(--fs-15);background:transparent}.md-actions{display:flex;gap:8px;margin-top:10px}.md-limit{width:100px}.md-btn{height:42px;border:1px solid #cbd5e1;border-radius:12px;background:#fff;padding:0 14px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px}.md-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}.md-kpi{border:1px solid #e2e8f0;background:#fff;border-radius:16px;padding:12px;text-align:left}.md-kpi-top{display:flex;align-items:center;gap:8px}.md-kpi-icon{width:28px;height:28px;border-radius:10px;background:#eff6ff;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center}.md-kpi-label{font-size:var(--fs-12);color:#64748b;font-weight:700}.md-kpi-value{margin-top:8px;font-size:var(--fs-24);font-weight:900}.md-list-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.md-list-title{font-size:var(--fs-16);font-weight:800}.md-list-sub,.md-page-info{font-size:var(--fs-12);color:#64748b}.md-list{display:grid;gap:10px}.md-item{border:1px solid #e2e8f0;border-radius:14px;padding:12px;background:#fff}.md-item-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.md-uid{font-family:var(--pps-font-mono);font-weight:800}.md-machine{margin-top:6px;font-weight:700;line-height:1.35}.md-meta{margin-top:6px;display:flex;flex-wrap:wrap;gap:8px 12px;font-size:var(--fs-12);color:#475569}.md-badge{font-size:var(--fs-11);padding:5px 8px;border-radius:999px;font-weight:800}.md-badge-done{background:#dcfce7;color:#16a34a}.md-badge-pending{background:#fef3c7;color:#d97706}.md-badge-issue{background:#fee2e2;color:#dc2626}.md-empty{text-align:center;color:#64748b;padding:24px 12px}.md-footer{display:flex;justify-content:space-between;gap:8px;margin-top:12px}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.md-header-top{margin-bottom:8px}.md-btn-back{height:36px;padding:0 10px;border-radius:10px;border:1px solid #cbd5e1;background:#fff;display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:var(--fs-13)}.md-badge-off{background:#fef3c7;color:#92400e}.md-kpi.active{border-color:#93c5fd;box-shadow:0 0 0 3px #2563eb1f}.pac-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--primary-soft: #e0f2fe;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--tap: 48px}.pac-topbar{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.pac-titlewrap{min-width:0;flex:1}.pac-title{font-size:var(--fs-16);font-weight:1000;line-height:1.1;color:var(--text)}.pac-sub{margin-top:4px;font-size:var(--fs-12);color:var(--muted);font-weight:800;word-break:break-word}.pac-who{margin-left:auto}.pac-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:#fff;border:1px solid var(--border);font-weight:900;color:var(--text)}.pac-back{width:46px;height:46px;min-width:46px;border-radius:14px;border:1.5px solid #cbd5e1;background:linear-gradient(180deg,#fff,#f8fafc);display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:0;color:#0f172a;box-shadow:0 4px 10px #0f172a1f,inset 0 1px #ffffffe6;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease}.pac-back svg{width:22px;height:22px;display:block;stroke-width:2.6}.pac-back:active{transform:translateY(1px) scale(.97);box-shadow:0 3px 8px #0f172a2e,inset 0 2px 4px #0f172a26}.pac-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px}.pac-alert{padding:10px 12px;border-radius:12px;background:#fee2e2;border:1px solid #fecaca;color:#7f1d1d;font-weight:1000}.pac-muted{color:var(--muted);font-weight:800}.pac-m-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}.pac-m-k{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-12);color:var(--muted);font-weight:1000}.pac-m-uid{margin-top:4px;font-size:var(--fs-18);font-weight:1000}.pac-m-name{margin-top:2px;font-size:var(--fs-13);font-weight:900;color:var(--text);line-height:1.25}.pac-status{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:var(--primary-soft);border:1px solid #bae6fd;color:#075985;font-weight:1000;font-size:var(--fs-12)}.pac-m-grid{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}.pac-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:#fff;border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:900;color:var(--text)}.pac-exist{margin-top:10px;padding-top:10px;border-top:1px dashed #e2e8f0;font-size:var(--fs-12);color:var(--muted);font-weight:900}.pac-section-title{font-weight:1000;font-size:var(--fs-14);margin-bottom:10px}.pac-label{display:block;font-size:var(--fs-12);font-weight:1000;color:#334155;margin-bottom:6px}.pac-textarea{width:100%;border:1px solid #94a3b8;background:#e8edf5;border-radius:14px;padding:12px;font-size:var(--fs-14);font-weight:700;outline:none;color:#0f172a;-webkit-text-fill-color:#0f172a}.pac-textarea:focus{background:#fff;border-color:var(--primary2);box-shadow:0 0 0 3px #0284c724}.pac-upload-row{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}.pac-btn{min-height:44px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:1000;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px}.pac-btn-soft{position:relative;overflow:hidden;background:var(--primary-soft);border-color:#bae6fd;color:#075985}.pac-file{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer}.pac-preview{margin-top:10px;border:1px solid var(--border);background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}.pac-preview img{width:100%;display:block;max-height:320px;object-fit:cover}.pac-preview-meta{padding:10px 12px}.pac-fn{font-weight:1000;font-size:var(--fs-13);color:var(--text);word-break:break-word}.pac-hint{margin-top:10px;font-size:var(--fs-12);color:var(--muted);font-weight:800}.pac-submit{margin-top:12px;width:100%;min-height:var(--tap);border-radius:14px;border:none;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;font-weight:1000;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px}.pac-submit:disabled{opacity:.7;cursor:not-allowed}:root{--pps-font-main: "Inter", "Noto Sans Thai", "Sarabun", system-ui, sans-serif;--pps-bg: #f8fafc;--pps-card: #ffffff;--pps-border: #e5e7eb;--pps-border-strong: #cbd5e1;--pps-text: #0f172a;--pps-text-soft: #334155;--pps-muted: #64748b;--pps-primary: #0369a1;--pps-radius-sm: 10px;--pps-radius-md: 14px;--pps-shadow: 0 4px 16px rgba(15, 23, 42, .05);--pps-text-xs: 12px;--pps-text-sm: 13px;--pps-text-md: 14px;--pps-text-lg: 16px}.pmtr-page{min-height:100svh;min-height:-webkit-fill-available;width:100%;max-width:100%;padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));padding-left:calc(12px + env(safe-area-inset-left,0px));padding-right:calc(12px + env(safe-area-inset-right,0px));background:var(--pps-bg);color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);color-scheme:light;font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:12px;overflow-x:hidden;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}.pmtr-page *{min-width:0}.pmtr-page a,.pmtr-page button,.pmtr-page input,.pmtr-page select,.pmtr-page textarea,.pmtr-page span,.pmtr-page div,.pmtr-page td,.pmtr-page th{-webkit-text-fill-color:currentColor}.pmtr-page button,.pmtr-page input,.pmtr-page select,.pmtr-page textarea{font:inherit;color:inherit;font-family:inherit}.pmtr-topbar,.pmtr-card{width:100%;max-width:100%;min-width:0;background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);color:var(--pps-text);box-shadow:var(--pps-shadow)}.pmtr-topbar{display:flex;flex-direction:column;gap:8px;padding:12px}.pmtr-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.3}.pmtr-sub{margin-top:2px;font-size:var(--pps-text-xs);font-weight:500;color:var(--pps-muted);line-height:1.45}.pmtr-actions{display:flex;gap:8px;flex-wrap:wrap}.pmtr-card{padding:12px}.pmtr-alert{display:flex;align-items:center;gap:10px;background:#fff7ed;border-color:#fed7aa;color:#9a3412;font-weight:700}.pmtr-hero{display:grid;gap:10px}.pmtr-uid-label{display:flex;align-items:center;gap:6px;font-size:var(--pps-text-xs);font-weight:800;color:var(--pps-text-soft)}.pmtr-uid-val{margin-top:2px;font-size:var(--pps-text-lg);font-weight:800;word-break:break-word}.pmtr-type,.pmtr-who{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.pmtr-pill,.pmtr-pill2,.pmtr-pill3{min-height:26px;display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:var(--pps-text-xs);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.pmtr-pill.elec{background:#e0f2fe;border-color:#7dd3fc;color:#075985}.pmtr-pill.water{background:#ecfeff;border-color:#a5f3fc;color:#155e75}.pmtr-pill.lpg{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.pmtr-pill2{background:#f8fafc;border-color:var(--pps-border);color:var(--pps-text)}.pmtr-pill3{background:#ecfdf5;border-color:#bbf7d0;color:#166534;font-weight:800}.pmtr-ref{border:1px dashed var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:10px;background:#f8fafc}.pmtr-ref-title{margin-bottom:8px;font-size:var(--pps-text-xs);font-weight:800;color:var(--pps-text-soft)}.pmtr-ref-row{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-top:1px solid var(--pps-border)}.pmtr-ref-row:first-of-type{border-top:none}.pmtr-ref-row .k{color:var(--pps-muted);font-size:var(--pps-text-xs);font-weight:700}.pmtr-ref-row .v{color:var(--pps-text);font-weight:800;text-align:right;word-break:break-word}.pmtr-form{display:grid;gap:10px}.pmtr-field label{display:block;margin-bottom:6px;font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.pmtr-field input:not([type=checkbox]):not([type=radio]),.pmtr-field select,.pmtr-field textarea{width:100%;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);font-size:var(--fs-16);font-weight:600;font-family:var(--pps-font-main);outline:none;-webkit-appearance:none;appearance:none;box-shadow:none}.pmtr-field input:not([type=checkbox]):not([type=radio]),.pmtr-field select{min-height:44px;padding:0 12px}.pmtr-field textarea{min-height:92px;padding:10px 12px;line-height:1.5;resize:vertical}.pmtr-field input::placeholder,.pmtr-field textarea::placeholder{color:#94a3b8;-webkit-text-fill-color:#94a3b8;font-weight:500}.pmtr-field input:focus,.pmtr-field select:focus,.pmtr-field textarea:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pmtr-field input:disabled,.pmtr-field select:disabled,.pmtr-field textarea:disabled{color:var(--pps-text)!important;-webkit-text-fill-color:var(--pps-text)!important;opacity:1;background:#f1f5f9;cursor:not-allowed}.pmtr-help{margin-top:6px;font-size:var(--pps-text-xs);font-weight:500;color:var(--pps-muted);line-height:1.45}.pmtr-checkrow{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;border:1px solid var(--pps-border);background:#fff;border-radius:var(--pps-radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.pmtr-checkrow:focus-within{border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pmtr-checkbox{width:20px;height:20px;margin-top:2px;flex:0 0 20px;accent-color:var(--pps-primary)}.pmtr-checktext{font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text);line-height:1.4}.pmtr-btn,.pmtr-btn-primary,.pmtr-link{min-height:40px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;text-decoration:none;white-space:nowrap;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.pmtr-btn,.pmtr-link{border:1px solid var(--pps-border);background:#fff;color:var(--pps-text)}.pmtr-btn:hover,.pmtr-link:hover{background:#f8fafc;transform:translateY(-1px)}.pmtr-btn-primary{width:100%;min-height:46px;border:none;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff!important;-webkit-text-fill-color:#ffffff!important;font-size:var(--pps-text-md);box-shadow:0 6px 14px #0284c72e}.pmtr-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985);transform:translateY(-1px)}.pmtr-btn:disabled,.pmtr-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pmtr-muted{color:var(--pps-muted);font-size:var(--pps-text-xs)}.pmtr-history-head{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.pmtr-history-title{font-size:var(--pps-text-md);font-weight:800}.pmtr-history-sub{font-size:var(--pps-text-xs);color:var(--pps-muted)}.pmtr-table-wrap{overflow:auto;max-height:55vh;border:1px solid var(--pps-border);border-radius:var(--pps-radius-sm);background:#fff;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.pmtr-table{width:max-content;min-width:720px;border-collapse:separate;border-spacing:0}.pmtr-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pmtr-table td{color:var(--pps-text);font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap}.pmtr-table tbody tr:nth-child(2n){background:#fafafa}.pmtr-table tbody tr:hover{background:#f1f5f9}.pmtr-empty{text-align:center;color:var(--pps-muted);padding:24px!important;font-size:var(--pps-text-md);font-weight:600}.pmtr-remark{white-space:normal;min-width:220px;max-width:420px;color:var(--pps-text-soft);word-break:break-word}.pmtr-foot{margin-top:10px;display:flex;justify-content:flex-end}@media(min-width:640px){.pmtr-page{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));padding-left:calc(16px + env(safe-area-inset-left,0px));padding-right:calc(16px + env(safe-area-inset-right,0px))}.pmtr-topbar{flex-direction:row;align-items:flex-end;justify-content:space-between}.pmtr-actions{justify-content:flex-end}}@media(max-width:720px){.pmtr-topbar{position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.pmtr-table{min-width:640px}.pmtr-table th{font-size:var(--fs-12);padding:10px 8px}.pmtr-table td{font-size:var(--fs-13);padding:10px 8px}}@media(hover:none){.pmtr-btn:hover,.pmtr-link:hover{background:#fff;transform:none}.pmtr-btn-primary:hover{background:linear-gradient(135deg,#0284c7,#0369a1);transform:none}}.portal2-page{--bg: #eef2f7;--bg-2: #f8fafc;--card: rgba(255, 255, 255, .78);--card-hover: rgba(255, 255, 255, .96);--card-border: rgba(255, 255, 255, .7);--line: rgba(15, 23, 42, .1);--text: #0f172a;--text-soft: #334155;--text-muted: #64748b;--primary: #2563eb;--shadow-sm: 0 10px 24px rgba(15, 23, 42, .06);--shadow-md: 0 18px 44px rgba(15, 23, 42, .12);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .16);min-height:100%;background:radial-gradient(circle at top left,#fff,#eef2f7 42%,#e8edf4);padding:28px 28px 44px;position:relative;overflow:hidden;color:var(--text)}.portal2-bg-orb{position:absolute;border-radius:999px;pointer-events:none;filter:blur(16px);opacity:.55}.portal2-bg-orb-1{width:260px;height:260px;top:-70px;left:-60px;background:#3b82f61f}.portal2-bg-orb-2{width:320px;height:320px;right:-110px;top:80px;background:#a855f71f}.portal2-shell{width:min(1600px,100%);margin:0 auto;position:relative;z-index:1}.portal2-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:28px;padding:6px 2px 2px}.portal2-header-left{display:flex;align-items:flex-start;gap:16px;min-width:0}.portal2-brand-icon{width:62px;height:62px;border-radius:18px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;display:grid;place-items:center;font-size:var(--fs-28);box-shadow:0 14px 34px #2563eb40;flex:0 0 auto}.portal2-header-copy{min-width:0}.portal2-eyebrow{font-size:var(--fs-12);font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.portal2-title{margin:0;font-size:clamp(28px,3vw,42px);line-height:1.05;font-weight:900;letter-spacing:-.04em}.portal2-subtitle{margin:10px 0 0;max-width:760px;font-size:var(--fs-14);line-height:1.6;color:var(--text-soft)}.portal2-header-right{flex:0 0 auto}.portal2-uid-card{min-width:180px;padding:14px 16px;border-radius:18px;background:#ffffffb8;border:1px solid rgba(255,255,255,.82);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.portal2-uid-label{display:block;font-size:var(--fs-11);font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.portal2-uid-value{font-size:var(--fs-18);font-weight:900;color:var(--text);word-break:break-word}.portal2-section{position:relative}.portal2-divider{height:1px;background:linear-gradient(90deg,transparent 0%,rgba(15,23,42,.14) 12%,rgba(15,23,42,.14) 88%,transparent 100%);margin:34px 0 26px}.portal2-section-head{margin-bottom:18px;padding:0 4px}.portal2-section-kicker{font-size:var(--fs-12);font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.portal2-section-title{margin:0;font-size:clamp(20px,2vw,30px);line-height:1.15;font-weight:900;letter-spacing:-.03em;color:var(--text)}.portal2-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:26px 28px}.portal2-card{position:relative;min-height:250px;border-radius:26px;text-decoration:none;color:inherit;display:flex;flex-direction:column;padding:22px 22px 18px;background:var(--card);border:1px solid var(--card-border);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden;transition:transform .22s ease,box-shadow .24s ease,background .24s ease,border-color .24s ease}.portal2-card:hover{transform:translateY(-6px);background:var(--card-hover);box-shadow:var(--shadow-lg);border-color:#fffffff2}.portal2-card.is-disabled{opacity:.62;cursor:not-allowed}.portal2-card.is-disabled:hover{transform:none;box-shadow:var(--shadow-sm)}.portal2-card-glow{position:absolute;inset:auto -40px -90px auto;width:180px;height:180px;border-radius:999px;background:radial-gradient(circle,rgba(59,130,246,.12),transparent 70%);pointer-events:none}.portal2-card-icon-wrap{display:flex;justify-content:flex-start;margin-bottom:20px}.portal2-card-icon{width:86px;height:86px;border-radius:24px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#2563eb,#3b82f6);font-size:var(--fs-40);box-shadow:0 16px 32px #0f172a24;overflow:hidden;flex:0 0 auto}.portal2-card-image{width:100%;height:100%;object-fit:cover}.portal2-card-body{flex:1 1 auto}.portal2-card-title{margin:0;font-size:clamp(24px,2vw,34px);line-height:1.12;font-weight:900;letter-spacing:-.04em;color:var(--text);word-break:break-word}.portal2-card-desc{margin:12px 0 0;font-size:var(--fs-14);line-height:1.55;color:var(--text-soft);max-width:92%}.portal2-card-footer{margin-top:18px;display:flex;align-items:center;justify-content:space-between;gap:12px}.portal2-card-linktext{font-size:var(--fs-13);font-weight:800;color:var(--text-muted);letter-spacing:.01em}.portal2-card-arrow{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:#0f172a0d;color:var(--text);font-size:var(--fs-16);transition:transform .2s ease,background .2s ease}.portal2-card:hover .portal2-card-arrow{transform:translate(2px,-2px);background:#2563eb1a}.portal2-error{margin-bottom:18px;border:1px solid #fecaca;background:#fff1f2;color:#9f1239;border-radius:16px;padding:14px 16px;font-size:var(--fs-14);font-weight:700;box-shadow:var(--shadow-sm)}.portal2-empty{min-height:300px;border-radius:28px;background:#ffffffad;border:1px solid rgba(255,255,255,.85);box-shadow:var(--shadow-sm);display:grid;place-items:center;text-align:center;padding:28px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.portal2-empty-icon{width:72px;height:72px;margin:0 auto 12px;border-radius:22px;display:grid;place-items:center;background:linear-gradient(135deg,#dbeafe,#ede9fe);color:#2563eb;font-size:var(--fs-32)}.portal2-empty-title{font-size:var(--fs-22);font-weight:900;color:var(--text)}.portal2-empty-subtitle{margin-top:8px;font-size:var(--fs-14);color:var(--text-muted)}.portal2-card-skeleton{min-height:250px;border-radius:26px;background:linear-gradient(90deg,#ffffff73,#ffffffe0,#ffffff73);background-size:200% 100%;border:1px solid rgba(255,255,255,.82);box-shadow:var(--shadow-sm);animation:portal2Shimmer 1.2s linear infinite}@keyframes portal2Shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:1280px){.portal2-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:900px){.portal2-header{flex-direction:column;align-items:stretch}.portal2-header-right,.portal2-uid-card{width:100%}}@media(max-width:768px){.portal2-page{padding:16px 14px 28px}.portal2-header-left{gap:12px}.portal2-brand-icon{width:52px;height:52px;border-radius:16px;font-size:var(--fs-24)}.portal2-title{font-size:var(--fs-28)}.portal2-grid{grid-template-columns:1fr;gap:18px}.portal2-card{min-height:220px;border-radius:22px;padding:18px 18px 16px}.portal2-card-icon{width:76px;height:76px;border-radius:20px;font-size:var(--fs-34)}.portal2-card-title{font-size:var(--fs-26)}.portal2-divider{margin:28px 0 20px}}.pchem-page{min-height:100svh;min-height:-webkit-fill-available;width:100%;max-width:100%;padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));padding-left:calc(12px + env(safe-area-inset-left,0px));padding-right:calc(12px + env(safe-area-inset-right,0px));background:var(--pps-bg);color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);color-scheme:light;font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:12px;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.pchem-page *{min-width:0}.pchem-page a,.pchem-page button,.pchem-page input,.pchem-page select,.pchem-page textarea,.pchem-page label,.pchem-page span,.pchem-page div,.pchem-page p,.pchem-page th,.pchem-page td,.pchem-page strong,.pchem-page em{-webkit-text-fill-color:currentColor}.pchem-page button,.pchem-page input,.pchem-page select,.pchem-page textarea{font:inherit;color:inherit;font-family:inherit}.pchem-topbar,.pchem-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);box-shadow:var(--pps-shadow);color:var(--pps-text)}.pchem-topbar{display:flex;flex-direction:column;gap:8px;padding:12px}.pchem-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.3;color:var(--pps-text)}.pchem-sub{margin-top:2px;font-size:var(--pps-text-xs);font-weight:500;color:var(--pps-muted);line-height:1.45}.pchem-actions{display:flex;gap:8px;flex-wrap:wrap}.pchem-card{padding:12px}.pchem-alert{display:flex;align-items:center;gap:10px;background:#fff7ed;border-color:#fed7aa;color:#9a3412;font-weight:700}.pchem-hero{display:grid;gap:10px}.pchem-uid-label{display:flex;align-items:center;gap:6px;font-size:var(--pps-text-xs);font-weight:800;color:var(--pps-muted-strong)}.pchem-uid-val{margin-top:2px;font-size:var(--pps-text-lg);font-weight:800;color:var(--pps-text)}.pchem-type{display:flex;gap:8px;flex-wrap:wrap}.pchem-pill2,.pchem-pill3{min-height:26px;display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:var(--pps-text-xs);line-height:1.2;white-space:nowrap}.pchem-pill2{font-weight:700;border:1px solid var(--pps-border);background:#f8fafc;color:var(--pps-text)}.pchem-pill3{font-weight:800;border:1px solid #bbf7d0;background:#ecfdf5;color:#166534}.pchem-ref{border:1px dashed var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:10px;background:#f8fafc}.pchem-ref-title{margin-bottom:8px;display:flex;align-items:center;gap:6px;font-size:var(--pps-text-xs);font-weight:800;color:var(--pps-text-soft)}.pchem-ref-row{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-top:1px solid var(--pps-border)}.pchem-ref-row:first-of-type{border-top:none}.pchem-ref-row .k{color:var(--pps-muted);font-weight:700;font-size:var(--pps-text-xs)}.pchem-ref-row .v{font-weight:800;color:var(--pps-text);text-align:right;word-break:break-word}.pchem-stock-card{display:grid;gap:10px}.pchem-stock-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.pchem-stock-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-md);font-weight:800;color:var(--pps-text)}.pchem-stock-badge{min-height:28px;padding:4px 10px;border-radius:999px;display:inline-flex;align-items:center;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.pchem-stock-badge.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pchem-stock-badge.warn{background:#fffbeb;border-color:#fde68a;color:#92400e}.pchem-stock-badge.danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.pchem-stock-main{display:flex;align-items:center;justify-content:flex-start}.pchem-stock-value{font-size:var(--fs-28);font-weight:800;line-height:1.1;color:var(--pps-text);font-variant-numeric:tabular-nums}.pchem-stock-help{font-size:var(--pps-text-xs);font-weight:500;color:var(--pps-muted);line-height:1.45}.pchem-form{display:grid;gap:10px;min-height:0}.pchem-grid2{display:grid;gap:10px}.pchem-field label{display:block;margin-bottom:6px;font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.pchem-field input,.pchem-field select,.pchem-field textarea{width:100%;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);font-size:var(--fs-16);font-weight:600;font-family:var(--pps-font-main);outline:none;-webkit-appearance:none;appearance:none;box-shadow:none}.pchem-field input,.pchem-field select{height:44px;padding:0 12px}.pchem-field textarea{min-height:92px;padding:10px 12px;line-height:1.5;resize:vertical}.pchem-field input::placeholder,.pchem-field textarea::placeholder{color:#94a3b8;-webkit-text-fill-color:#94a3b8;font-weight:500}.pchem-field select{padding-right:40px;background-image:linear-gradient(45deg,transparent 50%,#475569 50%),linear-gradient(135deg,#475569 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}.pchem-field input:focus,.pchem-field select:focus,.pchem-field textarea:focus{background-color:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pchem-field input:disabled,.pchem-field select:disabled,.pchem-field textarea:disabled{color:var(--pps-text)!important;opacity:1!important;-webkit-text-fill-color:var(--pps-text)!important;background:#f1f5f9;cursor:not-allowed}.pchem-seg{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pchem-seg-btn{min-height:44px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border-strong);background:#fff;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);font-weight:800;font-size:var(--pps-text-md);font-family:var(--pps-font-main);display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;-webkit-appearance:none;appearance:none;text-shadow:none;transition:transform .15s ease,background .15s ease,border-color .15s ease}.pchem-seg-btn:hover{background:#f8fafc;transform:translateY(-1px)}.pchem-seg-btn:active{transform:translateY(1px)}.pchem-seg-btn.active.in{background:#ecfdf5;border-color:#86efac;color:#166534;-webkit-text-fill-color:#166534}.pchem-seg-btn.active.out{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8;-webkit-text-fill-color:#1d4ed8}.pchem-btn,.pchem-btn-primary,.pchem-link{min-height:40px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-appearance:none;appearance:none;text-shadow:none;white-space:nowrap;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.pchem-btn{border:1px solid var(--pps-border);background:#fff;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text)}.pchem-btn:hover,.pchem-link:hover{background:#f8fafc;transform:translateY(-1px)}.pchem-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.pchem-btn-primary{width:100%;min-height:46px;border:none;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff!important;-webkit-text-fill-color:#ffffff!important;font-size:var(--pps-text-md);box-shadow:0 6px 14px #0284c72e}.pchem-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985);transform:translateY(-1px)}.pchem-btn-primary:disabled{background:#94a3b8;color:#fff!important;-webkit-text-fill-color:#ffffff!important;cursor:not-allowed;transform:none;box-shadow:none}.pchem-who{margin-top:6px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.pchem-muted{color:var(--pps-muted);font-size:var(--pps-text-xs)}.pchem-history-head{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.pchem-history-title{font-size:var(--pps-text-md);font-weight:800;color:var(--pps-text)}.pchem-history-sub{font-size:var(--pps-text-xs);color:var(--pps-muted)}.pchem-table-wrap{overflow:auto;max-height:55vh;border:1px solid var(--pps-border);border-radius:var(--pps-radius-sm);-webkit-overflow-scrolling:touch;overscroll-behavior:contain;min-height:0;background:#fff}.pchem-table{width:max-content;min-width:1100px;border-collapse:separate;border-spacing:0;color:var(--pps-text)}.pchem-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);border-bottom:1px solid var(--pps-border);padding:12px;font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap}.pchem-table td{border-bottom:1px solid #f1f5f9;padding:12px;white-space:nowrap;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;vertical-align:middle;color:var(--pps-text)}.pchem-table tbody tr:nth-child(2n){background:#fafafa}.pchem-table tbody tr:hover{background:#f1f5f9}.pchem-empty{text-align:center;color:var(--pps-muted);padding:24px;font-size:var(--pps-text-md);font-weight:600}.pchem-remark{white-space:normal;min-width:240px;max-width:420px;color:var(--pps-text-soft);line-height:1.5;word-break:break-word}.pchem-mv-badge{min-height:24px;padding:4px 9px;border-radius:999px;display:inline-flex;align-items:center;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.pchem-mv-badge.in{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pchem-mv-badge.out{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.pchem-foot{margin-top:10px;display:flex;justify-content:flex-end}.pchem-link{min-height:40px;border:1px solid var(--pps-border);background:#fff;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);text-decoration:none}@media(min-width:640px){.pchem-page{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));padding-left:calc(16px + env(safe-area-inset-left,0px));padding-right:calc(16px + env(safe-area-inset-right,0px))}.pchem-topbar{flex-direction:row;align-items:flex-end;justify-content:space-between}.pchem-grid2{grid-template-columns:1fr 1fr}}@media(max-width:720px){.pchem-topbar{position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.pchem-seg{grid-template-columns:1fr}.pchem-stock-value{font-size:var(--fs-24)}.pchem-table th{font-size:var(--fs-12);padding:10px 8px}.pchem-table td{font-size:var(--fs-13);padding:10px 8px}}.pcm-page{min-height:100%;width:100%;max-width:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:16px;overflow-x:hidden}.pcm-page>*{min-width:0}.pcm-topbar{display:flex;gap:12px;align-items:flex-end;justify-content:space-between;flex-wrap:wrap}.pcm-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25}.pcm-sub{margin-top:4px;font-size:var(--pps-text-sm);font-weight:500;color:var(--pps-muted);line-height:1.45}.pcm-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.pcm-summary-card,.pcm-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);box-shadow:var(--pps-shadow)}.pcm-summary-card,.pcm-card{padding:16px}.pcm-summary-label{font-size:var(--pps-text-xs);font-weight:700;color:var(--pps-muted);line-height:1.4}.pcm-summary-value{margin-top:6px;font-size:var(--fs-22);font-weight:800;line-height:1.2;color:var(--pps-text);font-variant-numeric:tabular-nums}.pcm-summary-value.ok{color:#166534}.pcm-summary-value.warn{color:#92400e}.pcm-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.pcm-card-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.35}.pcm-form{display:grid;gap:12px}.pcm-grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.pcm-grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.pcm-field label{display:block;margin-bottom:6px;font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.pcm-field input,.pcm-field select,.pcm-searchbar input{width:100%;height:40px;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;padding:0 12px;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text);outline:none;-webkit-appearance:none;appearance:none}.pcm-field input::placeholder,.pcm-searchbar input::placeholder{color:#94a3b8;font-weight:500}.pcm-field input:focus,.pcm-field select:focus,.pcm-searchbar input:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pcm-field input:disabled,.pcm-field select:disabled{opacity:.75;cursor:not-allowed;background:#f1f5f9}.pcm-help{margin-top:6px;font-size:var(--pps-text-xs);color:var(--pps-muted);line-height:1.45}.pcm-checkrow{display:flex;align-items:center;gap:10px;font-size:var(--pps-text-md);font-weight:700;color:var(--pps-text)}.pcm-checkrow input{width:18px;height:18px;accent-color:var(--pps-primary)}.pcm-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.pcm-btn,.pcm-btn-primary{height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.pcm-btn:hover,.pcm-btn-primary:hover{transform:translateY(-1px)}.pcm-btn{background:#fff;color:var(--pps-text);border:1px solid #d1d5db}.pcm-btn:hover{background:#f8fafc}.pcm-btn-ghost{background:#fff}.pcm-btn-sm{height:34px;padding:0 10px;font-size:var(--fs-12)}.pcm-btn-primary{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;box-shadow:0 6px 14px #0284c72e}.pcm-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985)}.pcm-btn:disabled,.pcm-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pcm-searchbar{position:relative;margin-bottom:12px}.pcm-searchbar input{padding-left:40px}.pcm-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--pps-muted)}.pcm-table-wrap{overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);max-height:60vh;background:#fff;-webkit-overflow-scrolling:touch}.pcm-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.pcm-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pcm-table td{padding:12px;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;color:var(--pps-text)}.pcm-table tbody tr:nth-child(2n){background:#fafafa}.pcm-table tbody tr:hover{background:#f1f5f9}.pcm-empty{text-align:center;color:var(--pps-muted);padding:24px;font-size:var(--pps-text-md);font-weight:600}.pcm-status{min-height:26px;padding:4px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-12);font-weight:700;line-height:1.2;white-space:nowrap}.pcm-status.ok{background:#ecfdf5;color:#166534;border:1px solid #bbf7d0}.pcm-status.off{background:#f3f4f6;color:#475569;border:1px solid #d1d5db}@media(max-width:920px){.pcm-grid3{grid-template-columns:1fr 1fr}}@media(max-width:720px){.pcm-page{padding:12px;gap:12px}.pcm-summary,.pcm-grid2,.pcm-grid3{grid-template-columns:1fr}.pcm-title{font-size:var(--fs-18)}.pcm-card,.pcm-summary-card{padding:12px;border-radius:14px}.pcm-actions{flex-direction:column;align-items:stretch}.pcm-btn,.pcm-btn-primary{width:100%}.pcm-table th{font-size:var(--fs-12);padding:10px 8px}.pcm-table td{font-size:var(--fs-13);padding:10px 8px}}.pcbe-page{min-height:100%;width:100%;max-width:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:16px;overflow-x:hidden}.pcbe-page>*{min-width:0}.pcbe-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.pcbe-title{font-size:var(--pps-text-xl);font-weight:800;line-height:1.25}.pcbe-sub{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45}.pcbe-top-actions{display:flex;gap:8px;flex-wrap:wrap}.pcbe-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);padding:16px;box-shadow:var(--pps-shadow);display:flex;flex-direction:column;gap:14px;min-width:0}.pcbe-search{position:relative}.pcbe-search input{width:100%;height:40px;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;padding:0 12px 0 40px;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text);outline:none}.pcbe-search input::placeholder{color:#94a3b8;font-weight:500}.pcbe-search input:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pcbe-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--pps-muted)}.pcbe-btn,.pcbe-btn-submit{height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.pcbe-btn:hover,.pcbe-btn-submit:hover{transform:translateY(-1px)}.pcbe-btn{background:#fff;color:var(--pps-text);border:1px solid #d1d5db}.pcbe-btn:hover{background:#f8fafc}.pcbe-btn-submit{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;min-width:180px;box-shadow:0 6px 14px #0284c72e}.pcbe-btn-submit:hover{background:linear-gradient(135deg,#0369a1,#075985)}.pcbe-btn:disabled,.pcbe-btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pcbe-table-wrap{overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);max-height:70vh;background:#fff;-webkit-overflow-scrolling:touch}.pcbe-master-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.pcbe-master-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pcbe-master-table td{padding:12px;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;color:var(--pps-text)}.pcbe-master-table tbody tr{background:#fff}.pcbe-master-table tbody tr:nth-child(2n){background:#fafafa}.pcbe-master-table tbody tr:hover{background:#f1f5f9}.pcbe-master-table input,.pcbe-master-table select{width:100%;min-width:120px;height:38px;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;padding:0 10px;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text);outline:none}.pcbe-master-table input::placeholder{color:#94a3b8;font-weight:500}.pcbe-master-table input:focus,.pcbe-master-table select:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pcbe-master-table input:disabled,.pcbe-master-table select:disabled{opacity:.7;cursor:not-allowed;background:#f1f5f9}.pcbe-stock-badge{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.pcbe-stock-badge.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pcbe-stock-badge.warn{background:#fffbeb;border-color:#fde68a;color:#92400e}.pcbe-stock-badge.danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.pcbe-projected{font-weight:800;font-size:var(--fs-14);font-variant-numeric:tabular-nums}.pcbe-projected.ok{color:#166534}.pcbe-projected.danger{color:#b91c1c}.pcbe-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.pcbe-footnote{display:grid;gap:6px;font-size:var(--pps-text-sm);font-weight:500;color:var(--pps-muted-strong);line-height:1.45}.pcbe-empty{text-align:center;color:var(--pps-muted);padding:24px;font-size:var(--pps-text-md);font-weight:600}.mv-in{color:#166534;font-weight:700}.mv-out{color:#1d4ed8;font-weight:700}@media(max-width:980px){.pcbe-topbar{align-items:flex-start}.pcbe-top-actions{width:100%}.pcbe-btn,.pcbe-btn-submit{flex:1 1 auto}}@media(max-width:720px){.pcbe-page{padding:12px;gap:12px}.pcbe-title{font-size:var(--fs-18)}.pcbe-card{padding:12px;border-radius:14px}.pcbe-top-actions{flex-direction:column;align-items:stretch}.pcbe-btn,.pcbe-btn-submit{width:100%}.pcbe-table-wrap{max-height:none}.pcbe-master-table th{font-size:var(--fs-12);padding:10px 8px}.pcbe-master-table td{font-size:var(--fs-13);padding:10px 8px}.pcbe-master-table input,.pcbe-master-table select{height:36px;font-size:var(--fs-13);min-width:110px}.pcbe-stock-badge,.pcbe-projected{font-size:var(--fs-12)}}.pcqp-page{padding:16px;background:#f8fafc;min-height:100%;color:#0f172a;display:flex;flex-direction:column;gap:16px}.pcqp-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.pcqp-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-24);font-weight:900}.pcqp-sub{margin-top:4px;font-size:var(--fs-13);color:#64748b}.pcqp-inline-code{display:inline-flex;align-items:center;margin-left:8px;padding:2px 8px;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:var(--fs-12);font-weight:800}.pcqp-actions{display:flex;gap:8px;flex-wrap:wrap}.pcqp-btn,.pcqp-btn-primary{height:42px;padding:0 14px;border-radius:12px;font-size:var(--fs-14);font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none}.pcqp-btn{background:#fff;color:#0f172a;border:1px solid #d1d5db}.pcqp-btn:hover{background:#f8fafc}.pcqp-btn-primary{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff}.pcqp-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:16px;box-shadow:0 8px 24px #0f172a0f}.pcqp-form-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:12px}.pcqp-field label{display:block;margin-bottom:6px;font-size:var(--fs-13);font-weight:900;color:#0f172a}.pcqp-field input{width:100%;height:44px;border:1px solid #94a3b8;border-radius:12px;background:#f1f5f9;padding:0 12px;font-size:var(--fs-15);color:#0f172a;outline:none}.pcqp-field input:focus{background:#fff;border-color:#0284c7;box-shadow:0 0 0 3px #38bdf833}.pcqp-help{margin-top:12px;font-size:var(--fs-13);color:#475569;display:flex;flex-wrap:wrap;gap:8px}.pcqp-stats{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}.pcqp-stat{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:800;background:#f8fafc;border:1px solid #e2e8f0;color:#334155}.pcqp-stat.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pcqp-stat.warn{background:#fffbeb;border-color:#fde68a;color:#92400e}.pcqp-master-alert{margin-top:12px;display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;font-size:var(--fs-13);font-weight:800}.pcqp-print-sheet{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:16mm 12mm;box-shadow:0 8px 24px #0f172a0f;width:210mm;max-width:100%;margin:0 auto;box-sizing:border-box}.pcqp-print-head{margin-bottom:10mm;text-align:center}.pcqp-print-title{font-size:var(--fs-22);font-weight:900;color:#0f172a}.pcqp-print-sub{margin-top:4px;font-size:var(--fs-13);color:#64748b}.pcqp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8mm}.pcqp-label-card{border:1px solid #dbe3ee;border-radius:12px;background:#fff;padding:8px;min-height:72mm;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:6px;box-sizing:border-box;break-inside:avoid;page-break-inside:avoid}.pcqp-label-card.missing{border-color:#f59e0b;background:#fffbeb}.pcqp-qr-wrap{background:#fff;padding:6px;border-radius:10px;border:1px solid #e5e7eb;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.pcqp-uid{font-size:var(--fs-14);font-weight:900;color:#0f172a;text-align:center;line-height:1.2;word-break:break-word}.pcqp-name{font-size:var(--fs-11);font-weight:800;text-align:center;color:#0f172a;line-height:1.25;min-height:28px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pcqp-code{font-size:var(--fs-10);color:#64748b;text-align:center;font-weight:700;line-height:1.2;word-break:break-word}.pcqp-group{font-size:var(--fs-9);color:#0369a1;text-align:center;font-weight:800;line-height:1.2}.pcqp-empty{padding:24px;text-align:center;color:#64748b;font-size:var(--fs-14);font-weight:700}@media(max-width:920px){.pcqp-form-grid{grid-template-columns:1fr 1fr}.pcqp-print-sheet{width:100%;padding:16px}.pcqp-grid{grid-template-columns:repeat(2,1fr);gap:12px}}@media(max-width:640px){.pcqp-page{padding:12px}.pcqp-title{font-size:var(--fs-20)}.pcqp-form-grid,.pcqp-grid{grid-template-columns:1fr}}@media print{html,body{width:210mm;min-height:297mm;background:#fff!important;margin:0;padding:0}body{-webkit-print-color-adjust:exact;print-color-adjust:exact}.no-print{display:none!important}.pcqp-page{padding:0;margin:0;background:#fff}.pcqp-print-sheet{width:190mm;min-height:auto;border:none;box-shadow:none;border-radius:0;padding:0;margin:0 auto}.pcqp-print-head{margin-bottom:6mm}.pcqp-print-title{font-size:var(--fs-18)}.pcqp-print-sub{font-size:var(--fs-11)}.pcqp-grid{grid-template-columns:repeat(3,1fr);gap:6mm}.pcqp-label-card{min-height:63mm;border:1px solid #cbd5e1;border-radius:8px;padding:5mm 3mm}.pcqp-uid{font-size:var(--fs-15)}.pcqp-name{font-size:var(--fs-11);min-height:20px}.pcqp-code{font-size:var(--fs-11)}.pcqp-group{font-size:var(--fs-9)}}.pcd-page{min-height:100%;width:100%;max-width:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:16px;overflow-x:hidden}.pcd-page>*{min-width:0}.pcd-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.pcd-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25}.pcd-subtitle{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45}.pcd-topbar-actions{display:flex;gap:8px;flex-wrap:wrap}.pcd-action-btn,.pcd-refresh-btn{height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.pcd-action-btn:hover,.pcd-refresh-btn:hover{transform:translateY(-1px)}.pcd-action-btn.print{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;box-shadow:0 6px 14px #0284c72e}.pcd-refresh-btn{background:#fff;color:var(--pps-text);border:1px solid var(--pps-border-strong)}.pcd-refresh-btn:hover{background:#f8fafc}.pcd-refresh-btn:disabled,.pcd-action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pcd-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.pcd-summary-card,.pcd-toolbar-card,.pcd-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);padding:16px;box-shadow:var(--pps-shadow);min-width:0}.pcd-summary-card.success{border-color:#bbf7d0}.pcd-summary-card.warning{border-color:#fde68a}.pcd-summary-card.danger{border-color:#fecaca}.pcd-summary-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--pps-primary-soft);color:var(--pps-primary);margin-bottom:10px;font-size:var(--fs-16)}.pcd-summary-label{font-size:var(--pps-text-xs);color:var(--pps-muted);font-weight:700;line-height:1.4}.pcd-summary-value{margin-top:6px;font-size:var(--fs-22);font-weight:800;line-height:1.2;color:var(--pps-text);font-variant-numeric:tabular-nums}.pcd-summary-sub{margin-top:4px;font-size:var(--pps-text-xs);color:var(--pps-muted-strong);font-weight:600}.pcd-toolbar{display:grid;grid-template-columns:minmax(260px,1.5fr) 180px auto;gap:12px;align-items:center}.pcd-search{height:40px;display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:0 12px;color:var(--pps-muted-strong)}.pcd-search input,.pcd-toolbar select{width:100%;height:40px;border:none;background:transparent;outline:none;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text)}.pcd-search input::placeholder{color:#94a3b8;font-weight:500}.pcd-toolbar select{border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;padding:0 12px}.pcd-search:focus-within,.pcd-toolbar select:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pcd-filter-group{display:flex;gap:8px;flex-wrap:wrap}.pcd-chip{height:36px;padding:0 12px;border-radius:999px;border:1px solid #d1d5db;background:#fff;color:var(--pps-text);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .15s ease}.pcd-chip:hover{background:#f8fafc;transform:translateY(-1px)}.pcd-chip.active{background:#e0f2fe;border-color:#7dd3fc;color:#075985}.pcd-chip.active.success{background:#ecfdf5;border-color:#86efac;color:#166534}.pcd-chip.active.warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.pcd-chip.active.danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.pcd-table-wrap{overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);max-height:68vh;background:#fff;-webkit-overflow-scrolling:touch}.pcd-table,.pcd-print-table{width:100%;border-collapse:collapse}.pcd-table{min-width:1180px}.pcd-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pcd-table td{padding:12px;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;color:var(--pps-text)}.pcd-table tbody tr{background:#fff}.pcd-table tbody tr:nth-child(2n){background:#fafafa}.pcd-table tbody tr:hover{background:#f1f5f9}.pcd-table tbody tr.is-low_stock{background:#fffbeb}.pcd-table tbody tr.is-out_of_stock{background:#fef2f2}.pcd-table tbody tr.is-low_stock:hover{background:#fef3c7}.pcd-table tbody tr.is-out_of_stock:hover{background:#fee2e2}.pcd-item-name{color:var(--pps-text);font-size:var(--fs-14);font-weight:700;line-height:1.45;white-space:normal;min-width:240px;max-width:420px;word-break:break-word}.pcd-item-sub,.pcd-print-sub{margin-top:2px;font-size:var(--fs-12);color:var(--pps-muted);font-weight:500;line-height:1.35}.pcd-badge{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.pcd-badge.success{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pcd-badge.warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.pcd-badge.danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.pcd-empty{padding:28px;text-align:center;color:var(--pps-muted);font-size:var(--pps-text-md);font-weight:600}.qty,.mono{font-family:var(--pps-font-mono);font-size:inherit;font-weight:600;letter-spacing:0;font-variant-numeric:tabular-nums}.pcd-print-area{display:none}.pcd-print-sheet{background:#fff;padding:0;color:#0f172a;font-family:var(--pps-font-main)}.pcd-print-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.pcd-print-title{font-size:var(--fs-22);font-weight:900;line-height:1.25}.pcd-print-subtitle{margin-top:2px;font-size:var(--fs-13);color:var(--pps-muted-strong)}.pcd-print-meta-right{font-size:var(--fs-12);color:#334155;text-align:right;display:grid;gap:4px}.pcd-print-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px 14px;margin-bottom:12px;font-size:var(--fs-12);line-height:1.4}.pcd-print-table th,.pcd-print-table td{border:1px solid var(--pps-border-strong);padding:8px;font-size:var(--fs-12);line-height:1.4;vertical-align:top;font-family:var(--pps-font-main)}.pcd-print-table th{background:#f8fafc;font-weight:800;text-align:left}.pcd-print-summary{margin-top:12px;display:grid;gap:6px;font-size:var(--fs-12)}.pcd-print-signatures{margin-top:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.pcd-sign-box{text-align:center;font-size:var(--fs-12)}.pcd-sign-line{border-bottom:1px solid #0f172a;height:36px;margin-bottom:8px}.spin{animation:pcd-spin 1s linear infinite}@keyframes pcd-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:980px){.pcd-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pcd-toolbar{grid-template-columns:1fr}.pcd-topbar{align-items:flex-start}.pcd-topbar-actions{width:100%}.pcd-action-btn,.pcd-refresh-btn{flex:1 1 auto}}@media(max-width:640px){.pcd-page{padding:12px;gap:12px}.pcd-title{font-size:var(--fs-18)}.pcd-summary-grid{grid-template-columns:1fr}.pcd-summary-card,.pcd-toolbar-card,.pcd-card{padding:12px;border-radius:14px}.pcd-action-btn,.pcd-refresh-btn{width:100%}.pcd-table th{font-size:var(--fs-12);padding:10px 8px}.pcd-table td{font-size:var(--fs-13);padding:10px 8px}.pcd-badge{font-size:var(--fs-12)}}@media print{@page{size:A4 landscape;margin:10mm}body.chemical-dashboard-printing *{visibility:hidden}body.chemical-dashboard-printing .pcd-print-area,body.chemical-dashboard-printing .pcd-print-area *{visibility:visible}body.chemical-dashboard-printing .pcd-print-area{display:block;position:absolute;inset:0;background:#fff;padding:0;margin:0}.pcd-print-sheet{display:block}}.pspd-page{min-height:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:16px}.pspd-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.pspd-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25;color:var(--pps-text)}.pspd-subtitle{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45}.pspd-topbar-actions{display:flex;gap:8px;flex-wrap:wrap}.pspd-action-btn,.pspd-refresh-btn{height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.pspd-action-btn:hover,.pspd-refresh-btn:hover{transform:translateY(-1px)}.pspd-action-btn.print{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;box-shadow:0 6px 14px #0284c72e}.pspd-refresh-btn{background:#fff;color:var(--pps-text);border:1px solid var(--pps-border-strong)}.pspd-refresh-btn:hover{background:#f8fafc}.pspd-refresh-btn:disabled,.pspd-action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pspd-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.pspd-summary-card,.pspd-toolbar-card,.pspd-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);box-shadow:var(--pps-shadow)}.pspd-summary-card,.pspd-toolbar-card,.pspd-card{padding:16px}.pspd-summary-card.info{border-color:#bfdbfe}.pspd-summary-card.warning{border-color:#fde68a}.pspd-summary-card.danger{border-color:#fecaca}.pspd-summary-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--pps-primary-soft);color:var(--pps-primary);margin-bottom:10px;font-size:var(--fs-16)}.pspd-summary-label{font-size:var(--pps-text-xs);color:var(--pps-muted);font-weight:700;line-height:1.4}.pspd-summary-value{margin-top:6px;font-size:var(--fs-22);font-weight:800;line-height:1.2;color:var(--pps-text);font-variant-numeric:tabular-nums}.pspd-summary-sub{margin-top:4px;font-size:var(--pps-text-xs);color:var(--pps-muted-strong);font-weight:600}.pspd-toolbar{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;align-items:center}.pspd-search{height:40px;display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:0 12px;color:var(--pps-muted-strong)}.pspd-search input,.pspd-toolbar select{width:100%;height:40px;border:none;background:transparent;outline:none;font-size:var(--pps-text-md);font-weight:600;color:var(--pps-text);font-family:var(--pps-font-main)}.pspd-search input::placeholder{color:#94a3b8;font-weight:500}.pspd-toolbar select{border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;padding:0 12px}.pspd-search:focus-within,.pspd-toolbar select:focus{border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f;background:#fff}.pspd-filter-group{display:flex;gap:8px;flex-wrap:wrap}.pspd-chip{height:36px;padding:0 12px;border-radius:999px;border:1px solid #d1d5db;background:#fff;color:var(--pps-text);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease,transform .15s ease}.pspd-chip:hover{background:#f8fafc;transform:translateY(-1px)}.pspd-chip.active{background:#e0f2fe;border-color:#7dd3fc;color:#075985}.pspd-chip.active.success{background:#ecfdf5;border-color:#86efac;color:#166534}.pspd-chip.active.warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.pspd-chip.active.danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.pspd-chip.active.info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.pspd-chip.active.nonstock{background:#f1f5f9;border-color:#cbd5e1;color:#334155}.pspd-table-wrap{overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);max-height:68vh;background:#fff}.pspd-table,.pspd-print-table{width:100%;border-collapse:collapse}.pspd-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pspd-table td{padding:12px;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;color:var(--pps-text)}.pspd-table tbody tr{background:#fff}.pspd-table tbody tr:nth-child(2n){background:#fafafa}.pspd-table tbody tr:hover{background:#f1f5f9}.pspd-table tbody tr.is-low_stock{background:#fffbeb}.pspd-table tbody tr.is-out_of_stock{background:#fef2f2}.pspd-table tbody tr.is-low_stock:hover{background:#fef3c7}.pspd-table tbody tr.is-out_of_stock:hover{background:#fee2e2}.pspd-thumb-wrap{width:86px;min-width:86px;display:flex;align-items:center;justify-content:center}.pspd-thumb{width:68px;height:68px;object-fit:contain;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border);background:#fff;padding:4px}.pspd-thumb.noimg{width:68px;height:68px;border-radius:var(--pps-radius-sm);border:1px dashed var(--pps-border-strong);background:#f8fafc;color:var(--pps-muted);font-size:var(--fs-10);font-weight:800;line-height:1.25;display:flex;align-items:center;justify-content:center;text-align:center;padding:6px}.pspd-item-name{min-width:280px;max-width:420px;color:var(--pps-text);font-size:var(--fs-14);font-weight:600;font-family:var(--pps-font-main);line-height:1.5;white-space:normal}.pspd-badge{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;font-family:var(--pps-font-main);line-height:1.2;border:1px solid transparent;white-space:nowrap}.pspd-badge.success{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pspd-badge.warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.pspd-badge.danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.pspd-badge.stock{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.pspd-badge.nonstock{background:#f1f5f9;border-color:#cbd5e1;color:#334155}.pspd-empty{padding:28px;text-align:center;color:var(--pps-muted);font-size:var(--pps-text-md);font-weight:600}.pspd-print-area{display:none}.pspd-print-sheet{background:#fff;padding:0;color:#0f172a;font-family:var(--pps-font-main)}.pspd-print-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.pspd-print-title{font-size:var(--fs-22);font-weight:900;line-height:1.25}.pspd-print-subtitle{margin-top:2px;font-size:var(--fs-13);color:var(--pps-muted-strong)}.pspd-print-sub{margin-top:2px;font-size:var(--fs-12);color:var(--pps-muted)}.pspd-print-meta-right{font-size:var(--fs-12);color:#334155;text-align:right;display:grid;gap:4px}.pspd-print-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px 14px;margin-bottom:12px;font-size:var(--fs-12);line-height:1.4}.pspd-print-table th,.pspd-print-table td{border:1px solid var(--pps-border-strong);padding:8px;font-size:var(--fs-12);line-height:1.4;vertical-align:top;font-family:var(--pps-font-main)}.pspd-print-table th{background:#f8fafc;font-weight:800;text-align:left}.pspd-print-summary{margin-top:12px;display:grid;gap:6px;font-size:var(--fs-12)}.pspd-print-signatures{margin-top:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.pspd-sign-box{text-align:center;font-size:var(--fs-12)}.pspd-sign-line{border-bottom:1px solid #0f172a;height:36px;margin-bottom:8px}.spin{animation:pspd-spin 1s linear infinite}@keyframes pspd-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1280px){.pspd-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pspd-toolbar{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}}@media(max-width:980px){.pspd-topbar{align-items:flex-start}.pspd-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pspd-toolbar{grid-template-columns:1fr}.pspd-topbar-actions{width:100%}.pspd-action-btn,.pspd-refresh-btn{flex:1 1 auto}}@media(max-width:640px){.pspd-page{padding:12px;gap:12px}.pspd-title{font-size:var(--fs-18)}.pspd-summary-grid{grid-template-columns:1fr}.pspd-summary-card,.pspd-toolbar-card,.pspd-card{padding:12px;border-radius:14px}.pspd-table th{font-size:var(--fs-12);padding:10px 8px}.pspd-table td{font-size:var(--fs-13);padding:10px 8px}.qty,.mono,.pspd-item-name{font-size:var(--fs-13)}.pspd-badge{font-size:var(--fs-12)}.pspd-thumb-wrap{width:72px;min-width:72px}.pspd-thumb,.pspd-thumb.noimg{width:58px;height:58px}.pspd-item-name{min-width:220px}}@media print{@page{size:A4 landscape;margin:10mm}body.pspd-printing *{visibility:hidden}body.pspd-printing .pspd-print-area,body.pspd-printing .pspd-print-area *{visibility:visible}body.pspd-printing .pspd-print-area{display:block;position:absolute;inset:0;background:#fff;padding:0;margin:0}.pspd-print-sheet{display:block}}.pspe-page{min-height:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:16px;width:100%;max-width:100%;overflow-x:hidden}.pspe-page>*{min-width:0}.pspe-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.pspe-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25}.pspe-subtitle{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45}.pspe-top-actions{display:flex;gap:8px;flex-wrap:wrap}.pspe-layout{display:grid;grid-template-columns:minmax(360px,420px) minmax(0,1fr);gap:16px;min-height:0}.pspe-left,.pspe-right{min-width:0}.pspe-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);padding:16px;box-shadow:var(--pps-shadow);display:flex;flex-direction:column;gap:14px;min-height:0}.pspe-card-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.35}.pspe-search{height:40px;display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:0 12px;color:var(--pps-muted-strong)}.pspe-search input{width:100%;border:none;background:transparent;outline:none;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text)}.pspe-search input::placeholder{color:#94a3b8;font-weight:500}.pspe-search:focus-within{border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f;background:#fff}.pspe-filter-row{display:grid;grid-template-columns:minmax(0,1fr) 180px;gap:12px;align-items:end}.pspe-filter-field,.pspe-field{display:grid;gap:6px}.pspe-filter-field label,.pspe-field label{font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.pspe-filter-field select,.pspe-filter-field input,.pspe-field input,.pspe-field textarea{width:100%;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;padding:0 12px;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text);outline:none}.pspe-filter-field select,.pspe-filter-field input,.pspe-field input{height:40px}.pspe-field textarea{min-height:96px;resize:vertical;padding-top:10px;padding-bottom:10px;line-height:1.5}.pspe-filter-field select:focus,.pspe-filter-field input:focus,.pspe-field input:focus,.pspe-field textarea:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pspe-filter-field.read-only input,.pspe-field input[disabled],.pspe-field input[readonly],.pspe-field textarea[disabled]{color:var(--pps-text);opacity:1;-webkit-text-fill-color:var(--pps-text);background:#f1f5f9}.pspe-list{display:grid;gap:10px;overflow:auto;max-height:68vh;min-height:0;padding-right:2px}.pspe-item{width:100%;text-align:left;border:1px solid var(--pps-border);background:#fff;border-radius:var(--pps-radius-md);padding:12px;display:grid;grid-template-columns:72px minmax(0,1fr);gap:12px;cursor:pointer;font-family:var(--pps-font-main);color:var(--pps-text);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .15s ease}.pspe-item:hover{background:#f8fafc;border-color:var(--pps-border-strong);transform:translateY(-1px)}.pspe-item:active{transform:translateY(1px)}.pspe-item.active{border-color:#7dd3fc;background:#f0f9ff;box-shadow:0 0 0 3px #38bdf826}.pspe-item-thumb-wrap{display:flex;align-items:flex-start;justify-content:center}.pspe-item-thumb,.pspe-selected-thumb{width:72px;height:72px;object-fit:contain;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border);background:#fff;padding:4px}.pspe-item-thumb.noimg,.pspe-selected-thumb.noimg{display:flex;align-items:center;justify-content:center;color:var(--pps-muted);border:1px dashed var(--pps-border-strong);background:#f8fafc}.pspe-item-content{min-width:0}.pspe-item-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.pspe-item-code{font-size:var(--pps-text-sm);font-weight:700;color:var(--pps-text)}.pspe-item-name{margin-top:6px;font-size:var(--pps-text-md);font-weight:700;color:var(--pps-text);white-space:normal;line-height:1.45;word-break:break-word}.pspe-item-meta{margin-top:6px;display:flex;gap:6px;flex-wrap:wrap;color:var(--pps-muted);font-size:var(--pps-text-xs);font-weight:500;line-height:1.35}.pspe-item-stock{margin-top:8px;color:var(--pps-text-soft);font-size:var(--pps-text-xs);font-weight:700}.pspe-badge,.pspe-status-dot,.pspe-inline-status{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid transparent;white-space:nowrap;line-height:1.2}.pspe-badge{min-height:24px;padding:4px 9px;font-size:var(--fs-12);font-weight:700}.pspe-status-dot{min-height:22px;padding:3px 8px;font-size:var(--fs-12);font-weight:700}.pspe-inline-status{width:fit-content;min-height:26px;padding:4px 10px;font-size:var(--fs-12);font-weight:700}.pspe-badge.stock{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.pspe-badge.nonstock{background:#f1f5f9;border-color:#cbd5e1;color:#334155}.pspe-status-dot.ok,.pspe-inline-status.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pspe-status-dot.warning,.pspe-inline-status.warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.pspe-status-dot.danger,.pspe-inline-status.danger{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.pspe-selected{display:grid;grid-template-columns:100px minmax(0,1fr);gap:16px;align-items:flex-start;padding:14px;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);background:#fff}.pspe-selected-thumb-wrap{display:flex;justify-content:center}.pspe-selected-thumb{width:96px;height:96px}.pspe-selected-info{display:grid;gap:8px}.pspe-selected-row{display:grid;grid-template-columns:130px minmax(0,1fr);gap:10px;align-items:start}.pspe-selected-row .label{color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:700}.pspe-selected-row .value{color:var(--pps-text);font-size:var(--pps-text-md);font-weight:700;word-break:break-word}.pspe-stock-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.pspe-stock-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:var(--pps-radius-md);padding:14px}.pspe-stock-box .k{font-size:var(--pps-text-xs);font-weight:700;color:var(--pps-muted)}.pspe-stock-box .v{margin-top:6px;font-size:var(--fs-22);font-weight:800;line-height:1.2;color:var(--pps-text);font-variant-numeric:tabular-nums}.pspe-stock-box .v.danger,.danger{color:#b91c1c}.pspe-form{display:grid;gap:12px}.pspe-grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.pspe-required{color:#dc2626}.pspe-field-help{margin-top:6px;font-size:var(--pps-text-xs);color:var(--pps-muted);line-height:1.45}.pspe-seg{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.pspe-seg-btn{min-height:42px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border-strong);background:#fff;color:var(--pps-text);font-weight:700;font-size:var(--pps-text-md);font-family:var(--pps-font-main);display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .15s ease}.pspe-seg-btn:hover{background:#f8fafc;transform:translateY(-1px)}.pspe-seg-btn:active{transform:translateY(1px)}.pspe-seg-btn.active.in{background:#ecfdf5;border-color:#86efac;color:#166534}.pspe-seg-btn.active.out{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}.pspe-seg-btn.active.adjust{background:#fff7ed;border-color:#fdba74;color:#9a3412}.pspe-picker,.pspe-picker-input-wrap{position:relative}.pspe-picker-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--pps-muted);pointer-events:none}.pspe-picker .pspe-picker-input-wrap input{padding-left:38px;padding-right:40px}.pspe-picker-caret{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--pps-muted);pointer-events:none}.pspe-picker-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:28px;height:28px;border:none;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#e2e8f0;color:var(--pps-text-soft);cursor:pointer}.pspe-picker-clear:hover{background:#cbd5e1}.pspe-picker-dropdown{margin-top:8px;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#fff;box-shadow:0 12px 24px #0f172a1f;max-height:260px;overflow:auto;z-index:20}.pspe-picker-empty{padding:12px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:600}.pspe-picker-item{width:100%;text-align:left;border:none;background:#fff;color:var(--pps-text);border-bottom:1px solid #f1f5f9;padding:10px 12px;cursor:pointer;display:grid;gap:4px;font-family:var(--pps-font-main)}.pspe-picker-item:last-child{border-bottom:none}.pspe-picker-item:hover{background:#f8fafc}.pspe-picker-item.active{background:#eff6ff}.pspe-picker-item-main{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-sm);font-weight:700}.pspe-actions{display:flex;gap:10px;flex-wrap:wrap}.pspe-btn,.pspe-btn-primary{height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.pspe-btn:hover,.pspe-btn-primary:hover{transform:translateY(-1px)}.pspe-btn{background:#fff;color:var(--pps-text);border:1px solid #d1d5db}.pspe-btn:hover{background:#f8fafc}.pspe-btn-primary{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;box-shadow:0 6px 14px #0284c72e}.pspe-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985)}.pspe-btn:disabled,.pspe-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pspe-empty{padding:24px;text-align:center;color:var(--pps-muted);font-size:var(--pps-text-md);font-weight:600}.pspe-hint{font-size:var(--pps-text-xs);color:var(--pps-muted);line-height:1.5}@media(max-width:1180px){.pspe-layout{grid-template-columns:1fr}.pspe-list{max-height:520px}}@media(max-width:860px){.pspe-stock-summary,.pspe-grid2,.pspe-seg,.pspe-filter-row,.pspe-selected{grid-template-columns:1fr}.pspe-selected-thumb-wrap{justify-content:flex-start}.pspe-selected-row{grid-template-columns:1fr;gap:2px}}@media(max-width:640px){.pspe-page{padding:12px;gap:12px}.pspe-title{font-size:var(--fs-18)}.pspe-card{padding:12px;border-radius:14px}.pspe-top-actions,.pspe-actions,.pspe-btn,.pspe-btn-primary{width:100%}.pspe-item{grid-template-columns:1fr}.pspe-item-thumb-wrap{justify-content:flex-start}.pspe-item-thumb{width:64px;height:64px}.pspe-selected-thumb{width:86px;height:86px}.pspe-stock-box .v{font-size:var(--fs-20)}}.pspm-page{min-height:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:16px;width:100%;max-width:100%;overflow-x:hidden}.pspm-page>*{min-width:0}.pspm-topbar{display:flex;gap:12px;align-items:flex-end;justify-content:space-between;flex-wrap:wrap}.pspm-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25}.pspm-sub{margin-top:4px;font-size:var(--pps-text-sm);font-weight:500;color:var(--pps-muted);line-height:1.45}.pspm-topbar-actions,.pspm-actions,.pspm-upload-row{display:flex;gap:10px;flex-wrap:wrap}.pspm-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.pspm-summary-card,.pspm-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);box-shadow:var(--pps-shadow)}.pspm-summary-card,.pspm-card{padding:16px}.pspm-summary-label{font-size:var(--pps-text-xs);font-weight:700;color:var(--pps-muted);line-height:1.4}.pspm-summary-value{margin-top:6px;font-size:var(--fs-22);font-weight:800;line-height:1.2;color:var(--pps-text);font-variant-numeric:tabular-nums}.pspm-summary-value.ok{color:#166534}.pspm-summary-value.warn{color:#92400e}.pspm-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.pspm-card-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.35}.pspm-form{display:grid;gap:12px}.pspm-grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.pspm-grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.pspm-field label,.pspm-filter-field label{display:block;margin-bottom:6px;font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.pspm-field input,.pspm-field select,.pspm-filter-field select,.pspm-filter-field input,.pspm-searchbar input{width:100%;height:40px;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;padding:0 12px;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text);outline:none}.pspm-field input::placeholder,.pspm-searchbar input::placeholder{color:#94a3b8;font-weight:500}.pspm-field input:focus,.pspm-field select:focus,.pspm-filter-field select:focus,.pspm-filter-field input:focus,.pspm-searchbar input:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pspm-field input:disabled,.pspm-field select:disabled{opacity:.75;cursor:not-allowed;background:#f1f5f9}.pspm-help,.pspm-file-meta{margin-top:6px;font-size:var(--pps-text-xs);color:var(--pps-muted);line-height:1.45;white-space:normal;word-break:break-word}.pspm-checkrow{display:flex;align-items:center;gap:10px;font-size:var(--pps-text-md);font-weight:700;color:var(--pps-text)}.pspm-checkrow input{width:18px;height:18px;accent-color:var(--pps-primary)}.pspm-btn,.pspm-btn-primary,.pspm-upload-btn,.pspm-clear-btn{height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.pspm-btn:hover,.pspm-btn-primary:hover,.pspm-upload-btn:hover,.pspm-clear-btn:hover{transform:translateY(-1px)}.pspm-btn,.pspm-clear-btn{background:#fff;color:var(--pps-text);border:1px solid #d1d5db}.pspm-btn:hover,.pspm-clear-btn:hover{background:#f8fafc}.pspm-btn-primary{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;box-shadow:0 6px 14px #0284c72e}.pspm-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985)}.pspm-btn-etl{background:linear-gradient(135deg,#0f766e,#0d9488);color:#fff;border:none;box-shadow:0 6px 14px #0d94882e}.pspm-btn-etl:hover{background:linear-gradient(135deg,#115e59,#0f766e)}.pspm-btn-ghost{background:#fff}.pspm-btn-sm{height:34px;padding:0 10px;font-size:var(--fs-12)}.pspm-upload-btn{position:relative;overflow:hidden;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;box-shadow:0 6px 14px #0284c72e}.pspm-upload-btn.is-loading{opacity:.75;cursor:wait}.pspm-clear-btn{color:#334155}.pspm-btn:disabled,.pspm-btn-primary:disabled,.pspm-upload-btn:disabled,.pspm-clear-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pspm-filterbar{display:grid;grid-template-columns:minmax(0,1fr) 220px 180px;gap:12px;align-items:end;margin-bottom:12px}.pspm-filter-field{display:grid;gap:6px}.pspm-filter-readonly input{color:var(--pps-text);opacity:1;-webkit-text-fill-color:var(--pps-text);background:#f1f5f9}.pspm-searchbar{position:relative}.pspm-searchbar input{padding-left:40px}.pspm-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--pps-muted)}.pspm-table-wrap{overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);max-height:60vh;background:#fff;-webkit-overflow-scrolling:touch}.pspm-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0}.pspm-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pspm-table td{padding:12px;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;color:var(--pps-text)}.pspm-table tbody tr:nth-child(2n){background:#fafafa}.pspm-table tbody tr:hover{background:#f1f5f9}.pspm-thumb-wrap{width:68px;min-width:68px;display:flex;align-items:center;justify-content:center}.pspm-thumb{width:56px;height:56px;object-fit:contain;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border);background:#fff;padding:4px;cursor:zoom-in}.pspm-thumb.noimg{width:56px;height:56px;display:flex;align-items:center;justify-content:center;color:var(--pps-muted);border:1px dashed var(--pps-border-strong);background:#f8fafc;cursor:default}.pspm-series{white-space:normal;min-width:280px;max-width:420px;font-weight:600;line-height:1.5;word-break:break-word}.pspm-empty{text-align:center;color:var(--pps-muted);padding:24px;font-size:var(--pps-text-md);font-weight:600}.pspm-badge,.pspm-status{min-height:26px;padding:4px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-12);font-weight:700;line-height:1.2;white-space:nowrap}.pspm-badge.stock{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.pspm-badge.nonstock{background:#f1f5f9;color:#334155;border:1px solid #cbd5e1}.pspm-status.ok{background:#ecfdf5;color:#166534;border:1px solid #bbf7d0}.pspm-status.off{background:#f3f4f6;color:#475569;border:1px solid #d1d5db}.pspm-image-preview-box{border:1px dashed var(--pps-border-strong);border-radius:var(--pps-radius-md);background:#f8fafc;padding:12px}.pspm-image-preview-inner{display:grid;gap:10px;justify-items:start}.pspm-preview{width:160px;height:160px;object-fit:contain;border-radius:var(--pps-radius-md);border:1px solid var(--pps-border);background:#fff;padding:6px;cursor:zoom-in}.pspm-preview.noimg{width:160px;height:160px;display:flex;align-items:center;justify-content:center;border-radius:var(--pps-radius-md);border:1px dashed var(--pps-border-strong);background:#f8fafc;color:var(--pps-muted);font-size:var(--fs-28);cursor:default}.pspm-preview-zoom{height:36px;padding:0 12px;border-radius:var(--pps-radius-sm);border:1px solid #d1d5db;background:#fff;font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;gap:8px;cursor:pointer}.pspm-preview-zoom:hover{background:#f8fafc}.pspm-lightbox{position:fixed;inset:0;background:#020617b8;display:flex;align-items:center;justify-content:center;padding:18px;z-index:9999}.pspm-lightbox-dialog{width:min(920px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:var(--pps-radius-lg);padding:14px;box-shadow:0 20px 60px #00000047}.pspm-lightbox-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}.pspm-lightbox-title{font-size:var(--pps-text-lg);font-weight:800;color:var(--pps-text);line-height:1.35}.pspm-lightbox-body{display:flex;justify-content:center;align-items:center}.pspm-lightbox-image{max-width:100%;max-height:72vh;object-fit:contain;border-radius:var(--pps-radius-md);background:#fff}.pspm-lightbox-image.noimg{width:280px;height:280px;display:flex;align-items:center;justify-content:center;border:1px dashed var(--pps-border-strong);background:#f8fafc;color:var(--pps-muted);font-size:var(--fs-36)}@media(max-width:920px){.pspm-grid3{grid-template-columns:1fr 1fr}.pspm-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.pspm-filterbar{grid-template-columns:1fr}}@media(max-width:720px){.pspm-page{padding:12px;gap:12px}.pspm-summary,.pspm-grid2,.pspm-grid3{grid-template-columns:1fr}.pspm-title{font-size:var(--fs-18)}.pspm-card,.pspm-summary-card{padding:12px;border-radius:14px}.pspm-actions,.pspm-upload-row,.pspm-topbar-actions{flex-direction:column;align-items:stretch}.pspm-btn,.pspm-btn-primary,.pspm-upload-btn,.pspm-clear-btn{width:100%}.pspm-table th{font-size:var(--fs-12);padding:10px 8px}.pspm-table td{font-size:var(--fs-13);padding:10px 8px}.pspm-preview,.pspm-preview.noimg{width:100%;max-width:220px;height:auto;aspect-ratio:1 / 1}.pspm-lightbox{padding:12px}.pspm-lightbox-dialog{padding:12px;border-radius:14px}}.psqp-page{padding:16px;background:#f8fafc;min-height:100%;color:#0f172a;display:flex;flex-direction:column;gap:16px}.psqp-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.psqp-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-24);font-weight:900}.psqp-sub{margin-top:4px;font-size:var(--fs-13);color:#64748b;line-height:1.5}.psqp-inline-code{display:inline-flex;align-items:center;margin-left:8px;padding:2px 8px;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:var(--fs-12);font-weight:800}.psqp-actions{display:flex;gap:8px;flex-wrap:wrap}.psqp-btn,.psqp-btn-primary{height:42px;padding:0 14px;border-radius:12px;font-size:var(--fs-14);font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none}.psqp-btn{background:#fff;color:#0f172a;border:1px solid #d1d5db}.psqp-btn:hover{background:#f8fafc}.psqp-btn-primary{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff}.psqp-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:16px;box-shadow:0 8px 24px #0f172a0f}.psqp-form-grid{display:grid;grid-template-columns:2fr 2fr 1fr;gap:12px}.psqp-form-grid-2{margin-top:12px;grid-template-columns:1fr 1fr}.psqp-field label{display:block;margin-bottom:6px;font-size:var(--fs-13);font-weight:900;color:#0f172a}.psqp-field input,.psqp-field select{width:100%;height:44px;border:1px solid #94a3b8;border-radius:12px;background:#f1f5f9;padding:0 12px;font-size:var(--fs-15);color:#0f172a;outline:none}.psqp-field input:focus,.psqp-field select:focus{background:#fff;border-color:#0284c7;box-shadow:0 0 0 3px #38bdf833}.psqp-field input[readonly]{color:#0f172a;opacity:1;-webkit-text-fill-color:#0f172a}.psqp-search{display:flex;align-items:center;gap:8px;border:1px solid #94a3b8;border-radius:12px;background:#f1f5f9;padding:0 12px;height:44px}.psqp-search input{border:none;background:transparent;padding:0;height:auto;box-shadow:none}.psqp-help{margin-top:12px;font-size:var(--fs-13);color:#475569;display:flex;flex-wrap:wrap;gap:8px}.psqp-stats{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}.psqp-stat{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:800;background:#f8fafc;border:1px solid #e2e8f0;color:#334155}.psqp-stat.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.psqp-master-alert{margin-top:12px;display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;font-size:var(--fs-13);font-weight:800}.psqp-print-sheet{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:16mm 12mm;box-shadow:0 8px 24px #0f172a0f;width:210mm;max-width:100%;margin:0 auto;box-sizing:border-box}.psqp-print-head{margin-bottom:10mm;text-align:center}.psqp-print-title{font-size:var(--fs-22);font-weight:900;color:#0f172a}.psqp-print-sub{margin-top:4px;font-size:var(--fs-13);color:#64748b}.psqp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8mm}.psqp-label-card{border:1px solid #dbe3ee;border-radius:12px;background:#fff;padding:8px;min-height:76mm;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:6px;box-sizing:border-box;break-inside:avoid;page-break-inside:avoid}.psqp-qr-wrap{background:#fff;padding:6px;border-radius:10px;border:1px solid #e5e7eb;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.psqp-autoid{font-size:var(--fs-14);font-weight:900;color:#0f172a;text-align:center;line-height:1.2;word-break:break-word}.psqp-name{font-size:var(--fs-11);font-weight:800;text-align:center;color:#0f172a;line-height:1.25;min-height:28px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.psqp-code{font-size:var(--fs-10);color:#64748b;text-align:center;font-weight:700;line-height:1.2;word-break:break-word}.psqp-brand{font-size:var(--fs-10);color:#334155;text-align:center;font-weight:700;line-height:1.2}.psqp-group{font-size:var(--fs-9);color:#0369a1;text-align:center;font-weight:800;line-height:1.2}.psqp-location{font-size:var(--fs-9);color:#166534;background:#ecfdf5;border:1px solid #bbf7d0;border-radius:999px;padding:2px 8px;text-align:center;font-weight:900;line-height:1.2}.psqp-empty{padding:24px;text-align:center;color:#64748b;font-size:var(--fs-14);font-weight:700}@media(max-width:920px){.psqp-form-grid,.psqp-form-grid-2{grid-template-columns:1fr}.psqp-print-sheet{width:100%;padding:16px}.psqp-grid{grid-template-columns:repeat(2,1fr);gap:12px}}@media(max-width:640px){.psqp-page{padding:12px}.psqp-title{font-size:var(--fs-20)}.psqp-grid{grid-template-columns:1fr}}@page{size:A4 portrait;margin:10mm}@media print{html,body{width:210mm;min-height:297mm;background:#fff!important;margin:0;padding:0}body{-webkit-print-color-adjust:exact;print-color-adjust:exact}.no-print{display:none!important}.psqp-page{padding:0;margin:0;background:#fff}.psqp-print-sheet{width:190mm;min-height:auto;border:none;box-shadow:none;border-radius:0;padding:0;margin:0 auto}.psqp-print-head{margin-bottom:6mm}.psqp-print-title{font-size:var(--fs-18)}.psqp-print-sub{font-size:var(--fs-11)}.psqp-grid{grid-template-columns:repeat(3,1fr);gap:6mm}.psqp-label-card{min-height:66mm;border:1px solid #cbd5e1;border-radius:8px;padding:5mm 3mm}.psqp-autoid{font-size:var(--fs-15)}.psqp-name{font-size:var(--fs-11);min-height:20px}.psqp-code,.psqp-brand{font-size:var(--fs-11)}.psqp-group,.psqp-location{font-size:var(--fs-9)}}:root{--pps-font-main: "Inter", "Noto Sans Thai", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--pps-bg: #f8fafc;--pps-card: #ffffff;--pps-border: #e5e7eb;--pps-border-strong: #cbd5e1;--pps-text: #0f172a;--pps-text-soft: #334155;--pps-muted: #64748b;--pps-muted-strong: #475569;--pps-primary: #0369a1;--pps-radius-sm: 10px;--pps-radius-md: 14px;--pps-shadow: 0 4px 16px rgba(15, 23, 42, .05);--pps-text-xs: 12px;--pps-text-sm: 13px;--pps-text-md: 14px;--pps-text-lg: 16px}.psp-page{min-height:100svh;min-height:-webkit-fill-available;width:100%;max-width:100%;padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));padding-left:calc(12px + env(safe-area-inset-left,0px));padding-right:calc(12px + env(safe-area-inset-right,0px));background:var(--pps-bg);color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);color-scheme:light;font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:12px;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.psp-page *{min-width:0}.psp-page a,.psp-page button,.psp-page input,.psp-page textarea,.psp-page select,.psp-page label,.psp-page span,.psp-page div,.psp-page p,.psp-page th,.psp-page td,.psp-page strong,.psp-page em{-webkit-text-fill-color:currentColor}.psp-page button,.psp-page input,.psp-page textarea,.psp-page select{font:inherit;color:inherit;font-family:inherit}.psp-topbar,.psp-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);box-shadow:var(--pps-shadow);color:var(--pps-text)}.psp-topbar{display:flex;flex-direction:column;gap:8px;padding:12px}.psp-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.3;color:var(--pps-text)}.psp-sub{margin-top:2px;font-size:var(--pps-text-xs);font-weight:500;color:var(--pps-muted);line-height:1.45}.psp-actions{display:flex;gap:8px;flex-wrap:wrap}.psp-card{padding:12px}.psp-alert{display:flex;align-items:center;gap:10px;background:#fff7ed;border-color:#fed7aa;color:#9a3412;font-weight:700}.psp-hero{display:grid;gap:10px}.psp-uid-label{display:flex;align-items:center;gap:6px;font-size:var(--pps-text-xs);font-weight:800;color:var(--pps-muted-strong)}.psp-uid-val{margin-top:2px;font-size:var(--pps-text-lg);font-weight:800;color:var(--pps-text)}.psp-thumb-zone{display:flex;justify-content:center;align-items:center}.psp-thumb{width:120px;height:120px;object-fit:contain;border-radius:var(--pps-radius-md);border:1px solid var(--pps-border);background:#fff;padding:8px}.psp-thumb.noimg{width:120px;height:120px;display:flex;align-items:center;justify-content:center;border-radius:var(--pps-radius-md);border:1px dashed var(--pps-border-strong);background:#f8fafc;color:var(--pps-muted);font-size:var(--fs-24)}.psp-type{display:flex;gap:8px;flex-wrap:wrap}.psp-pill2,.psp-pill3{min-height:26px;display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:var(--pps-text-xs);line-height:1.2;white-space:nowrap}.psp-pill2{font-weight:700;border:1px solid var(--pps-border);background:#f8fafc;color:var(--pps-text)}.psp-pill2.stock{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.psp-pill2.nonstock{background:#f1f5f9;border-color:#cbd5e1;color:#334155}.psp-pill3{font-weight:800;border:1px solid #bbf7d0;background:#ecfdf5;color:#166534}.psp-ref{border:1px dashed var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:10px;background:#f8fafc}.psp-ref-title{margin-bottom:8px;display:flex;align-items:center;gap:6px;font-size:var(--pps-text-xs);font-weight:800;color:var(--pps-text-soft)}.psp-ref-row{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-top:1px solid var(--pps-border)}.psp-ref-row:first-of-type{border-top:none}.psp-ref-row .k{color:var(--pps-muted);font-weight:700;font-size:var(--pps-text-xs)}.psp-ref-row .v{font-weight:800;color:var(--pps-text);text-align:right;word-break:break-word}.psp-stock-card{display:grid;gap:10px}.psp-stock-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.psp-stock-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-md);font-weight:800;color:var(--pps-text)}.psp-stock-badge{min-height:28px;padding:4px 10px;border-radius:999px;display:inline-flex;align-items:center;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.psp-stock-badge.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.psp-stock-badge.warn{background:#fffbeb;border-color:#fde68a;color:#92400e}.psp-stock-badge.danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.psp-stock-main{display:flex;align-items:center;justify-content:flex-start}.psp-stock-value{font-size:var(--fs-28);font-weight:800;line-height:1.1;color:var(--pps-text);font-variant-numeric:tabular-nums}.psp-stock-help{font-size:var(--pps-text-xs);font-weight:500;color:var(--pps-muted);line-height:1.45}.psp-form{display:grid;gap:10px;min-height:0}.psp-grid2{display:grid;gap:10px}.psp-field{min-width:0}.psp-field label{display:block;margin-bottom:6px;font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.psp-required{color:#dc2626}.psp-field input,.psp-field textarea{width:100%;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);font-size:var(--fs-16);font-weight:600;font-family:var(--pps-font-main);outline:none;-webkit-appearance:none;appearance:none;box-shadow:none}.psp-field input{height:44px;padding:0 12px}.psp-field textarea{min-height:92px;padding:10px 12px;line-height:1.5;resize:vertical}.psp-field input::placeholder,.psp-field textarea::placeholder{color:#94a3b8;-webkit-text-fill-color:#94a3b8;font-weight:500}.psp-field input:focus,.psp-field textarea:focus{background-color:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.psp-field input:disabled,.psp-field textarea:disabled{color:var(--pps-text)!important;opacity:1!important;-webkit-text-fill-color:var(--pps-text)!important;background:#f1f5f9;cursor:not-allowed}.psp-seg{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.psp-seg-btn{min-height:44px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border-strong);background:#fff;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);font-weight:800;font-size:var(--pps-text-md);font-family:var(--pps-font-main);display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;-webkit-appearance:none;appearance:none;text-shadow:none;transition:transform .15s ease,background .15s ease,border-color .15s ease}.psp-seg-btn:hover{background:#f8fafc;transform:translateY(-1px)}.psp-seg-btn:active{transform:translateY(1px)}.psp-seg-btn.active.in{background:#ecfdf5;border-color:#86efac;color:#166534;-webkit-text-fill-color:#166534}.psp-seg-btn.active.out{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8;-webkit-text-fill-color:#1d4ed8}.psp-seg-btn.active.adjust{background:#fff7ed;border-color:#fdba74;color:#9a3412;-webkit-text-fill-color:#9a3412}.psp-btn,.psp-btn-primary,.psp-link{min-height:40px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-appearance:none;appearance:none;text-shadow:none;white-space:nowrap;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.psp-btn{border:1px solid var(--pps-border);background:#fff;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text)}.psp-btn:hover,.psp-link:hover{background:#f8fafc;transform:translateY(-1px)}.psp-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.psp-btn-primary{width:100%;min-height:46px;border:none;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff!important;-webkit-text-fill-color:#ffffff!important;font-size:var(--pps-text-md);box-shadow:0 6px 14px #0284c72e}.psp-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985);transform:translateY(-1px)}.psp-btn-primary:disabled{background:#94a3b8;color:#fff!important;-webkit-text-fill-color:#ffffff!important;cursor:not-allowed;transform:none;box-shadow:none}.psp-picker,.psp-picker-input-wrap{position:relative}.psp-picker-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--pps-muted);pointer-events:none}.psp-picker .psp-picker-input-wrap input{padding-left:38px;padding-right:40px}.psp-picker-caret{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--pps-muted);pointer-events:none}.psp-picker-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:28px;height:28px;border:none;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#e2e8f0;color:var(--pps-text-soft);cursor:pointer}.psp-picker-clear:hover{background:#cbd5e1}.psp-picker-help{margin-top:6px;font-size:var(--pps-text-xs);color:var(--pps-muted);line-height:1.45}.psp-picker-dropdown{margin-top:8px;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#fff;box-shadow:0 12px 24px #0f172a1f;max-height:260px;overflow:auto;z-index:20}.psp-picker-empty{padding:12px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:600}.psp-picker-item{width:100%;text-align:left;border:none;background:#fff;color:var(--pps-text);border-bottom:1px solid #f1f5f9;padding:10px 12px;cursor:pointer;display:grid;gap:4px;font-family:var(--pps-font-main)}.psp-picker-item:last-child{border-bottom:none}.psp-picker-item:hover{background:#f8fafc}.psp-picker-item.active{background:#eff6ff}.psp-picker-item-main{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-sm);font-weight:700}.psp-picker-item-sub{font-size:var(--pps-text-xs);color:var(--pps-muted);padding-left:22px}.psp-who{margin-top:6px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.psp-muted{color:var(--pps-muted);font-size:var(--pps-text-xs)}.psp-history-head{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.psp-history-title{font-size:var(--pps-text-md);font-weight:800;color:var(--pps-text)}.psp-history-sub{font-size:var(--pps-text-xs);color:var(--pps-muted)}.psp-table-wrap{overflow:auto;max-height:55vh;border:1px solid var(--pps-border);border-radius:var(--pps-radius-sm);-webkit-overflow-scrolling:touch;overscroll-behavior:contain;min-height:0;background:#fff}.psp-table{width:max-content;min-width:980px;border-collapse:separate;border-spacing:0;color:var(--pps-text)}.psp-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);border-bottom:1px solid var(--pps-border);padding:12px;font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap}.psp-table td{border-bottom:1px solid #f1f5f9;padding:12px;white-space:nowrap;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;vertical-align:middle;color:var(--pps-text)}.psp-table tbody tr:nth-child(2n){background:#fafafa}.psp-table tbody tr:hover{background:#f1f5f9}.psp-empty{text-align:center;color:var(--pps-muted);padding:24px;font-size:var(--pps-text-md);font-weight:600}.psp-remark{white-space:normal;min-width:240px;max-width:420px;color:var(--pps-text-soft);line-height:1.5;word-break:break-word}.psp-mv-badge{min-height:24px;padding:4px 9px;border-radius:999px;display:inline-flex;align-items:center;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.psp-mv-badge.in{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.psp-mv-badge.out{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.psp-mv-badge.adjust{background:#fff7ed;border-color:#fdba74;color:#9a3412}.psp-foot{margin-top:10px;display:flex;justify-content:flex-end}.psp-link{min-height:40px;border:1px solid var(--pps-border);background:#fff;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);text-decoration:none}@media(min-width:640px){.psp-page{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));padding-left:calc(16px + env(safe-area-inset-left,0px));padding-right:calc(16px + env(safe-area-inset-right,0px))}.psp-topbar{flex-direction:row;align-items:flex-end;justify-content:space-between}.psp-grid2{grid-template-columns:1fr 1fr}}@media(max-width:720px){.psp-topbar{position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.psp-seg{grid-template-columns:1fr}.psp-thumb,.psp-thumb.noimg{width:96px;height:96px}.psp-stock-value{font-size:var(--fs-24)}.psp-table th{font-size:var(--fs-12);padding:10px 8px}.psp-table td{font-size:var(--fs-13);padding:10px 8px}}:root{--pps-font-main: "Inter", "Noto Sans Thai", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--pps-bg: #f8fafc;--pps-card: #ffffff;--pps-border: #e5e7eb;--pps-border-strong: #cbd5e1;--pps-text: #0f172a;--pps-text-soft: #334155;--pps-muted: #64748b;--pps-muted-strong: #475569;--pps-primary: #0369a1;--pps-primary-soft: #eff6ff;--pps-radius-sm: 10px;--pps-radius-md: 14px;--pps-radius-lg: 18px;--pps-shadow: 0 4px 16px rgba(15, 23, 42, .05);--pps-text-xs: 12px;--pps-text-sm: 13px;--pps-text-md: 14px;--pps-text-xl: 20px}.pspw-page{width:100%;max-width:100%;min-height:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:16px;overflow-x:hidden}.pspw-page>*{min-width:0}.pspw-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap;width:100%;min-width:0}.pspw-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25;color:var(--pps-text);min-width:0;word-break:break-word}.pspw-subtitle{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45}.pspw-topbar-actions{display:flex;gap:8px;flex-wrap:wrap;min-width:0}.pspw-action-btn,.pspw-refresh-btn{height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;max-width:100%;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.pspw-action-btn:hover,.pspw-refresh-btn:hover{transform:translateY(-1px)}.pspw-action-btn.print{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;box-shadow:0 6px 14px #0284c72e}.pspw-action-btn.export{background:linear-gradient(135deg,#059669,#047857);color:#fff;box-shadow:0 6px 14px #0596692e}.pspw-refresh-btn{background:#fff;color:var(--pps-text);border:1px solid var(--pps-border-strong)}.pspw-refresh-btn:hover{background:#f8fafc}.pspw-refresh-btn:disabled,.pspw-action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pspw-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;width:100%;min-width:0}.pspw-summary-card,.pspw-toolbar-card,.pspw-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);padding:16px;box-shadow:var(--pps-shadow);width:100%;max-width:100%;min-width:0}.pspw-card,.pspw-toolbar-card{overflow:hidden}.pspw-summary-card.info{border-color:#bfdbfe}.pspw-summary-card.warning{border-color:#fde68a}.pspw-summary-card.success{border-color:#bbf7d0}.pspw-summary-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--pps-primary-soft);color:var(--pps-primary);margin-bottom:10px;font-size:var(--fs-16)}.pspw-summary-label{font-size:var(--pps-text-xs);color:var(--pps-muted);font-weight:700;line-height:1.4}.pspw-summary-value{margin-top:6px;font-size:var(--fs-22);font-weight:800;line-height:1.2;color:var(--pps-text);word-break:break-word;font-variant-numeric:tabular-nums}.pspw-toolbar{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;align-items:center;width:100%;min-width:0}.pspw-toolbar>*{min-width:0}.pspw-search,.pspw-input-icon{height:40px;width:100%;min-width:0;display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:0 12px;color:var(--pps-muted-strong)}.pspw-search input,.pspw-input-icon input,.pspw-toolbar select{width:100%;min-width:0;height:40px;border:none;background:transparent;outline:none;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text)}.pspw-search input::placeholder,.pspw-input-icon input::placeholder{color:#94a3b8;font-weight:500}.pspw-toolbar select{border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;padding:0 12px;max-width:100%}.pspw-search:focus-within,.pspw-input-icon:focus-within,.pspw-toolbar select:focus{border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f;background:#fff}.pspw-table-wrap{width:100%;max-width:100%;min-width:0;overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);max-height:68vh;background:#fff;-webkit-overflow-scrolling:touch}.pspw-table,.pspw-print-table{width:100%;border-collapse:collapse}.pspw-table{min-width:1180px}.pspw-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pspw-table td{padding:12px;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;color:var(--pps-text)}.pspw-table tbody tr{background:#fff}.pspw-table tbody tr:nth-child(2n){background:#fafafa}.pspw-table tbody tr:hover{background:#f1f5f9}.pspw-item-name{min-width:260px;max-width:420px;color:var(--pps-text);font-size:var(--fs-14);font-weight:600;font-family:var(--pps-font-main);line-height:1.5;white-space:normal;word-break:break-word}.pspw-remark{min-width:240px;max-width:420px;white-space:normal!important;word-break:break-word;color:var(--pps-text-soft);line-height:1.5}.qty,.mono{font-family:var(--pps-font-mono);font-size:var(--fs-14);font-weight:600;letter-spacing:0;font-variant-numeric:tabular-nums}.pspw-empty{padding:28px;text-align:center;color:var(--pps-muted);font-size:var(--pps-text-md);font-weight:600}.pspw-print-area{display:none}.pspw-print-sheet{background:#fff;padding:0;color:#0f172a;font-family:var(--pps-font-main)}.pspw-print-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.pspw-print-title{font-size:var(--fs-22);font-weight:900;line-height:1.25}.pspw-print-subtitle{margin-top:2px;font-size:var(--fs-13);color:var(--pps-muted-strong)}.pspw-print-sub{margin-top:2px;font-size:var(--fs-12);color:var(--pps-muted)}.pspw-print-meta-right{font-size:var(--fs-12);color:#334155;text-align:right;display:grid;gap:4px}.pspw-print-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px 14px;margin-bottom:12px;font-size:var(--fs-12);line-height:1.4}.pspw-print-table th,.pspw-print-table td{border:1px solid var(--pps-border-strong);padding:8px;font-size:var(--fs-12);line-height:1.4;vertical-align:top;font-family:var(--pps-font-main)}.pspw-print-table th{background:#f8fafc;font-weight:800;text-align:left}.pspw-print-summary{margin-top:12px;display:grid;gap:6px;font-size:var(--fs-12)}.pspw-print-signatures{margin-top:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.pspw-sign-box{text-align:center;font-size:var(--fs-12)}.pspw-sign-line{border-bottom:1px solid #0f172a;height:36px;margin-bottom:8px}.spin{animation:pspw-spin 1s linear infinite}@keyframes pspw-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1280px){.pspw-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pspw-toolbar{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}}@media(max-width:980px){.pspw-topbar{align-items:flex-start}.pspw-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pspw-toolbar{grid-template-columns:1fr 1fr}.pspw-topbar-actions{width:100%}.pspw-action-btn,.pspw-refresh-btn{flex:1 1 auto}.pspw-print-info-grid{grid-template-columns:1fr}.pspw-print-signatures{grid-template-columns:1fr;gap:16px}}@media(max-width:640px){.pspw-page{padding:12px;gap:12px}.pspw-title{font-size:var(--fs-18)}.pspw-summary-grid,.pspw-toolbar{grid-template-columns:1fr}.pspw-summary-card,.pspw-toolbar-card,.pspw-card{padding:12px;border-radius:14px}.pspw-topbar-actions,.pspw-action-btn,.pspw-refresh-btn{width:100%}.pspw-table th{font-size:var(--fs-12);padding:10px 8px}.pspw-table td,.qty,.mono,.pspw-item-name{font-size:var(--fs-13)}.pspw-table td{padding:10px 8px}.pspw-item-name,.pspw-remark{min-width:220px}}@media print{@page{size:A4 landscape;margin:10mm}body.pspw-printing *{visibility:hidden}body.pspw-printing .pspw-print-area,body.pspw-printing .pspw-print-area *{visibility:visible}body.pspw-printing .pspw-print-area{display:block;position:absolute;inset:0;background:#fff;padding:0;margin:0}.pspw-print-sheet{display:block}}.pcnem-page{display:grid;gap:16px;padding:16px}.pcnem-topbar,.pcnem-card{background:#fff;border:1px solid #dbe3ef;border-radius:18px;box-shadow:0 8px 24px #0f172a0f}.pcnem-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 18px}.pcnem-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-22);font-weight:900;color:#0f172a}.pcnem-sub{margin-top:6px;color:#475569;font-size:var(--fs-14)}.pcnem-topbar-actions,.pcnem-actions{display:flex;gap:10px;flex-wrap:wrap}.pcnem-card{padding:16px}.pcnem-card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.pcnem-card-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-18);font-weight:900;color:#0f172a}.pcnem-form,.pcnem-grid2,.pcnem-grid3{display:grid;gap:12px}.pcnem-grid2{grid-template-columns:repeat(2,minmax(0,1fr))}.pcnem-grid3{grid-template-columns:repeat(3,minmax(0,1fr))}.pcnem-field{display:grid;gap:6px}.pcnem-field label{font-size:var(--fs-13);font-weight:800;color:#0f172a}.pcnem-field input{width:100%;min-height:44px;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px;font-size:var(--fs-15);color:#0f172a;background:#fff}.pcnem-field input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.pcnem-checkrow{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#0f172a}.pcnem-btn,.pcnem-btn-primary{min-height:42px;border-radius:12px;border:1px solid #cbd5e1;padding:0 14px;display:inline-flex;align-items:center;gap:8px;font-weight:800;cursor:pointer;background:#fff;color:#0f172a}.pcnem-btn-primary{border-color:#2563eb;background:#2563eb;color:#fff}.pcnem-btn-ghost{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.pcnem-btn-sm{min-height:36px;padding:0 10px;font-size:var(--fs-13)}.pcnem-filterbar{margin-bottom:12px}.pcnem-searchbar{position:relative}.pcnem-searchbar input{width:100%;min-height:44px;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px 10px 40px}.pcnem-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.pcnem-table-wrap{overflow:auto}.pcnem-table{width:100%;border-collapse:collapse;min-width:1100px}.pcnem-table th,.pcnem-table td{border-bottom:1px solid #e2e8f0;padding:10px 12px;text-align:left;vertical-align:top}.pcnem-table th{background:#f8fafc;color:#0f172a;font-size:var(--fs-13);font-weight:900}.pcnem-table td{color:#334155;font-size:var(--fs-14)}.pcnem-empty{text-align:center;color:#64748b;padding:24px!important}.pcnem-status{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:900}.pcnem-status.ok{color:#166534;background:#dcfce7}.pcnem-status.off{color:#991b1b;background:#fee2e2}@media(max-width:900px){.pcnem-topbar{flex-direction:column}.pcnem-grid2,.pcnem-grid3{grid-template-columns:1fr}}.psnem-page{display:grid;gap:16px;padding:16px}.psnem-topbar,.psnem-card{background:#fff;border:1px solid #dbe3ef;border-radius:18px;box-shadow:0 8px 24px #0f172a0f}.psnem-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 18px}.psnem-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-22);font-weight:900;color:#0f172a}.psnem-sub{margin-top:6px;color:#475569;font-size:var(--fs-14)}.psnem-topbar-actions,.psnem-actions{display:flex;gap:10px;flex-wrap:wrap}.psnem-card{padding:16px}.psnem-card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.psnem-card-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-18);font-weight:900;color:#0f172a}.psnem-form{display:grid;gap:12px}.psnem-grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.psnem-field{display:grid;gap:6px}.psnem-field label{font-size:var(--fs-13);font-weight:800;color:#0f172a}.psnem-field input{width:100%;min-height:44px;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px;font-size:var(--fs-15);color:#0f172a;background:#fff}.psnem-field input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.psnem-checkrow{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#0f172a}.psnem-btn,.psnem-btn-primary{min-height:42px;border-radius:12px;border:1px solid #cbd5e1;padding:0 14px;display:inline-flex;align-items:center;gap:8px;font-weight:800;cursor:pointer;background:#fff;color:#0f172a}.psnem-btn-primary{border-color:#2563eb;background:#2563eb;color:#fff}.psnem-btn-ghost{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.psnem-btn-sm{min-height:36px;padding:0 10px;font-size:var(--fs-13)}.psnem-filterbar{margin-bottom:12px}.psnem-searchbar{position:relative}.psnem-searchbar input{width:100%;min-height:44px;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px 10px 40px}.psnem-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.psnem-table-wrap{overflow:auto}.psnem-table{width:100%;border-collapse:collapse;min-width:1050px}.psnem-table th,.psnem-table td{border-bottom:1px solid #e2e8f0;padding:10px 12px;text-align:left;vertical-align:top}.psnem-table th{background:#f8fafc;color:#0f172a;font-size:var(--fs-13);font-weight:900}.psnem-table td{color:#334155;font-size:var(--fs-14)}.psnem-empty{text-align:center;color:#64748b;padding:24px!important}.psnem-status{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:900}.psnem-status.ok{color:#166534;background:#dcfce7}.psnem-status.off{color:#991b1b;background:#fee2e2}@media(max-width:900px){.psnem-topbar{flex-direction:column}.psnem-grid2{grid-template-columns:1fr}}:root{--pps-font-main: "Inter", "Noto Sans Thai", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--pps-bg: #f8fafc;--pps-card: #ffffff;--pps-border: #e5e7eb;--pps-border-strong: #cbd5e1;--pps-text: #0f172a;--pps-text-soft: #334155;--pps-muted: #64748b;--pps-muted-strong: #475569;--pps-primary: #0369a1;--pps-primary-soft: #eff6ff;--pps-radius-sm: 10px;--pps-radius-md: 14px;--pps-radius-lg: 18px;--pps-shadow: 0 4px 16px rgba(15, 23, 42, .05);--pps-text-xs: 12px;--pps-text-sm: 13px;--pps-text-md: 14px;--pps-text-lg: 16px;--pps-text-xl: 20px}.pcwr-page{min-height:100%;width:100%;max-width:100%;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:16px;overflow-x:hidden}.pcwr-page>*{min-width:0}.pcwr-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.pcwr-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25;color:var(--pps-text)}.pcwr-subtitle{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45}.pcwr-topbar-actions{display:flex;gap:8px;flex-wrap:wrap}.pcwr-action-btn,.pcwr-refresh-btn{height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease,opacity .15s ease}.pcwr-action-btn:hover,.pcwr-refresh-btn:hover{transform:translateY(-1px)}.pcwr-action-btn.print{background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;box-shadow:0 6px 14px #0284c72e}.pcwr-action-btn.export{background:linear-gradient(135deg,#059669,#047857);color:#fff;box-shadow:0 6px 14px #0596692e}.pcwr-refresh-btn{background:#fff;color:var(--pps-text);border:1px solid var(--pps-border-strong)}.pcwr-refresh-btn:hover{background:#f8fafc}.pcwr-refresh-btn:disabled,.pcwr-action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pcwr-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.pcwr-summary-card,.pcwr-toolbar-card,.pcwr-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);padding:16px;box-shadow:var(--pps-shadow);min-width:0}.pcwr-summary-card.info{border-color:#bfdbfe}.pcwr-summary-card.warning{border-color:#fde68a}.pcwr-summary-card.success{border-color:#bbf7d0}.pcwr-summary-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--pps-primary-soft);color:var(--pps-primary);margin-bottom:10px;font-size:var(--fs-16)}.pcwr-summary-label{font-size:var(--pps-text-xs);color:var(--pps-muted);font-weight:700;line-height:1.4}.pcwr-summary-value{margin-top:6px;font-size:var(--fs-22);font-weight:800;line-height:1.2;color:var(--pps-text);font-variant-numeric:tabular-nums}.pcwr-summary-sub{margin-top:6px;color:var(--pps-muted);font-size:var(--pps-text-sm)}.pcwr-toolbar{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;align-items:center}.pcwr-search,.pcwr-input-icon{height:40px;display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:0 12px;color:var(--pps-muted-strong);min-width:0}.pcwr-search svg,.pcwr-input-icon svg{flex:0 0 auto;color:var(--pps-muted)}.pcwr-search input,.pcwr-input-icon input,.pcwr-toolbar select{width:100%;height:40px;min-width:0;border:none;background:transparent;outline:none;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text)}.pcwr-search input::placeholder,.pcwr-input-icon input::placeholder{color:#94a3b8;font-weight:500}.pcwr-toolbar select{border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;padding:0 12px;appearance:none;-webkit-appearance:none;-moz-appearance:none}.pcwr-search:focus-within,.pcwr-input-icon:focus-within,.pcwr-toolbar select:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pcwr-table-wrap{overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);max-height:68vh;background:#fff;-webkit-overflow-scrolling:touch}.pcwr-table,.pcwr-print-table{width:100%;border-collapse:collapse}.pcwr-table{min-width:1500px}.pcwr-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pcwr-table td{padding:12px;font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap;color:var(--pps-text)}.pcwr-table tbody tr{background:#fff}.pcwr-table tbody tr:nth-child(2n){background:#fafafa}.pcwr-table tbody tr:hover{background:#f1f5f9}.pcwr-item-name{font-size:var(--fs-14);font-weight:700;color:var(--pps-text);white-space:normal;min-width:240px;max-width:420px;line-height:1.45;word-break:break-word}.pcwr-remark{white-space:normal!important;min-width:240px;max-width:420px;line-height:1.5;color:var(--pps-text-soft);word-break:break-word}.pcwr-empty{padding:28px;text-align:center;color:var(--pps-muted);font-size:var(--pps-text-md);font-weight:600}.mono,.qty{font-family:var(--pps-font-mono);font-size:inherit;font-weight:600;letter-spacing:0;font-variant-numeric:tabular-nums}.qty{text-align:right}.strong{font-weight:700}.danger{color:#b91c1c;font-weight:800}.pcwr-print-area{display:none}.pcwr-print-sheet{background:#fff;padding:0;color:#0f172a;font-family:var(--pps-font-main)}.pcwr-print-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.pcwr-print-title{font-size:var(--fs-22);font-weight:900;line-height:1.25;color:var(--pps-text)}.pcwr-print-subtitle{margin-top:2px;font-size:var(--fs-13);color:var(--pps-muted-strong)}.pcwr-print-meta-right{font-size:var(--fs-12);color:#334155;text-align:right;display:grid;gap:4px}.pcwr-print-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px 14px;margin-bottom:12px;font-size:var(--fs-12);line-height:1.4}.pcwr-print-table th,.pcwr-print-table td{border:1px solid var(--pps-border-strong);padding:8px;font-size:var(--fs-12);line-height:1.4;vertical-align:top;font-family:var(--pps-font-main)}.pcwr-print-table th{background:#f8fafc;font-weight:800;text-align:left;color:var(--pps-text)}.pcwr-print-summary{margin-top:12px;display:grid;gap:6px;font-size:var(--fs-12)}.pcwr-print-signatures{margin-top:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.pcwr-sign-box{text-align:center;font-size:var(--fs-12);color:var(--pps-text)}.pcwr-sign-line{border-bottom:1px solid var(--pps-text);height:36px;margin-bottom:8px}.spin{animation:pcwr-spin 1s linear infinite}@keyframes pcwr-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1280px){.pcwr-summary-grid,.pcwr-print-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:980px){.pcwr-topbar{align-items:flex-start}.pcwr-topbar-actions{width:100%}.pcwr-action-btn,.pcwr-refresh-btn{flex:1 1 auto}.pcwr-toolbar{grid-template-columns:1fr 1fr}}@media(max-width:640px){.pcwr-page{padding:12px;gap:12px}.pcwr-title{font-size:var(--fs-18)}.pcwr-summary-grid,.pcwr-toolbar{grid-template-columns:1fr}.pcwr-summary-card,.pcwr-toolbar-card,.pcwr-card{padding:12px;border-radius:14px}.pcwr-action-btn,.pcwr-refresh-btn{width:100%}.pcwr-table-wrap{max-height:none}.pcwr-table th{font-size:var(--fs-12);padding:10px 8px}.pcwr-table td{font-size:var(--fs-13);padding:10px 8px}.pcwr-print-info-grid{grid-template-columns:1fr}}@media print{@page{size:A4 landscape;margin:10mm}body.pcwr-printing *{visibility:hidden}body.pcwr-printing .pcwr-print-area,body.pcwr-printing .pcwr-print-area *{visibility:visible}body.pcwr-printing .pcwr-print-area{display:block;position:absolute;inset:0;background:#fff;padding:0;margin:0}.pcwr-print-sheet{display:block}}:root{--pps-font-main: "Inter", "Noto Sans Thai", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--pps-bg: #f8fafc;--pps-card: #ffffff;--pps-border: #e5e7eb;--pps-border-strong: #cbd5e1;--pps-text: #0f172a;--pps-text-soft: #334155;--pps-muted: #64748b;--pps-primary: #0369a1;--pps-radius-sm: 10px;--pps-radius-md: 14px;--pps-shadow: 0 4px 16px rgba(15, 23, 42, .05);--pps-text-xs: 12px;--pps-text-sm: 13px;--pps-text-md: 14px;--pps-text-lg: 16px}.pdw-page{min-height:100svh;min-height:-webkit-fill-available;width:100%;max-width:100%;min-width:0;padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));padding-left:calc(12px + env(safe-area-inset-left,0px));padding-right:calc(12px + env(safe-area-inset-right,0px));background:var(--pps-bg);color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);color-scheme:light;font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;display:flex;flex-direction:column;gap:12px;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.pdw-page *{min-width:0}.pdw-page a,.pdw-page button,.pdw-page input,.pdw-page select,.pdw-page textarea,.pdw-page label,.pdw-page span,.pdw-page div,.pdw-page p,.pdw-page th,.pdw-page td,.pdw-page strong,.pdw-page em{-webkit-text-fill-color:currentColor}.pdw-page button,.pdw-page input,.pdw-page select,.pdw-page textarea{font:inherit;color:inherit;font-family:inherit}.pdw-topbar,.pdw-card{width:100%;max-width:100%;min-width:0;background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);color:var(--pps-text);box-shadow:var(--pps-shadow)}.pdw-topbar{display:flex;flex-direction:column;gap:8px;padding:12px}.pdw-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.3;color:var(--pps-text)}.pdw-sub{margin-top:2px;font-size:var(--pps-text-xs);font-weight:500;color:var(--pps-muted);line-height:1.45}.pdw-actions{display:flex;gap:8px;flex-wrap:wrap;max-width:100%}.pdw-card{padding:12px}.pdw-alert{display:flex;align-items:center;gap:10px;background:#fff7ed;border-color:#fed7aa;color:#9a3412;font-weight:700}.pdw-hero{display:grid;gap:12px}.pdw-uid-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}.pdw-uid-label,.pdw-section-title,.pdw-asset-title,.pdw-history-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-md);font-weight:800;color:var(--pps-text)}.pdw-uid-label{font-size:var(--pps-text-xs);color:var(--pps-text-soft)}.pdw-uid-val{margin-top:2px;font-size:var(--pps-text-lg);font-weight:800;color:var(--pps-text);word-break:break-word}.pdw-overall,.pdw-mini-badge{min-height:28px;padding:4px 12px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.pdw-overall.ok,.pdw-mini-badge.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pdw-overall.ng,.pdw-mini-badge.ng{background:#fef2f2;border-color:#fecaca;color:#991b1b}.pdw-overall.skip,.pdw-mini-badge.skip{background:#fff7ed;border-color:#fed7aa;color:#c2410c}.pdw-overall.pending,.pdw-mini-badge.pending{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.pdw-pill-wrap,.pdw-who,.pdw-upload-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.pdw-pill,.pdw-pill2{min-height:26px;padding:4px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--pps-border);background:#f8fafc;font-size:var(--pps-text-xs);font-weight:700;color:var(--pps-text);line-height:1.2}.pdw-pill2{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.pdw-asset-grid,.pdw-grid2{display:grid;gap:10px;width:100%;min-width:0}.pdw-asset-card{border:1px dashed var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:10px;background:#f8fafc;min-width:0}.pdw-ref-row{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-top:1px solid var(--pps-border)}.pdw-ref-row:first-of-type{border-top:none}.pdw-ref-row .k{color:var(--pps-muted);font-size:var(--pps-text-xs);font-weight:700}.pdw-ref-row .v{color:var(--pps-text);font-weight:800;text-align:right;word-break:break-word}.pdw-image-box{width:100%;max-width:320px;height:220px;overflow:hidden;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border);background:#fff}.pdw-image{display:block;width:100%;height:100%;object-fit:cover;cursor:zoom-in}.pdw-image-empty,.pdw-empty{border:1px dashed var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:16px;text-align:center;color:var(--pps-muted);background:#f8fafc;font-size:var(--pps-text-md);font-weight:600}.pdw-form-head,.pdw-history-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px;flex-wrap:wrap}.pdw-section-sub,.pdw-history-sub,.pdw-muted,.pdw-help{font-size:var(--pps-text-xs);color:var(--pps-muted);line-height:1.45}.pdw-field{min-width:0}.pdw-field label{display:block;margin-bottom:6px;font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.pdw-field input,.pdw-field select,.pdw-field textarea{width:100%;max-width:100%;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);background:#f8fafc;color:var(--pps-text);-webkit-text-fill-color:var(--pps-text);font-size:var(--fs-16);font-weight:600;font-family:var(--pps-font-main);outline:none;-webkit-appearance:none;appearance:none;box-shadow:none}.pdw-field input,.pdw-field select{min-height:44px;padding:0 12px}.pdw-field textarea{min-height:88px;padding:10px 12px;line-height:1.5;resize:vertical}.pdw-field input::placeholder,.pdw-field textarea::placeholder{color:#94a3b8;-webkit-text-fill-color:#94a3b8;font-weight:500}.pdw-field input:focus,.pdw-field select:focus,.pdw-field textarea:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pdw-field input:disabled,.pdw-field textarea:disabled,.pdw-field select:disabled{color:var(--pps-text)!important;opacity:1!important;-webkit-text-fill-color:var(--pps-text)!important;background:#f1f5f9;cursor:not-allowed}.pdw-existing-box{margin-top:10px;display:flex;gap:8px;align-items:flex-start;border-radius:var(--pps-radius-sm);border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;padding:10px 12px;font-size:var(--pps-text-sm);font-weight:700;flex-wrap:wrap}.pdw-existing-time{margin-left:auto}.pdw-items{display:grid;gap:12px}.pdw-item-card{border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);padding:12px;background:#fff;display:grid;gap:10px;min-width:0}.pdw-item-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.pdw-item-title{font-size:var(--pps-text-md);font-weight:800;color:var(--pps-text);line-height:1.4}.pdw-item-sub{margin-top:2px;font-size:var(--pps-text-xs);color:var(--pps-muted);word-break:break-word}.pdw-item-badge{min-height:28px;padding:4px 10px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.pdw-item-badge.pass{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pdw-item-badge.fail{background:#fef2f2;border-color:#fecaca;color:#991b1b}.pdw-item-badge.na{background:#f8fafc;border-color:#cbd5e1;color:#475569}.pdw-spec-box{border:1px dashed var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:10px;background:#f8fafc;font-size:var(--pps-text-xs);color:var(--pps-text-soft);display:grid;gap:4px;line-height:1.45}.pdw-seg{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.pdw-seg-btn,.pdw-btn,.pdw-btn-primary,.pdw-upload-btn,.pdw-clear-btn,.pdw-preview-zoom{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;-webkit-appearance:none;appearance:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;font-family:var(--pps-font-main);font-weight:700;text-shadow:none;max-width:100%;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.pdw-seg-btn{min-height:44px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border-strong);background:#fff;color:var(--pps-text)}.pdw-seg-btn:hover,.pdw-btn:hover,.pdw-upload-btn:hover,.pdw-clear-btn:hover,.pdw-preview-zoom:hover{transform:translateY(-1px)}.pdw-seg-btn.active.pass{background:#ecfdf5;border-color:#86efac;color:#166534}.pdw-seg-btn.active.fail{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.pdw-seg-btn.active.na{background:#f8fafc;border-color:#94a3b8;color:#334155}.pdw-btn{min-height:40px;padding:0 14px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border);background:#fff;color:var(--pps-text);text-decoration:none}.pdw-btn:hover{background:#f8fafc}.pdw-btn-primary{min-height:46px;width:100%;padding:0 14px;border-radius:var(--pps-radius-sm);border:none;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff!important;-webkit-text-fill-color:#ffffff!important;font-size:var(--pps-text-md);box-shadow:0 6px 14px #0284c72e}.pdw-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985);transform:translateY(-1px)}.pdw-upload-btn{min-height:38px;padding:0 12px;border-radius:var(--pps-radius-sm);border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8}.pdw-clear-btn{min-height:38px;padding:0 12px;border-radius:var(--pps-radius-sm);border:1px solid #fecdd3;background:#fff1f2;color:#b91c1c}.pdw-btn-primary:disabled,.pdw-btn:disabled,.pdw-seg-btn:disabled,.pdw-upload-btn:disabled,.pdw-clear-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pdw-savebar{margin-top:12px;display:grid;gap:10px}.pdw-file-meta{margin-top:6px;color:var(--pps-muted);font-size:var(--pps-text-xs);line-height:1.45;word-break:break-all}.pdw-inline-preview-wrap{margin-top:8px;display:grid;gap:8px;justify-content:flex-start}.pdw-inline-image,.pdw-inline-image-empty{width:100%;max-width:220px;height:140px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border);background:#f8fafc;overflow:hidden}.pdw-inline-image{display:block;object-fit:cover;cursor:zoom-in}.pdw-inline-image-empty{display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:var(--fs-28)}.pdw-preview-zoom{width:fit-content;max-width:220px;min-height:36px;padding:0 12px;border-radius:var(--pps-radius-sm);border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;font-size:var(--pps-text-sm)}.pdw-table-wrap{overflow-x:auto;overflow-y:visible;max-width:100%;min-width:0;border:1px solid var(--pps-border);border-radius:var(--pps-radius-sm);background:#fff;-webkit-overflow-scrolling:touch}.pdw-table{width:100%;min-width:760px;border-collapse:separate;border-spacing:0}.pdw-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pdw-table td{color:var(--pps-text);font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap}.pdw-table tbody tr:nth-child(2n){background:#fafafa}.pdw-table tbody tr:hover{background:#f1f5f9}.pdw-remark{white-space:pre-wrap;word-break:break-word;color:var(--pps-text-soft);min-width:220px;max-width:420px}.pdw-foot{margin-top:12px}.pdw-link{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:var(--pps-primary);font-weight:800}.pdw-link:hover{text-decoration:underline}.pdw-lightbox{position:fixed;inset:0;z-index:9999;background:#020617b8;display:flex;align-items:center;justify-content:center;padding:16px}.pdw-lightbox-dialog{width:min(960px,100%);max-height:calc(100vh - 32px);background:#fff;border-radius:16px;overflow:hidden;display:grid;grid-template-rows:auto 1fr}.pdw-lightbox-head{padding:12px 14px;border-bottom:1px solid var(--pps-border);display:flex;align-items:center;justify-content:space-between;gap:12px}.pdw-lightbox-title{font-size:var(--pps-text-md);font-weight:800;color:var(--pps-text)}.pdw-lightbox-body{padding:12px;display:flex;align-items:center;justify-content:center;background:#f8fafc;min-height:220px}.pdw-lightbox-image{display:block;max-width:100%;max-height:calc(100vh - 140px);object-fit:contain;border-radius:var(--pps-radius-md)}@media(min-width:768px){.pdw-page{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));padding-left:calc(16px + env(safe-area-inset-left,0px));padding-right:calc(16px + env(safe-area-inset-right,0px))}.pdw-topbar{flex-direction:row;justify-content:space-between;align-items:flex-start}.pdw-asset-grid,.pdw-grid2{grid-template-columns:repeat(2,minmax(0,1fr))}.pdw-savebar{grid-template-columns:1fr 240px;align-items:center}}@media(max-width:768px){.pdw-topbar{position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.pdw-seg{grid-template-columns:1fr}.pdw-inline-image,.pdw-inline-image-empty{max-width:160px;height:110px}.pdw-preview-zoom{max-width:160px;font-size:var(--fs-12)}.pdw-image-box{max-width:100%;height:180px}.pdw-table th{font-size:var(--fs-12);padding:10px 8px}.pdw-table td{font-size:var(--fs-13);padding:10px 8px}}.pdwp-page{min-height:100dvh;width:100%;max-width:100%;min-width:0;display:grid;gap:16px;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;overflow-x:hidden}.pdwp-page *{min-width:0}.pdwp-card{width:100%;max-width:100%;min-width:0;background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);box-shadow:var(--pps-shadow);padding:16px}.pdwp-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.pdwp-title{display:flex;align-items:center;gap:10px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25;color:var(--pps-text)}.pdwp-subtitle{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45}.pdwp-top-actions{display:flex;gap:8px;flex-wrap:wrap;max-width:100%}.pdwp-btn,.pdwp-btn-primary,.pdwp-btn-soft{min-height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:1px solid var(--pps-border-strong);background:#fff;color:var(--pps-text);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);text-decoration:none;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease}.pdwp-btn:hover,.pdwp-btn-primary:hover,.pdwp-btn-soft:hover{transform:translateY(-1px)}.pdwp-btn:hover{background:#f8fafc}.pdwp-btn-primary{border:none;background:linear-gradient(135deg,#0284c7,#0369a1);color:#fff;box-shadow:0 6px 14px #0284c72e}.pdwp-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985)}.pdwp-btn-soft{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.pdwp-btn-soft:hover{background:#dbeafe;border-color:#93c5fd}.pdwp-btn:disabled,.pdwp-btn-primary:disabled,.pdwp-btn-soft:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pdwp-grid-filter{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;width:100%}.pdwp-field{min-width:0;max-width:100%}.pdwp-field label{display:block;margin-bottom:6px;font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.pdwp-field input,.pdwp-field select,.pdwp-field textarea,.pdwp-table input,.pdwp-table select,.pdwp-table textarea{width:100%;max-width:100%;border:1px solid var(--pps-border-strong);background:#f8fafc;color:var(--pps-text);border-radius:var(--pps-radius-sm);padding:0 12px;outline:none;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);line-height:1.45;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.pdwp-field input,.pdwp-field select,.pdwp-table input,.pdwp-table select{min-height:40px}.pdwp-field textarea,.pdwp-table textarea{min-height:72px;padding-top:10px;padding-bottom:10px;resize:vertical}.pdwp-field input::placeholder,.pdwp-field textarea::placeholder,.pdwp-table input::placeholder,.pdwp-table textarea::placeholder{color:#94a3b8;font-weight:500}.pdwp-field input:focus,.pdwp-field select:focus,.pdwp-field textarea:focus,.pdwp-table input:focus,.pdwp-table select:focus,.pdwp-table textarea:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pdwp-summary{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;width:100%}.pdwp-metric{border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);padding:16px;background:#fff;min-width:0}.pdwp-metric-k{font-size:var(--pps-text-xs);font-weight:700;color:var(--pps-muted);line-height:1.4}.pdwp-metric-v{margin-top:6px;font-size:var(--fs-22);font-weight:800;line-height:1.2;color:var(--pps-text);font-variant-numeric:tabular-nums}.pdwp-table-wrap{width:100%;max-width:100%;min-width:0;overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);background:#fff;-webkit-overflow-scrolling:touch}.pdwp-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1220px;background:#fff}.pdwp-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pdwp-table td{color:var(--pps-text);font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap}.pdwp-table tbody tr:nth-child(2n){background:#fafafa}.pdwp-table tbody tr:hover{background:#f1f5f9}.pdwp-table tbody tr:last-child td{border-bottom:none}.pdwp-code{font-family:var(--pps-font-mono);font-size:inherit;font-weight:600;letter-spacing:0;font-variant-numeric:tabular-nums;color:var(--pps-text);line-height:1.45;word-break:break-word}.pdwp-help{color:var(--pps-muted);font-size:var(--pps-text-xs);font-weight:500;line-height:1.45;word-break:break-word}.pdwp-help label{display:inline-flex;align-items:center;gap:4px;cursor:pointer;flex-wrap:wrap}.pdwp-help input[type=checkbox]{width:14px;height:14px;min-height:14px;margin:0;padding:0;accent-color:var(--pps-primary);flex:0 0 auto}.pdwp-pill{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap;max-width:100%}.pdwp-pill.planned{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.pdwp-pill.done,.pdwp-pill.pass{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pdwp-pill.skip{background:#fff7ed;border-color:#fed7aa;color:#c2410c}.pdwp-pill.overdue,.pdwp-pill.fail{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.pdwp-pill.cancelled{background:#f1f5f9;border-color:#cbd5e1;color:#475569}.pdwp-pill.pending{background:#fffbeb;border-color:#fde68a;color:#92400e}.pdwp-row-actions{display:grid;gap:8px;min-width:132px;width:100%}.pdwp-row-actions .pdwp-btn-primary,.pdwp-row-actions .pdwp-btn-soft,.pdwp-row-actions .pdwp-btn{min-height:38px;width:100%;font-size:var(--pps-text-sm);border-radius:var(--pps-radius-sm)}.pdwp-empty{padding:24px;border:1px dashed var(--pps-border-strong);border-radius:var(--pps-radius-md);color:var(--pps-muted);text-align:center;background:#f8fafc;font-size:var(--pps-text-md);font-weight:600}.pdwp-image-btn{border:none;background:transparent;padding:0;cursor:pointer}.pdwp-image-thumb,.pdwp-image-empty{width:88px;height:64px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border);background:#f8fafc;object-fit:cover;display:block}.pdwp-image-empty{display:flex;align-items:center;justify-content:center;color:#94a3b8}.pdwp-lightbox{position:fixed;inset:0;z-index:9999;background:#020617b8;display:flex;align-items:center;justify-content:center;padding:16px}.pdwp-lightbox-dialog{width:min(960px,100%);max-height:calc(100vh - 32px);background:#fff;border-radius:var(--pps-radius-lg);overflow:hidden;display:grid;grid-template-rows:auto 1fr}.pdwp-lightbox-head{padding:12px 14px;border-bottom:1px solid var(--pps-border);display:flex;align-items:center;justify-content:space-between;gap:12px}.pdwp-lightbox-title{font-size:var(--pps-text-md);font-weight:800;color:var(--pps-text)}.pdwp-lightbox-body{padding:12px;display:flex;align-items:center;justify-content:center;background:#f8fafc;min-height:220px}.pdwp-lightbox-image{display:block;max-width:100%;max-height:calc(100vh - 140px);object-fit:contain;border-radius:var(--pps-radius-md)}@media(max-width:1280px){.pdwp-grid-filter,.pdwp-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.pdwp-table{min-width:1160px}}@media(max-width:900px){.pdwp-grid-filter,.pdwp-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.pdwp-page{padding:12px;gap:12px}.pdwp-card{padding:12px;border-radius:14px}.pdwp-topbar{align-items:flex-start}.pdwp-title{font-size:var(--fs-18)}.pdwp-subtitle{font-size:var(--fs-13)}.pdwp-grid-filter,.pdwp-summary{grid-template-columns:1fr}.pdwp-top-actions{width:100%;flex-direction:column;align-items:stretch}.pdwp-top-actions>*{width:100%}.pdwp-table{min-width:1080px}.pdwp-table th{font-size:var(--fs-12);padding:10px 8px}.pdwp-table td{font-size:var(--fs-13);padding:10px 8px}.pdwp-row-actions{min-width:120px}}.pdwm-page{--pdwm-bg: #f8fafc;--pdwm-card: #ffffff;--pdwm-border: #dbe3ef;--pdwm-border-strong: #cbd5e1;--pdwm-text: #0f172a;--pdwm-muted: #475569;--pdwm-muted-2: #64748b;--pdwm-primary: #2563eb;--pdwm-primary-soft: #dbeafe;--pdwm-ok: #16a34a;--pdwm-ok-soft: #dcfce7;--pdwm-overdue: #dc2626;--pdwm-overdue-soft: #fee2e2;--pdwm-planned: #0284c7;--pdwm-planned-soft: #e0f2fe;--pdwm-skip: #92400e;--pdwm-skip-soft: #fef3c7;--pdwm-cancelled: #64748b;--pdwm-cancelled-soft: #f1f5f9;min-height:100dvh;padding:14px;background:var(--pdwm-bg);color:var(--pdwm-text);font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px;overflow-x:hidden;-webkit-text-size-adjust:100%}.pdwm-page,.pdwm-page *{box-sizing:border-box;min-width:0}.pdwm-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.pdwm-title{font-size:var(--fs-24);font-weight:900;line-height:1.15;color:var(--pdwm-text)}.pdwm-subtitle{margin-top:4px;font-size:var(--fs-13);color:var(--pdwm-muted);line-height:1.45}.pdwm-live-hint{min-height:40px;padding:0 12px;border:1px solid var(--pdwm-border);border-radius:12px;background:#fff;display:inline-flex;align-items:center;font-size:var(--fs-13);font-weight:800;color:var(--pdwm-muted);white-space:nowrap}.pdwm-card{background:var(--pdwm-card);border:1px solid var(--pdwm-border);border-radius:18px;box-shadow:0 8px 24px #0f172a0d}.pdwm-filter-card,.pdwm-legend-card,.pdwm-generate-card{padding:12px}.pdwm-filter-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.pdwm-filter-title{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-14);font-weight:900}.pdwm-filters,.pdwm-generate-grid{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.pdwm-field{display:flex;flex-direction:column;gap:4px;min-width:120px}.pdwm-field-search{min-width:260px;flex:1 1 260px}.pdwm-field label{font-size:var(--fs-12);font-weight:800;color:var(--pdwm-muted)}.pdwm-field input,.pdwm-field select,.pdwm-searchbox input,.pdwm-form-field input,.pdwm-form-field select,.pdwm-form-field textarea{width:100%;min-height:44px;padding:0 12px;border-radius:12px;border:1px solid var(--pdwm-border-strong);background:#fff;color:var(--pdwm-text);font-size:var(--fs-15);font-family:inherit;font-weight:700;outline:none}.pdwm-field input::placeholder,.pdwm-searchbox input::placeholder,.pdwm-form-field input::placeholder,.pdwm-form-field textarea::placeholder{color:#94a3b8;font-weight:500}.pdwm-field input:focus,.pdwm-field select:focus,.pdwm-searchbox:focus-within,.pdwm-form-field input:focus,.pdwm-form-field select:focus,.pdwm-form-field textarea:focus{border-color:var(--pdwm-primary);box-shadow:0 0 0 3px #2563eb24}.pdwm-searchbox{width:100%;height:44px;min-height:44px;padding:0 12px;border:1px solid var(--pdwm-border-strong);border-radius:14px;background:#fff;display:flex;align-items:center;gap:10px;overflow:hidden}.pdwm-searchbox:focus-within{border-color:var(--pdwm-primary);box-shadow:0 0 0 3px #2563eb24}.pdwm-search-icon{flex:0 0 auto;font-size:var(--fs-22);color:var(--pdwm-text)}.pdwm-search-input{flex:1 1 auto;width:100%;height:100%;min-height:0!important;padding:0!important;border:0!important;border-radius:0!important;outline:none!important;box-shadow:none!important;background:transparent!important;color:var(--pdwm-text);font-size:var(--fs-15);font-weight:700;font-family:inherit;-webkit-text-fill-color:var(--pdwm-text)}.pdwm-search-input::placeholder{color:#94a3b8;font-weight:700}.pdwm-search-input:focus{border:0!important;box-shadow:none!important;outline:none!important}.pdwm-btn{height:44px;padding:0 14px;border:1px solid var(--pdwm-border-strong);border-radius:12px;background:#fff;color:var(--pdwm-text);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-14);font-weight:800;font-family:inherit;cursor:pointer;white-space:nowrap;transition:transform .12s ease,background .12s ease,box-shadow .12s ease,border-color .12s ease}.pdwm-btn:active{transform:translateY(1px) scale(.99)}.pdwm-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pdwm-btn-primary{border-color:#93c5fd;background:linear-gradient(180deg,#fff,#f8fbff);color:#1d4ed8}.pdwm-btn-primary:hover{background:#eff6ff}.pdwm-btn-sm{height:38px;padding:0 12px;font-size:var(--fs-13)}.pdwm-btn-ghost{border:none;background:transparent}.pdwm-btn-icon{width:30px;height:30px;border:none;background:transparent;border-radius:999px;color:var(--pdwm-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.pdwm-btn-icon:hover{background:#f1f5f9}.pdwm-kpis{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.pdwm-kpi{background:#fff;border:1px solid var(--pdwm-border);border-radius:18px;padding:14px}.pdwm-kpi-top{display:flex;align-items:center;gap:8px}.pdwm-kpi-icon{width:32px;height:32px;border-radius:10px;background:#eff6ff;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center}.pdwm-kpi-label{font-size:var(--fs-12);font-weight:800;color:var(--pdwm-muted)}.pdwm-kpi-value{margin-top:10px;font-size:var(--fs-24);font-weight:900;line-height:1.1;font-variant-numeric:tabular-nums}.pdwm-legend{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.pdwm-legend-item{display:inline-flex;gap:8px;align-items:center;font-size:var(--fs-13);font-weight:700}.pdwm-legend-note{font-size:var(--fs-12);color:var(--pdwm-muted)}.pdwm-dot,.pdwm-cell{width:28px;height:28px;border-radius:999px;border:1.5px solid #94a3b8;background:#fff;color:#475569;font-size:var(--fs-14);font-weight:900;display:inline-flex;align-items:center;justify-content:center}.pdwm-cell{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.pdwm-cell:hover:not(:disabled){transform:scale(1.08);box-shadow:0 0 0 3px #2563eb1f}.pdwm-cell:disabled{cursor:default;opacity:.35}.pdwm-dot.is-done,.pdwm-cell.is-done{background:var(--pdwm-ok-soft);border-color:#86efac;color:var(--pdwm-ok)}.pdwm-dot.is-overdue,.pdwm-cell.is-overdue{background:var(--pdwm-overdue-soft);border-color:#fca5a5;color:var(--pdwm-overdue)}.pdwm-dot.is-skip,.pdwm-cell.is-skip{background:var(--pdwm-skip-soft);border-color:#fbbf24;color:var(--pdwm-skip)}.pdwm-dot.is-cancelled,.pdwm-cell.is-cancelled{background:var(--pdwm-cancelled-soft);border-color:#cbd5e1;color:var(--pdwm-cancelled)}.pdwm-dot.is-planned,.pdwm-cell.is-planned{background:var(--pdwm-planned-soft);border-color:#7dd3fc;color:var(--pdwm-planned)}.pdwm-cell.is-empty{background:#fff;border-color:#94a3b8;color:transparent}.pdwm-table-card{overflow:hidden;display:flex;flex-direction:column}.pdwm-table-headbar{position:sticky;top:0;z-index:40;padding:12px 14px;border-bottom:1px solid var(--pdwm-border);background:#fffffff5;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;justify-content:space-between;gap:10px;align-items:center}.pdwm-table-title{font-weight:900}.pdwm-pager{display:flex;gap:8px;align-items:center}.pdwm-table-wrap{position:relative;overflow:auto;max-width:100%;max-height:min(72dvh,calc(100dvh - 220px));overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.pdwm-table-wrap:focus-within{outline:2px solid rgba(37,99,235,.22);outline-offset:-2px}.pdwm-matrix-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-13)}.pdwm-matrix-table thead th{position:sticky;top:0;z-index:30;background:#f8fafc;border-bottom:1px solid var(--pdwm-border);box-shadow:0 2px #0f172a0d,0 8px 16px #0f172a0f;padding:10px 8px;white-space:nowrap;text-align:center;font-weight:900}.pdwm-day-head{min-width:38px;width:38px}.pdwm-day-week{font-size:var(--fs-10);font-weight:700;color:var(--pdwm-muted);margin-top:2px}.pdwm-matrix-table tbody td{border-bottom:1px solid #eef2f7;padding:6px;background:#fff;vertical-align:middle}.pdwm-matrix-table tbody tr:hover td{background:#fcfdff}.pdwm-sticky-col{position:sticky;background:#fff!important;z-index:4}.pdwm-matrix-table thead .pdwm-sticky-col{background:#f8fafc!important;z-index:45}.pdwm-sticky-1{left:0;min-width:250px;width:250px;border-right:1px solid var(--pdwm-border)}.pdwm-sticky-2{left:250px;min-width:150px;width:150px;border-right:1px solid var(--pdwm-border)}.pdwm-asset-name{font-weight:800;color:var(--pdwm-text);line-height:1.35}.pdwm-asset-sub{margin-top:4px;font-size:var(--fs-11);color:var(--pdwm-muted);line-height:1.35}.pdwm-uid{font-size:var(--fs-13);font-weight:900;color:#1d4ed8;word-break:break-word}.pdwm-cell-td{text-align:center}.pdwm-footnote{padding:10px 14px;border-top:1px solid var(--pdwm-border);font-size:var(--fs-12);color:var(--pdwm-muted)}.pdwm-empty{padding:20px;text-align:center;color:var(--pdwm-muted);font-weight:700}.pdwm-error{padding:12px 14px;border-radius:14px;background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;font-weight:800;white-space:pre-line}.pdwm-day-head.is-today{background:#fef3c7!important;color:#92400e;box-shadow:inset 0 -3px #f59e0b}.pdwm-cell-td.is-today{background:#fffbeb!important}.pdwm-matrix-table tbody tr:hover .pdwm-cell-td.is-today{background:#fef3c7!important}.pdwm-cell[draggable=true]{cursor:grab}.pdwm-cell[draggable=true]:active{cursor:grabbing}.pdwm-cell-td.is-drag-over{position:relative;background:#eff6ff!important;box-shadow:inset 0 0 0 2px #2563eb,inset 0 0 0 999px #2563eb0f}.pdwm-cell-td.is-drag-over:after{content:"Drop";position:absolute;left:50%;bottom:2px;transform:translate(-50%);padding:1px 6px;border-radius:999px;background:#2563eb;color:#fff;font-size:var(--fs-9);font-weight:900;line-height:1.3;pointer-events:none}.pdwm-drawer-backdrop{position:fixed;inset:0;background:#0f172a70;z-index:1000;display:flex;justify-content:flex-end}.pdwm-drawer{width:560px;max-width:100%;height:100%;background:#fff;display:flex;flex-direction:column;box-shadow:-12px 0 30px #0f172a29}.pdwm-drawer-header{padding:14px;border-bottom:1px solid var(--pdwm-border);display:flex;justify-content:space-between;gap:10px}.pdwm-drawer-title{font-size:var(--fs-16);font-weight:900}.pdwm-drawer-body{flex:1;overflow:auto;padding:14px}.pdwm-detail-list{display:flex;flex-direction:column;gap:10px}.pdwm-detail-card{border:1px solid var(--pdwm-border);border-radius:14px;padding:12px;background:#fff}.pdwm-detail-card-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;margin-bottom:12px}.pdwm-detail-title{font-size:var(--fs-15);font-weight:900;color:#1d4ed8}.pdwm-image-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}.pdwm-image-btn{border:none;background:transparent;padding:0;cursor:pointer}.pdwm-image-thumb,.pdwm-image-empty{width:88px;height:64px;border:1px solid var(--pdwm-border);border-radius:12px;background:#f8fafc;object-fit:cover;display:block}.pdwm-image-empty{display:flex;align-items:center;justify-content:center;color:#94a3b8}.pdwm-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px;margin-bottom:12px}.pdwm-kv{border:1px solid var(--pdwm-border);border-radius:14px;padding:10px;background:#fff}.pdwm-k{font-size:var(--fs-11);color:var(--pdwm-muted)}.pdwm-v{font-weight:700;color:var(--pdwm-text);word-break:break-word}.pdwm-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.pdwm-form-field{display:flex;flex-direction:column;gap:5px;font-size:var(--fs-12);font-weight:800;color:var(--pdwm-muted)}.pdwm-form-field textarea{min-height:74px;padding-top:10px;padding-bottom:10px;resize:vertical}.pdwm-form-field-wide{grid-column:1 / -1}.pdwm-check-field{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;color:var(--pdwm-text)}.pdwm-check-field input{width:16px;height:16px;accent-color:var(--pdwm-planned)}.pdwm-detail-actions{margin-top:12px;display:flex;justify-content:space-between;gap:10px;align-items:center}.pdwm-dirty{color:#b45309;font-weight:900;font-size:var(--fs-12)}.pdwm-muted{color:var(--pdwm-muted);font-size:var(--fs-12)}.pdwm-mono{font-family:var(--pps-font-mono)}.pdwm-lightbox{position:fixed;inset:0;z-index:9999;background:#020617b8;display:flex;align-items:center;justify-content:center;padding:16px}.pdwm-lightbox-dialog{width:min(960px,100%);max-height:calc(100vh - 32px);background:#fff;border-radius:18px;overflow:hidden;display:grid;grid-template-rows:auto 1fr}.pdwm-lightbox-head{padding:12px 14px;border-bottom:1px solid var(--pdwm-border);display:flex;align-items:center;justify-content:space-between;gap:12px}.pdwm-lightbox-title{font-size:var(--fs-14);font-weight:900}.pdwm-lightbox-image{max-width:100%;max-height:calc(100vh - 140px);object-fit:contain;border-radius:14px}.pdwm-spin{animation:pdwm-spin .8s linear infinite}@keyframes pdwm-spin{to{transform:rotate(360deg)}}@media(max-width:900px){.pdwm-table-wrap{max-height:min(70dvh,calc(100dvh - 180px))}.pdwm-matrix-table thead th{z-index:30}.pdwm-matrix-table thead .pdwm-sticky-col{z-index:45}}@media(max-width:900px){.pdwm-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.pdwm-sticky-1{min-width:220px;width:220px}.pdwm-sticky-2{left:220px;min-width:130px;width:130px}.pdwm-edit-grid,.pdwm-form-grid,.pdwm-image-row{grid-template-columns:1fr}}@media(max-width:640px){.pdwm-page{padding:12px}.pdwm-title{font-size:var(--fs-19)}.pdwm-live-hint{width:100%;justify-content:center}.pdwm-field,.pdwm-field-search{width:100%;min-width:100%}.pdwm-filters>.pdwm-btn,.pdwm-generate-grid>.pdwm-btn{width:100%}.pdwm-kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.pdwm-sticky-1{min-width:190px;width:190px}.pdwm-sticky-2{left:190px;min-width:115px;width:115px}.pdwm-drawer{width:100%}.pdwm-drawer-header{padding-top:calc(14px + env(safe-area-inset-top))}.pdwm-drawer-body{padding-bottom:calc(14px + env(safe-area-inset-bottom))}.pdwm-detail-actions{align-items:stretch;flex-direction:column}.pdwm-detail-actions .pdwm-btn{width:100%}}.pdwm-detail-card.is-locked{border-color:#fde68a;background:linear-gradient(180deg,#fffbeb,#fff 58%)}.pdwm-locked-note{margin:10px 0 12px;padding:10px 12px;border:1px solid #fde68a;border-radius:12px;background:#fffbeb;color:#92400e;font-size:var(--fs-13);font-weight:800;line-height:1.45}.pdwm-detail-card.is-locked input,.pdwm-detail-card.is-locked select,.pdwm-detail-card.is-locked textarea{background:#f8fafc;color:#64748b;cursor:not-allowed}.pdwm-page{min-height:100dvh;width:100%;max-width:100%;display:grid;gap:16px;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;overflow-x:hidden}.pdwm-page *{min-width:0}.pdwm-card{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);box-shadow:var(--pps-shadow);padding:16px;min-width:0}.pdwm-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap}.pdwm-title{display:flex;align-items:center;gap:10px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25;color:var(--pps-text)}.pdwm-subtitle{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45}.pdwm-top-actions,.pdwm-upload-row,.pdwm-drawer-foot{display:flex;gap:8px;flex-wrap:wrap}.pdwm-btn,.pdwm-btn-primary,.pdwm-btn-soft,.pdwm-upload-btn,.pdwm-clear-btn{min-height:38px;padding:0 14px;border-radius:var(--pps-radius-sm);display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:1px solid var(--pps-border-strong);background:#fff;color:var(--pps-text);font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);text-decoration:none;white-space:nowrap;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease}.pdwm-btn:hover,.pdwm-btn-primary:hover,.pdwm-btn-soft:hover,.pdwm-upload-btn:hover,.pdwm-clear-btn:hover{transform:translateY(-1px)}.pdwm-btn:hover{background:#f8fafc}.pdwm-btn-primary{border:none;color:#fff;background:linear-gradient(135deg,#0284c7,#0369a1);box-shadow:0 6px 14px #0284c72e}.pdwm-btn-primary:hover{background:linear-gradient(135deg,#0369a1,#075985)}.pdwm-btn-soft,.pdwm-upload-btn{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.pdwm-btn-soft:hover,.pdwm-upload-btn:hover{background:#dbeafe;border-color:#93c5fd}.pdwm-clear-btn{color:#b91c1c;background:#fff1f2;border-color:#fecdd3}.pdwm-clear-btn:hover{background:#ffe4e6}.pdwm-btn:disabled,.pdwm-btn-primary:disabled,.pdwm-btn-soft:disabled,.pdwm-upload-btn:disabled,.pdwm-clear-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.pdwm-toolbar{display:grid;grid-template-columns:minmax(220px,1.5fr) repeat(3,minmax(140px,.7fr)) auto;gap:12px;align-items:center}.pdwm-search{min-height:40px;display:flex;align-items:center;gap:8px;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:0 12px;background:#f8fafc;color:var(--pps-muted)}.pdwm-search input,.pdwm-field input,.pdwm-field select,.pdwm-field textarea,.pdwm-toolbar select{width:100%;border:1px solid var(--pps-border-strong);background:#f8fafc;color:var(--pps-text);border-radius:var(--pps-radius-sm);padding:0 12px;outline:none;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);line-height:1.45}.pdwm-search input{height:38px;border:none;padding:0;background:transparent}.pdwm-field input,.pdwm-field select,.pdwm-toolbar select{min-height:40px}.pdwm-field textarea{min-height:90px;padding-top:10px;padding-bottom:10px;resize:vertical}.pdwm-search input::placeholder,.pdwm-field input::placeholder,.pdwm-field textarea::placeholder{color:#94a3b8;font-weight:500}.pdwm-search:focus-within,.pdwm-field input:focus,.pdwm-field select:focus,.pdwm-field textarea:focus,.pdwm-toolbar select:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pdwm-table-wrap{overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);background:#fff;-webkit-overflow-scrolling:touch}.pdwm-table{width:100%;min-width:1180px;border-collapse:separate;border-spacing:0}.pdwm-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pdwm-table td{color:var(--pps-text);font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap}.pdwm-table tbody tr:nth-child(2n){background:#fafafa}.pdwm-table tbody tr:hover{background:#f1f5f9}.pdwm-empty{text-align:center;color:var(--pps-muted);padding:24px;font-size:var(--pps-text-md);font-weight:600}.pdwm-thumb-btn{border:none;background:transparent;padding:0;cursor:pointer}.pdwm-thumb,.pdwm-thumb-empty{width:76px;height:56px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border);background:#f8fafc;object-fit:cover;display:block}.pdwm-thumb-empty{display:flex;align-items:center;justify-content:center;color:#94a3b8}.pdwm-pill{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid transparent;white-space:nowrap}.pdwm-pill.on{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.pdwm-pill.off{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.pdwm-last-check{display:grid;gap:4px}.pdwm-drawer-backdrop{position:fixed;inset:0;z-index:9999;background:#0206178c;display:flex;justify-content:flex-end}.pdwm-drawer{width:min(720px,100%);height:100%;background:#fff;display:grid;grid-template-rows:auto 1fr auto;box-shadow:-8px 0 30px #0f172a2e}.pdwm-drawer-head,.pdwm-drawer-foot{padding:16px;border-bottom:1px solid var(--pps-border)}.pdwm-drawer-foot{border-bottom:none;border-top:1px solid var(--pps-border);justify-content:flex-end}.pdwm-drawer-body{padding:16px;overflow:auto}.pdwm-drawer-title{font-size:var(--pps-text-lg);font-weight:800;color:var(--pps-text)}.pdwm-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.pdwm-field{min-width:0}.pdwm-field label{display:block;margin-bottom:6px;font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.pdwm-span-2{grid-column:span 2}.pdwm-file-meta{margin-top:8px;color:var(--pps-muted);font-size:var(--pps-text-xs);font-weight:500;line-height:1.45;word-break:break-all}.pdwm-preview-wrap{margin-top:10px;display:grid;gap:8px;justify-content:flex-start}.pdwm-preview-btn{padding:0;border:none;background:transparent;width:fit-content;cursor:pointer}.pdwm-preview-image,.pdwm-preview-empty{width:100%;max-width:260px;height:170px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border);background:#f8fafc;overflow:hidden}.pdwm-preview-image{object-fit:cover;display:block}.pdwm-preview-empty{display:flex;align-items:center;justify-content:center;gap:8px;color:#94a3b8;font-size:var(--pps-text-sm);font-weight:600}.pdwm-lightbox{position:fixed;inset:0;z-index:10000;background:#020617b8;display:flex;align-items:center;justify-content:center;padding:16px}.pdwm-lightbox-dialog{width:min(960px,100%);max-height:calc(100vh - 32px);background:#fff;border-radius:var(--pps-radius-lg);overflow:hidden;display:grid;grid-template-rows:auto 1fr}.pdwm-lightbox-head{padding:12px 14px;border-bottom:1px solid var(--pps-border);display:flex;align-items:center;justify-content:space-between;gap:12px}.pdwm-lightbox-title{font-size:var(--pps-text-md);font-weight:800;color:var(--pps-text)}.pdwm-lightbox-body{padding:12px;display:flex;align-items:center;justify-content:center;background:#f8fafc;min-height:220px}.pdwm-lightbox-image{display:block;max-width:100%;max-height:calc(100vh - 140px);object-fit:contain;border-radius:var(--pps-radius-md)}@media(max-width:1100px){.pdwm-toolbar{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.pdwm-page{padding:12px;gap:12px}.pdwm-card{padding:12px;border-radius:14px}.pdwm-topbar{align-items:flex-start}.pdwm-title{font-size:var(--fs-18)}.pdwm-form-grid,.pdwm-toolbar{grid-template-columns:1fr}.pdwm-span-2{grid-column:span 1}.pdwm-top-actions,.pdwm-drawer-foot{width:100%;flex-direction:column;align-items:stretch}.pdwm-top-actions>*,.pdwm-drawer-foot>*{width:100%}.pdwm-drawer{width:100%}.pdwm-table{min-width:1080px}.pdwm-table th{font-size:var(--fs-12);padding:10px 8px}.pdwm-table td{font-size:var(--fs-13);padding:10px 8px}.pdwm-preview-image,.pdwm-preview-empty{max-width:180px;height:120px}}.pdwqr-page{padding:16px;background:#f8fafc}.pdwqr-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.pdwqr-actions{display:flex;gap:8px}.pdwqr-actions input{height:36px;padding:0 10px}.pdwqr-actions button{padding:6px 12px;border-radius:8px}.pdwqr-actions .primary{background:#0284c7;color:#fff}.pdwqr-sheet{background:#fff;padding:16px;border-radius:12px}.pdwqr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.pdwqr-card{border:1px solid #e2e8f0;border-radius:10px;padding:10px;text-align:center}.pdwqr-uid{font-weight:900;margin-top:6px}.pdwqr-name{font-size:var(--fs-12)}.pdwqr-sec{font-size:var(--fs-11);color:#64748b}@media print{.no-print{display:none}.pdwqr-grid{grid-template-columns:repeat(3,1fr)}}.pdwnem-page{display:grid;gap:16px;padding:16px}.pdwnem-topbar,.pdwnem-card{background:#fff;border:1px solid #dbe3ef;border-radius:18px;box-shadow:0 8px 24px #0f172a0f}.pdwnem-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 18px}.pdwnem-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-22);font-weight:900;color:#0f172a}.pdwnem-sub{margin-top:6px;color:#475569;font-size:var(--fs-14)}.pdwnem-topbar-actions,.pdwnem-actions{display:flex;gap:10px;flex-wrap:wrap}.pdwnem-card{padding:16px}.pdwnem-card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.pdwnem-card-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-18);font-weight:900;color:#0f172a}.pdwnem-form{display:grid;gap:12px}.pdwnem-grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.pdwnem-field{display:grid;gap:6px}.pdwnem-field label{font-size:var(--fs-13);font-weight:800;color:#0f172a}.pdwnem-field input{width:100%;min-height:44px;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px;font-size:var(--fs-15);color:#0f172a;background:#fff}.pdwnem-field input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.pdwnem-checkrow{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#0f172a}.pdwnem-btn,.pdwnem-btn-primary{min-height:42px;border-radius:12px;border:1px solid #cbd5e1;padding:0 14px;display:inline-flex;align-items:center;gap:8px;font-weight:800;cursor:pointer;background:#fff;color:#0f172a}.pdwnem-btn-primary{border-color:#2563eb;background:#2563eb;color:#fff}.pdwnem-btn-ghost{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.pdwnem-btn-sm{min-height:36px;padding:0 10px;font-size:var(--fs-13)}.pdwnem-filterbar{margin-bottom:12px}.pdwnem-searchbar{position:relative}.pdwnem-searchbar input{width:100%;min-height:44px;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px 10px 40px}.pdwnem-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.pdwnem-table-wrap{overflow:auto}.pdwnem-table{width:100%;border-collapse:collapse;min-width:1050px}.pdwnem-table th,.pdwnem-table td{border-bottom:1px solid #e2e8f0;padding:10px 12px;text-align:left;vertical-align:top}.pdwnem-table th{background:#f8fafc;color:#0f172a;font-size:var(--fs-13);font-weight:900}.pdwnem-table td{color:#334155;font-size:var(--fs-14)}.pdwnem-empty{text-align:center;color:#64748b;padding:24px!important}.pdwnem-status{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:var(--fs-12);font-weight:900}.pdwnem-status.ok{color:#166534;background:#dcfce7}.pdwnem-status.off{color:#991b1b;background:#fee2e2}@media(max-width:900px){.pdwnem-topbar{flex-direction:column}.pdwnem-grid2{grid-template-columns:1fr}}*,*:before,*:after{box-sizing:border-box}:root{--pps-font-main: "Inter", "Noto Sans Thai", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--pps-bg: #f8fafc;--pps-card: #ffffff;--pps-border: #e5e7eb;--pps-border-strong: #cbd5e1;--pps-text: #0f172a;--pps-text-soft: #334155;--pps-muted: #64748b;--pps-primary: #0369a1;--pps-radius-sm: 10px;--pps-radius-md: 14px;--pps-radius-lg: 18px;--pps-shadow: 0 4px 16px rgba(15, 23, 42, .05);--pps-text-xs: 12px;--pps-text-sm: 13px;--pps-text-md: 14px;--pps-text-lg: 16px;--pps-text-xl: 20px}.pdwr-page{min-height:100%;width:100%;max-width:100%;display:grid;gap:16px;padding:16px;background:var(--pps-bg);color:var(--pps-text);font-family:var(--pps-font-main);font-size:var(--pps-text-md);line-height:1.5;overflow-x:hidden}.pdwr-card,.pdwr-topbar{background:var(--pps-card);border:1px solid var(--pps-border);border-radius:var(--pps-radius-lg);box-shadow:var(--pps-shadow);min-width:0}.pdwr-card{padding:16px}.pdwr-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;padding:16px;flex-wrap:wrap}.pdwr-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-xl);font-weight:800;line-height:1.25;color:var(--pps-text)}.pdwr-subtitle{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-sm);font-weight:500;line-height:1.45}.pdwr-card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}.pdwr-card-title{display:flex;align-items:center;gap:8px;font-size:var(--pps-text-lg);font-weight:800;line-height:1.35;color:var(--pps-text)}.pdwr-top-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.pdwr-btn,.pdwr-btn-soft{min-height:38px;border-radius:var(--pps-radius-sm);border:1px solid var(--pps-border-strong);padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--pps-text-sm);font-weight:700;font-family:var(--pps-font-main);cursor:pointer;background:#fff;color:var(--pps-text);white-space:nowrap;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.pdwr-btn:hover,.pdwr-btn-soft:hover{transform:translateY(-1px)}.pdwr-btn-soft{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8}.pdwr-btn:disabled,.pdwr-btn-soft:disabled{opacity:.6;cursor:not-allowed;transform:none}.pdwr-filter-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.pdwr-field{display:grid;gap:6px}.pdwr-field label{font-size:var(--pps-text-sm);font-weight:800;color:var(--pps-text)}.pdwr-field input,.pdwr-field select,.pdwr-searchbar input{width:100%;min-height:40px;border:1px solid var(--pps-border-strong);border-radius:var(--pps-radius-sm);padding:0 12px;font-size:var(--pps-text-md);font-weight:600;font-family:var(--pps-font-main);color:var(--pps-text);background:#f8fafc;outline:none}.pdwr-searchbar input{padding-left:40px}.pdwr-field input::placeholder,.pdwr-searchbar input::placeholder{color:#94a3b8;font-weight:500}.pdwr-field input:focus,.pdwr-field select:focus,.pdwr-searchbar input:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 3px #0ea5e91f}.pdwr-searchbar{position:relative;margin-top:12px}.pdwr-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--pps-muted)}.pdwr-summary{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.pdwr-metric-k{display:flex;align-items:center;gap:8px;color:var(--pps-muted);font-size:var(--pps-text-xs);font-weight:700;line-height:1.4}.pdwr-metric-v{margin-top:6px;font-size:var(--fs-22);line-height:1.2;font-weight:800;color:var(--pps-text);font-variant-numeric:tabular-nums}.pdwr-table-wrap{overflow:auto;border:1px solid var(--pps-border);border-radius:var(--pps-radius-md);background:#fff;-webkit-overflow-scrolling:touch}.pdwr-table{width:100%;border-collapse:collapse;min-width:1280px}.pdwr-table th{position:sticky;top:0;z-index:2;background:#f8fafc;color:var(--pps-text-soft);font-size:var(--fs-13);font-weight:800;font-family:var(--pps-font-main);line-height:1.45;letter-spacing:.2px;text-align:left;white-space:nowrap;padding:12px;border-bottom:1px solid var(--pps-border)}.pdwr-table td{color:var(--pps-text);font-size:var(--fs-14);font-weight:500;font-family:var(--pps-font-main);line-height:1.5;padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:middle;white-space:nowrap}.pdwr-table tbody tr:nth-child(2n){background:#fafafa}.pdwr-table tbody tr:hover{background:#f1f5f9}.pdwr-empty{text-align:center;color:var(--pps-muted);padding:24px!important;font-size:var(--pps-text-md);font-weight:600}.pdwr-status{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:700;line-height:1.2;white-space:nowrap}.pdwr-status.ok{color:#166534;background:#ecfdf5;border:1px solid #bbf7d0}.pdwr-status.ng{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.pdwr-status.pending{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.pdwr-status.skip{color:#374151;background:#f3f4f6;border:1px solid #d1d5db}.pdwr-help{margin-top:4px;color:var(--pps-muted);font-size:var(--pps-text-xs);font-weight:500;line-height:1.35}.mono{font-family:var(--pps-font-mono);font-size:inherit;font-weight:600;letter-spacing:0;font-variant-numeric:tabular-nums}@media(max-width:1200px){.pdwr-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.pdwr-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.pdwr-page{padding:12px;gap:12px}.pdwr-topbar{flex-direction:column;align-items:stretch;padding:12px;border-radius:14px}.pdwr-title{font-size:var(--fs-18)}.pdwr-card{padding:12px;border-radius:14px}.pdwr-filter-grid,.pdwr-summary{grid-template-columns:1fr}.pdwr-top-actions{flex-direction:column;align-items:stretch}.pdwr-btn,.pdwr-btn-soft{width:100%}.pdwr-table th{font-size:var(--fs-12);padding:10px 8px}.pdwr-table td{font-size:var(--fs-13);padding:10px 8px}}.pmpp-page{--pmpp-bg: #f8fafc;--pmpp-card: #ffffff;--pmpp-border: #dbe3ef;--pmpp-text: #0f172a;--pmpp-muted: #475569;--pmpp-primary: #2563eb;--pmpp-primary-soft: #dbeafe;--pmpp-done: #16a34a;--pmpp-done-soft: #dcfce7;--pmpp-overdue: #dc2626;--pmpp-overdue-soft: #fee2e2;--pmpp-pending: #94a3b8;--pmpp-pending-soft: #f1f5f9;--pmpp-planned: #0284c7;--pmpp-planned-soft: #e0f2fe;--pmpp-wait: #7c3aed;--pmpp-wait-soft: #ede9fe;--pmpp-change: #dc2626;--pmpp-change-soft: #fee2e2;--pmpp-other: #92400e;--pmpp-other-soft: #fef3c7;min-height:100dvh;padding:14px;background:var(--pmpp-bg);color:var(--pmpp-text);font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px;-webkit-text-size-adjust:100%}.pmpp-page,.pmpp-page *{box-sizing:border-box}.pmpp-topbar{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}.pmpp-title{font-size:var(--fs-24);font-weight:900;line-height:1.15;color:var(--pmpp-text)}.pmpp-subtitle{margin-top:4px;font-size:var(--fs-13);color:var(--pmpp-muted);line-height:1.4}.pmpp-live-hint{min-height:40px;padding:0 12px;border-radius:12px;border:1px solid var(--pmpp-border);background:#fff;display:inline-flex;align-items:center;font-size:var(--fs-13);font-weight:800;color:var(--pmpp-muted)}.pmpp-card{background:var(--pmpp-card);border:1px solid var(--pmpp-border);border-radius:18px;box-shadow:0 8px 24px #0f172a0d}.pmpp-filter-card,.pmpp-legend-card{padding:12px}.pmpp-filter-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.pmpp-filter-title{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-14);font-weight:900}.pmpp-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.pmpp-field{display:flex;flex-direction:column;gap:4px;min-width:120px}.pmpp-field label{font-size:var(--fs-12);font-weight:800;color:var(--pmpp-muted)}.pmpp-field-search{min-width:260px;flex:1 1 260px}.pmpp-select,.pmpp-input{width:100%;height:44px;padding:0 12px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;color:var(--pmpp-text);font-size:var(--fs-16);-webkit-text-fill-color:var(--pmpp-text)}.pmpp-select:focus,.pmpp-input:focus,.pmpp-searchbox:focus-within{outline:none;border-color:var(--pmpp-primary);box-shadow:0 0 0 3px #2563eb24}.pmpp-searchbox{min-height:44px;padding:0 10px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;display:flex;align-items:center;gap:8px}.pmpp-searchbox .pmpp-input{border:none;box-shadow:none;padding:0;background:transparent}.pmpp-btn{height:44px;padding:0 14px;border-radius:12px;border:1px solid #cbd5e1;background:#fff;color:var(--pmpp-text);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-14);font-weight:800;cursor:pointer;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.pmpp-btn:hover{background:#f8fafc}.pmpp-btn:active{transform:translateY(1px) scale(.99)}.pmpp-btn:disabled{opacity:.6;cursor:not-allowed}.pmpp-btn-primary{border-color:#93c5fd;background:linear-gradient(180deg,#fff,#f8fbff)}.pmpp-btn-reset{background:#f8fafc}.pmpp-btn-sm{height:38px;padding:0 12px;font-size:var(--fs-13)}.pmpp-btn-ghost{border:none;background:transparent}.pmpp-btn-icon{width:30px;height:30px;border:none;background:transparent;border-radius:999px;color:var(--pmpp-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.pmpp-kpis{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.pmpp-kpi{background:#fff;border:1px solid var(--pmpp-border);border-radius:18px;padding:14px}.pmpp-kpi-top{display:flex;align-items:center;gap:8px}.pmpp-kpi-icon{width:32px;height:32px;border-radius:10px;background:#eff6ff;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center}.pmpp-kpi-label{font-size:var(--fs-12);font-weight:800;color:var(--pmpp-muted)}.pmpp-kpi-value{margin-top:10px;font-size:var(--fs-24);font-weight:900}.pmpp-legend{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.pmpp-legend-item{display:inline-flex;gap:8px;align-items:center;font-size:var(--fs-13);font-weight:700}.pmpp-legend-note{font-size:var(--fs-12);color:var(--pmpp-muted)}.pmpp-dot,.pmpp-cell{width:28px;height:28px;border-radius:999px;border:1.5px solid #94a3b8;background:#fff;color:#475569;font-size:var(--fs-14);font-weight:900;display:inline-flex;align-items:center;justify-content:center}.pmpp-cell{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.pmpp-cell:hover:not(:disabled){transform:scale(1.08);box-shadow:0 0 0 3px #2563eb1f}.pmpp-cell:disabled{cursor:default;opacity:.35}.pmpp-dot.is-done,.pmpp-cell.is-done{background:var(--pmpp-done-soft);border-color:#86efac;color:var(--pmpp-done)}.pmpp-dot.is-overdue,.pmpp-cell.is-overdue,.pmpp-dot.is-change,.pmpp-cell.is-change{background:var(--pmpp-overdue-soft);border-color:#fca5a5;color:var(--pmpp-overdue)}.pmpp-dot.is-planned,.pmpp-cell.is-planned{background:var(--pmpp-planned-soft);border-color:#7dd3fc;color:var(--pmpp-planned)}.pmpp-dot.is-wait,.pmpp-cell.is-wait{background:var(--pmpp-wait-soft);border-color:#a78bfa;color:var(--pmpp-wait)}.pmpp-dot.is-other,.pmpp-cell.is-other{background:var(--pmpp-other-soft);border-color:#f59e0b;color:var(--pmpp-other)}.pmpp-cell.is-empty{background:#fff;border-color:#94a3b8;color:transparent}.pmpp-table-headbar{padding:12px 14px;border-bottom:1px solid var(--pmpp-border);display:flex;justify-content:space-between;gap:10px;align-items:center}.pmpp-table-title{font-weight:900}.pmpp-pager{display:flex;gap:8px;align-items:center}.pmpp-table-wrap{overflow:auto;max-width:100%}.pmpp-matrix-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-13)}.pmpp-matrix-table thead th{position:sticky;top:0;z-index:5;background:#f8fafc;border-bottom:1px solid var(--pmpp-border);padding:10px 8px;white-space:nowrap;text-align:center;font-weight:900}.pmpp-day-head{min-width:38px;width:38px}.pmpp-day-week{font-size:var(--fs-10);font-weight:700;color:var(--pmpp-muted);margin-top:2px}.pmpp-matrix-table tbody td{border-bottom:1px solid #eef2f7;padding:6px;background:#fff}.pmpp-matrix-table tbody tr:hover td{background:#fcfdff}.pmpp-sticky-col{position:sticky;background:#fff!important;z-index:4}.pmpp-matrix-table thead .pmpp-sticky-col{background:#f8fafc!important;z-index:6}.pmpp-sticky-1{left:0;min-width:250px;width:250px;border-right:1px solid var(--pmpp-border)}.pmpp-sticky-2{left:250px;min-width:150px;width:150px;border-right:1px solid var(--pmpp-border)}.pmpp-machine-name{font-weight:800;color:var(--pmpp-text)}.pmpp-machine-sub{margin-top:4px;font-size:var(--fs-11);color:var(--pmpp-muted);line-height:1.35}.pmpp-pm-code{font-size:var(--fs-13);font-weight:800;color:#1d4ed8}.pmpp-cell-td{text-align:center}.pmpp-footnote{padding:10px 14px;border-top:1px solid var(--pmpp-border);font-size:var(--fs-12);color:var(--pmpp-muted)}.pmpp-empty{padding:20px;text-align:center;color:var(--pmpp-muted)}.pmpp-error{padding:12px 14px;border-radius:14px;background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;font-weight:800}.pmpp-drawer-backdrop{position:fixed;inset:0;background:#0f172a70;z-index:1000;display:flex;justify-content:flex-end}.pmpp-drawer{width:460px;max-width:100%;height:100%;background:#fff;display:flex;flex-direction:column}.pmpp-drawer-header{padding:14px;border-bottom:1px solid var(--pmpp-border);display:flex;justify-content:space-between;gap:10px}.pmpp-drawer-title{font-size:var(--fs-16);font-weight:900}.pmpp-drawer-body{flex:1;overflow:auto;padding:14px}.pmpp-detail-list{display:flex;flex-direction:column;gap:10px}.pmpp-detail-card{border:1px solid var(--pmpp-border);border-radius:14px;padding:12px;background:#fff}.pmpp-detail-card-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;margin-bottom:12px}.pmpp-detail-title{font-size:var(--fs-15);font-weight:900;color:#1d4ed8}.pmpp-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}.pmpp-kv{border:1px solid var(--pmpp-border);border-radius:14px;padding:10px;background:#fff}.pmpp-k{font-size:var(--fs-11);color:var(--pmpp-muted)}.pmpp-v{font-weight:700;color:var(--pmpp-text)}.pmpp-muted{color:var(--pmpp-muted);font-size:var(--fs-12)}.pmpp-mono{font-family:var(--pps-font-mono)}.pmpp-spin{animation:pmpp-spin .8s linear infinite}@keyframes pmpp-spin{to{transform:rotate(360deg)}}@media(max-width:900px){.pmpp-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.pmpp-sticky-1{min-width:220px;width:220px}.pmpp-sticky-2{left:220px;min-width:130px;width:130px}.pmpp-detail-grid{grid-template-columns:1fr}}@media(max-width:640px){.pmpp-page{padding:12px}.pmpp-title{font-size:var(--fs-19)}.pmpp-field,.pmpp-field-search{width:100%;min-width:100%}.pmpp-kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.pmpp-sticky-1{min-width:190px;width:190px}.pmpp-sticky-2{left:190px;min-width:115px;width:115px}.pmpp-drawer{width:100%;max-width:100%}.pmpp-drawer-header{padding-top:calc(14px + env(safe-area-inset-top))}.pmpp-drawer-body{padding-bottom:calc(14px + env(safe-area-inset-bottom))}}.pmpp-day-head.is-today{background:#fef3c7!important;color:#92400e;box-shadow:inset 0 -3px #f59e0b}.pmpp-cell-td.is-today{background:#fffbeb!important}.pmpp-matrix-table tbody tr:hover .pmpp-cell-td.is-today{background:#fef3c7!important}.pmpp-table-card{overflow:hidden}.pmpp-table-wrap{overflow:auto;max-width:100%;max-height:60vh;background:#fff;border-top:1px solid var(--dc3-border);-webkit-overflow-scrolling:touch}.pmpp-table{width:max-content;min-width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-13)}.pmpp-table thead th{position:sticky;top:0;z-index:20;background:#f8fafc;border-bottom:1px solid var(--dc3-border);box-shadow:0 2px 6px #0f172a14;padding:10px 8px;white-space:nowrap;text-align:center;font-weight:900}.sticky-col{position:sticky;background:#fff!important;z-index:5}.pmpp-table thead .sticky-col{background:#f8fafc!important;z-index:25}.sticky-col-1{left:0;min-width:110px;width:110px;border-right:1px solid var(--dc3-border)}.sticky-col-2{left:110px;min-width:250px;width:250px;border-right:1px solid var(--dc3-border)}.sa-page{padding:16px 18px;background:#f8fafc;color:#0f172a;font-family:var(--pps-font-main);display:flex;flex-direction:column;gap:12px;min-height:0}.sa-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:12px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.sa-title{font-size:var(--fs-18);font-weight:900}.sa-sub{margin-top:2px;font-size:var(--fs-12);color:#64748b}.sa-filterbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:12px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:14px}.sa-filter-left{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}.sa-filter-right{display:flex;align-items:center;gap:10px}.sa-count{font-size:var(--fs-12);color:#64748b;font-weight:800}.sa-count b{color:#0f172a}.sa-field-inline{width:auto;min-width:160px}.sa-q{min-width:260px}.sa-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:12px;min-height:0}.sa-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:12px 14px;min-height:0}.sa-card-hd{display:flex;flex-direction:column;gap:2px;margin-bottom:10px}.sa-h2{font-size:var(--fs-14);font-weight:900}.sa-hint{font-size:var(--fs-12);color:#64748b}.sa-form{display:flex;flex-direction:column;gap:10px}.sa-field{display:flex;flex-direction:column;gap:6px}.sa-field>span{font-size:var(--fs-12);color:#475569;font-weight:700}.sa-field input,.sa-field select{border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px;outline:none;font-size:var(--fs-14);background:#fff}.sa-scan{font-size:var(--fs-16);letter-spacing:.3px}.sa-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.sa-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-weight:800;font-size:var(--fs-13);-webkit-user-select:none;user-select:none}.sa-btn:disabled{opacity:.55;cursor:not-allowed}.sa-btn-primary{background:#0f172a;color:#fff}.sa-btn-success{background:#16a34a;color:#fff}.sa-btn-ghost{background:#fff;color:#0f172a;border-color:#e2e8f0}.sa-woinfo{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:10px 12px;border:1px solid #e2e8f0;border-radius:14px;background:#f8fafc}.sa-woitem{display:flex;flex-direction:column;gap:4px;min-width:0}.sa-woitem .k{font-size:var(--fs-11);color:#64748b;font-weight:800}.sa-woitem .v{font-size:var(--fs-13);color:#0f172a;font-weight:900;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sa-woitem-wide{grid-column:1 / -1}.sa-created{margin-top:12px;padding-top:12px;border-top:1px dashed #e2e8f0;display:flex;flex-direction:column;gap:8px}.sa-created-label{font-size:var(--fs-12);color:#64748b;font-weight:800}.sa-serial{font-size:var(--fs-22);font-weight:1000;letter-spacing:.8px;line-height:1.1}.sa-created-meta{display:flex;flex-wrap:wrap;gap:10px}.sa-created-meta .m{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#f8fafc;border:1px solid #e2e8f0;max-width:100%}.sa-created-meta .k{font-size:var(--fs-11);color:#64748b;font-weight:900}.sa-created-meta .v{font-size:var(--fs-12);color:#0f172a;font-weight:900;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:360px}.sa-badges{display:flex;gap:8px;flex-wrap:wrap}.sa-badge{font-size:var(--fs-12);font-weight:800;padding:6px 10px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc}.sa-badge.ok{border-color:#bbf7d0;background:#f0fdf4;color:#166534}.sa-badge.wait{border-color:#fde68a;background:#fffbeb;color:#92400e}.sa-badge.info{border-color:#bae6fd;background:#f0f9ff;color:#075985}.sa-created-actions{display:flex;gap:10px;flex-wrap:wrap}.sa-note{font-size:var(--fs-12);color:#64748b;line-height:1.5}.sa-note-muted{color:#94a3b8;font-weight:700}@media(max-width:980px){.sa-grid{grid-template-columns:1fr}.sa-q{min-width:220px}.sa-field-inline{min-width:140px}}@media(max-width:560px){.sa-filterbar{align-items:stretch}.sa-filter-left{width:100%}.sa-filter-right{width:100%;justify-content:flex-start}.sa-woinfo{grid-template-columns:1fr}.sa-created-meta .v{max-width:240px}}.stcd-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--fs-2xl: 1.75rem;--lh-tight: 1.2;--lh-base: 1.45;--lh-relax: 1.6;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);overflow:auto;-webkit-overflow-scrolling:touch;font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base)}.stcd-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stcd-title{font-size:var(--fs-lg);font-weight:700;letter-spacing:.2px;line-height:var(--lh-tight)}.stcd-sub{margin-top:4px;font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stcd-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stcd-btn{height:38px;padding:0 12px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stcd-btn:hover{box-shadow:var(--shadow-sm)}.stcd-btn:active{transform:translateY(1px)}.stcd-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stcd-btn-primary{border-color:transparent;background:var(--primary);color:#fff}.stcd-btn-primary:hover{background:var(--primary2)}.stcd-btn-danger{border-color:transparent;background:var(--danger);color:#fff}.stcd-error{background:var(--danger-bg);border:1px solid #fecdd3;color:#9f1239;padding:10px 12px;border-radius:12px;font-weight:700;font-size:var(--fs-sm);line-height:var(--lh-base);margin:8px 0 12px}.stcd-kpiRow{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:12px}@media(min-width:720px){.stcd-kpiRow{grid-template-columns:repeat(3,1fr)}}.stcd-kpiCard{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm);min-height:0}.stcd-kpiLabel{font-size:var(--fs-xxs);color:var(--muted);font-weight:700;display:flex;align-items:center;gap:6px;line-height:var(--lh-tight)}.stcd-kpiValue{margin-top:4px;font-size:var(--fs-2xl);font-weight:700;letter-spacing:.2px;line-height:var(--lh-tight)}.stcd-kpiHint{margin-top:4px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stcd-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm);margin-bottom:12px;min-height:0}.stcd-sectionHead{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stcd-sectionTitle{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stcd-sectionRight{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stcd-modeToggle{display:flex;flex-wrap:wrap;border:1px solid var(--border);background:var(--card);border-radius:12px;overflow:hidden}.stcd-modeBtn{height:38px;padding:0 12px;border:0;background:transparent;color:var(--muted);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stcd-modeBtn:hover{background:#f8fafc}.stcd-modeBtn.is-active{background:var(--soft);color:var(--primary)}.stcd-modeIcon{display:inline-flex;align-items:center;justify-content:center}.stcd-statusGrid{display:grid;grid-template-columns:1fr;gap:10px}@media(min-width:560px){.stcd-statusGrid{grid-template-columns:repeat(2,1fr)}}@media(min-width:980px){.stcd-statusGrid{grid-template-columns:repeat(5,1fr)}}.stcd-statusCard{width:100%;text-align:left;border:1px solid var(--border);border-radius:14px;background:#fff;padding:10px;cursor:pointer;min-height:0;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stcd-statusCard:hover{box-shadow:var(--shadow-sm);border-color:#cbd5e1}.stcd-statusCard:active{transform:translateY(1px)}.stcd-statusTop{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.stcd-statusLabel{font-size:var(--fs-xxs);font-weight:700;color:var(--muted);line-height:var(--lh-tight)}.stcd-statusCount{font-size:var(--fs-xl);font-weight:700;line-height:var(--lh-tight)}.stcd-statusHint{margin-top:4px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stcd-tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border-radius:12px;border:1px solid var(--border);position:relative;background:#fff;min-height:0;max-height:400px}.stcd-table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px;background:#fff}.stcd-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;color:#334155;font-size:var(--fs-xxs);font-weight:700;padding:10px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;line-height:var(--lh-tight);box-shadow:0 1px #0f172a0f}.stcd-table tbody td{padding:10px;border-bottom:1px solid #f1f5f9;font-size:var(--fs-xs);line-height:var(--lh-base);vertical-align:top}.stcd-table tbody tr:hover td{background:#fafcff}.stcd-tdMuted{color:var(--muted)}.stcd-tdMono{font-family:var(--pps-font-mono)}.stcd-link{color:var(--primary);font-weight:600;text-decoration:none}.stcd-link:hover{text-decoration:underline}.stcd-pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:var(--fs-xxs);font-weight:700;line-height:var(--lh-tight);border:1px solid var(--border);background:#fff;white-space:nowrap}.stcd-pill-gray{background:#f1f5f9;color:#334155}.stcd-pill-amber{background:#fffbeb;border-color:#fde68a;color:#92400e}.stcd-pill-blue{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.stcd-pill-green{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.stcd-pill-red{background:#fff1f2;border-color:#fecdd3;color:#9f1239}.stcd-footnote{margin-top:8px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stcd-tdMuted small{color:inherit}.stcd-chipRow{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stcd-chip{height:34px;padding:0 12px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--muted);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stcd-chip:hover{box-shadow:var(--shadow-sm)}.stcd-chip.is-active{background:var(--soft);color:var(--primary);border-color:#bae6fd}.stcd-btn:focus-visible,.stcd-modeBtn:focus-visible,.stcd-statusCard:focus-visible,.stcd-chip:focus-visible,.stcd-link:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}.stct-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--lh-tight: 1.2;--lh-base: 1.45;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base);overflow:auto;-webkit-overflow-scrolling:touch}.stct-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stct-title{font-size:var(--fs-lg);font-weight:700;line-height:var(--lh-tight);letter-spacing:.2px}.stct-sub{margin-top:4px;font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stct-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stct-btn{height:38px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}.stct-btn:hover{box-shadow:var(--shadow-sm)}.stct-btn:active{transform:translateY(1px)}.stct-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stct-btn-primary{border-color:transparent;background:var(--primary);color:#fff}.stct-btn-primary:hover{background:var(--primary2)}.stct-btn-danger{border-color:transparent;background:var(--danger);color:#fff}.stct-error{background:var(--danger-bg);border:1px solid #fecdd3;color:#9f1239;border-radius:var(--radius);padding:10px 12px;margin-bottom:12px;font-size:var(--fs-sm);line-height:var(--lh-base);font-weight:700}.stct-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px;min-height:0}.stct-sectionHead{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stct-sectionTitle{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stct-sectionRight{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stct-modeToggle{display:flex;flex-wrap:wrap;border:1px solid var(--border);background:var(--card);border-radius:12px;overflow:hidden}.stct-modeBtn{height:38px;padding:0 12px;border:0;background:transparent;color:var(--muted);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stct-modeBtn:hover{background:#f8fafc}.stct-modeBtn.is-active{background:var(--soft);color:var(--primary)}.stct-modeIcon{display:inline-flex;align-items:center;justify-content:center}.stct-filterRow{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.stct-field{display:flex;flex-direction:column;gap:6px;min-width:160px}.stct-fieldGrow{flex:1;min-width:240px}.stct-field label{font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-tight);font-weight:700}.stct-field input,.stct-field select{height:40px;border-radius:12px;border:1px solid var(--border);background:#fff;padding:0 10px;outline:none;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stct-field input:focus,.stct-field select:focus{border-color:#0369a18c;box-shadow:0 0 0 3px #0369a124}.stct-footnote{margin-top:10px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stct-tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid rgba(226,232,240,.9);border-radius:12px;background:#fff;position:relative;min-height:0;max-height:calc(100vh - 360px)}.stct-table{width:100%;border-collapse:separate;border-spacing:0;min-width:980px;background:#fff}.stct-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;text-align:left;font-size:var(--fs-xxs);color:#334155;font-weight:700;line-height:var(--lh-tight);padding:12px;border-bottom:1px solid var(--border);white-space:nowrap}.stct-table tbody td{padding:12px;border-bottom:1px solid rgba(226,232,240,.9);vertical-align:top;font-size:var(--fs-xs);line-height:var(--lh-base)}.stct-table tbody tr:hover td{background:#e0f2fe66}.stct-tdMuted{color:var(--muted)}.stct-tdMono{font-family:var(--pps-font-mono);font-weight:500}.stct-link{color:var(--primary);text-decoration:none;font-weight:700}.stct-link:hover{text-decoration:underline}.stct-pill{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:var(--fs-xxs);line-height:var(--lh-tight);font-weight:700;white-space:nowrap}.stct-pill-gray{background:#64748b14;color:#334155}.stct-pill-amber{background:#f59e0b1a;border-color:#f59e0b40;color:#92400e}.stct-pill-blue{background:#0284c71a;border-color:#0284c738;color:#1d4ed8}.stct-pill-green{background:#16a34a1a;border-color:#16a34a40;color:#065f46}.stct-pill-red{background:#b91c1c14;border-color:#b91c1c40;color:#9f1239}.stct-pager{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;font-size:var(--fs-sm);line-height:var(--lh-base)}.stct-iconBtn{width:38px;height:38px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease,color .12s ease}.stct-iconBtn svg{width:22px;height:22px;color:currentColor;stroke-width:2.2}.stct-iconBtn svg *{stroke:currentColor;fill:currentColor}.stct-iconBtn:hover{transform:translateY(-1px);background:var(--soft);border-color:#0369a159;color:var(--primary2);box-shadow:var(--shadow)}.stct-iconBtn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.stct-iconBtn:focus-visible{outline:none;box-shadow:0 0 0 3px #0369a140,var(--shadow-sm)}.stct-iconBtn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;color:var(--muted)}.stct-btn:focus-visible,.stct-modeBtn:focus-visible,.stct-link:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}@media(max-width:640px){.stct-page{padding:14px 12px}.stct-title{font-size:var(--fs-md)}.stct-table{min-width:820px}}.stct-pill-green-dark{color:#1e3a8a;background:#dbeafe;border:1px solid #2563eb}.stcf-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--fs-2xl: 1.75rem;--lh-tight: 1.2;--lh-base: 1.45;--lh-relax: 1.6;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);overflow:auto;-webkit-overflow-scrolling:touch;font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base)}.stcf-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stcf-title{font-size:var(--fs-lg);font-weight:700;line-height:var(--lh-tight);letter-spacing:.2px}.stcf-sub{margin-top:4px;font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stcf-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stcf-btn{height:38px;padding:0 12px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stcf-btn:hover{box-shadow:var(--shadow-sm)}.stcf-btn:active{transform:translateY(1px)}.stcf-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stcf-btn-primary{border-color:transparent;background:var(--primary);color:#fff}.stcf-btn-primary:hover{background:var(--primary2)}.stcf-btn-danger{border-color:transparent;background:var(--danger);color:#fff}.stcf-btn-icon{width:38px;padding:0;gap:0}.stcf-btn-icon svg{display:block}a.stcf-btn{text-decoration:none}.stcf-linkBtn{background:transparent;border:0;padding:0;cursor:pointer;font:inherit}.stcf-error{background:var(--danger-bg);border:1px solid #fecdd3;color:#9f1239;padding:10px 12px;border-radius:12px;font-weight:700;font-size:var(--fs-sm);line-height:var(--lh-base);margin:8px 0 12px}.stcf-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm);margin-bottom:12px;min-height:0}.stcf-sectionHead{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stcf-sectionTitle{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stcf-sectionRight{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stcf-tabRow{display:flex;flex-wrap:wrap;border:1px solid var(--border);background:var(--card);border-radius:12px;overflow:hidden}.stcf-tabBtn{height:38px;padding:0 12px;border:0;background:transparent;color:var(--muted);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:flex;align-items:center;gap:8px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stcf-tabBtn:hover{background:#f8fafc}.stcf-tabBtn.is-active{background:var(--soft);color:var(--primary)}.stcf-tabIcon{display:inline-flex}.stcf-field{display:flex;flex-direction:column;gap:6px;min-width:180px}.stcf-field label{font-size:var(--fs-xxs);color:var(--muted);font-weight:700;line-height:var(--lh-tight)}.stcf-field input,.stcf-field select,.stcf-field textarea{border:1px solid var(--border);border-radius:12px;background:#fff;padding:10px;outline:none;font-size:var(--fs-sm);line-height:var(--lh-base)}.stcf-field input[type=file]{padding:8px 10px}.stcf-field input:disabled,.stcf-field select:disabled,.stcf-field textarea:disabled{background:#f8fafc;color:#475569;border-color:var(--border2);opacity:1;cursor:not-allowed}.stcf-field input:focus,.stcf-field select:focus,.stcf-field textarea:focus{border-color:#0369a18c;box-shadow:0 0 0 3px #0369a124}.stcf-field textarea{min-height:92px;resize:vertical}.stcf-req{color:#dc2626;font-weight:700;margin-left:2px}.stcf-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.stcf-mgrGrid{display:grid;grid-template-columns:1fr;gap:10px}@media(min-width:860px){.stcf-mgrGrid{grid-template-columns:1fr 100px 1fr;align-items:end}}.stcf-mgrSearch{position:relative;display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:12px;background:#fff;padding:0 10px;height:40px}.stcf-mgrSearchIcon{display:inline-flex;color:var(--muted)}.stcf-mgrSearch input{border:0;outline:none;background:transparent;padding:0;width:100%;font-size:var(--fs-sm);line-height:var(--lh-base);color:var(--text)}.stcf-mgrSearch input::placeholder{color:#94a3b8}.stcf-mgrSearch:focus-within{border-color:#0369a18c;box-shadow:0 0 0 3px #0369a124}.stcf-mgrMeta{margin-top:8px}.stcf-grid2{display:grid;grid-template-columns:1fr;gap:10px}@media(min-width:860px){.stcf-grid2{grid-template-columns:repeat(2,1fr)}}.stcf-grid3{display:grid;grid-template-columns:1fr;gap:10px}@media(min-width:980px){.stcf-grid3{grid-template-columns:repeat(3,1fr)}}.stcf-span2,.stcf-span3{grid-column:1 / -1}.stcf-list{display:flex;flex-direction:column;gap:10px}.stcf-card{border:1px solid var(--border);border-radius:14px;background:var(--card);padding:12px;box-shadow:var(--shadow-sm)}.stcf-cardHead{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.stcf-cardTitle{font-weight:700;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stcf-strong{font-weight:500}.stcf-muted{color:var(--muted);font-size:var(--fs-xs);line-height:var(--lh-base)}.stcf-mono{font-family:var(--pps-font-mono)}.stcf-tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border-radius:12px;border:1px solid var(--border);background:#fff;min-height:0;position:relative}.stcf-table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px;background:#fff}.stcf-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;color:#334155;font-size:var(--fs-xxs);font-weight:700;line-height:var(--lh-tight);padding:10px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap}.stcf-table tbody td{padding:10px;border-bottom:1px solid #f1f5f9;font-size:var(--fs-xs);line-height:var(--lh-base);vertical-align:top}.stcf-table tbody tr:hover td{background:#fafcff}.stcf-tdActions{text-align:right;white-space:nowrap}.stcf-tdActions .stcf-btn{vertical-align:middle}.stcf-tdActions .stcf-btn+.stcf-btn{margin-left:6px}.stcf-attBar{margin-top:12px;padding:0}.stcf-attGrid{display:grid;grid-template-columns:1fr;gap:10px;align-items:end}@media(min-width:860px){.stcf-attGrid{grid-template-columns:1fr 1fr auto}}.stcf-attActions{display:flex;justify-content:flex-end;align-items:center}.stcf-miniList{display:flex;flex-direction:column;gap:10px;margin-top:10px}.stcf-miniRow{display:grid;grid-template-columns:160px 1fr;gap:10px;align-items:start}@media(max-width:640px){.stcf-miniRow{grid-template-columns:1fr}}.stcf-footnote{margin-top:10px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stcf-link{color:var(--primary);font-weight:500;text-decoration:none}.stcf-link:hover{text-decoration:underline}.stcf-mt12{margin-top:12px}.stcf-mt6{margin-top:6px}.stcf-btn:focus-visible,.stcf-tabBtn:focus-visible,.stcf-link:focus-visible,.stcf-field input:focus-visible,.stcf-field select:focus-visible,.stcf-field textarea:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}@media(max-width:640px){.stcf-page{padding:14px 12px}.stcf-title{font-size:var(--fs-md)}.stcf-table{min-width:680px}.stcf-btn{height:40px}.stcf-btn-icon{width:40px}}.stcf-tabIcon svg,.stcf-btn svg{flex:0 0 auto}.stcf-sub b,.stcf-muted b{color:var(--text);font-weight:700}.stcf-header .stcf-actions>.stcf-btn:first-child:not(:disabled){border-color:transparent;background:var(--primary);color:#fff}.stcf-header .stcf-actions>.stcf-btn:first-child:not(:disabled):hover{background:var(--primary2)}.stcf-mgrSearch .stcf-btn-icon{height:34px;width:34px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--muted);box-shadow:none}.stcf-mgrSearch .stcf-btn-icon:hover{box-shadow:var(--shadow-sm);color:var(--text)}.stcf-mgrSearch .stcf-btn-icon:active{transform:translateY(1px)}.stcf-mgrSearch .stcf-btn-icon:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stcf-field input[list]{background-image:linear-gradient(transparent,transparent)}.stcf-field input[list]::-webkit-calendar-picker-indicator{opacity:.45;cursor:pointer}.stcf-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:var(--fs-xxs);line-height:var(--lh-tight);color:var(--muted);font-weight:700;white-space:nowrap}.stcf-pill.is-soft{background:var(--soft);border-color:#0369a12e;color:var(--primary)}.stcf-pill.is-danger{background:var(--danger-bg);border-color:#fecdd3;color:#9f1239}.stcf-kbd{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:18px;padding:0 6px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--muted);font-size:var(--fs-xxs);font-weight:800;line-height:1}.stcf-divider{height:1px;background:var(--border2);width:100%}.stcf-table thead th{box-shadow:inset 0 -1px 0 var(--border)}.stcf-tableWrap{contain:content}.stcf-table td .stcf-strong{word-break:break-word}@media(max-width:640px){.stcf-mgrSearch{height:42px}.stcf-mgrSearch .stcf-btn-icon{height:36px;width:36px}}.stcf-stdWrap{display:flex;flex-direction:column;gap:8px}.stcf-stdInputRow{display:flex;align-items:center;gap:8px}.stcf-stdInput{flex:1}.stcf-stdList{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.stcf-stdChip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;font-size:var(--fs-xxs);font-weight:700;border:1px solid rgba(3,105,161,.25);background:var(--soft);color:var(--primary);line-height:1}.stcf-stdChip button{border:none;background:transparent;cursor:pointer;font-size:var(--fs-12);font-weight:700;color:var(--primary);padding:0;line-height:1}.stcf-stdChip button:hover{color:#dc2626}.stcf-stdInput input[list]{width:100%}.stcf-stdHint{font-size:var(--fs-xxs);color:var(--muted);margin-top:2px}@media(max-width:640px){.stcf-stdChip{font-size:var(--fs-11);padding:4px 6px}}.stcf-stdTop{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.stcf-stdChips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;min-width:0;flex:1}.stcf-stdChipX{width:26px;height:26px;border-radius:999px;border:1px solid #e2e8f0;background:#fff;display:inline-flex;align-items:center;justify-content:center;color:#334155;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stcf-stdAdder{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.stcf-stdInput{height:38px;border-radius:12px;border:1px solid var(--border);background:#fff;padding:0 10px;font-size:var(--fs-sm);line-height:var(--lh-base);min-width:220px}.stcf-stdInput:focus{border-color:#0369a18c;box-shadow:0 0 0 3px #0369a124;outline:none}.stcf-stdAddBtn{height:38px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:800;font-size:var(--fs-xs);display:inline-flex;align-items:center;gap:8px;cursor:pointer}.stcf-stdAddBtn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.stcf-stdEmpty{font-size:var(--fs-xs);color:var(--muted);font-style:italic}@media(max-width:640px){.stcf-stdBox{padding:10px}.stcf-stdInput{min-width:160px;width:100%}.stcf-stdAdder{width:100%}.stcf-stdAddBtn{width:100%;justify-content:center}}.stcf-stdBox{border:1px solid var(--border);border-radius:14px;background:#fff;padding:10px;min-height:44px}.stcf-stdChips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;flex:1;min-width:220px}.stcf-stdChip{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;color:#0f172a;font-size:var(--fs-xs);font-weight:800;line-height:1;max-width:100%}.stcf-stdChipX{width:28px;height:28px;border-radius:999px;border:1px solid #e2e8f0;background:#fff;color:#334155;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stcf-stdAdder{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.stcf-stdInput{height:38px;border-radius:12px;border:1px solid var(--border);background:#fff;padding:0 10px;font-size:var(--fs-sm);line-height:var(--lh-base);min-width:260px}.stcf-stdAddBtn{height:38px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:800;font-size:var(--fs-xs);line-height:var(--lh-tight);display:inline-flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stcf-stdAddBtn svg{width:16px;height:16px}@media(max-width:640px){.stcf-stdChips{min-width:0;flex-basis:100%}.stcf-stdAdder{width:100%;justify-content:stretch}.stcf-stdInput{width:100%;min-width:0}.stcf-stdAddBtn{width:100%;justify-content:center}}.stcf-stdBox{border:1px solid var(--border);border-radius:14px;background:#fff;padding:10px;min-height:44px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.stcf-stdBox:hover{border-color:#d7e0ec}.stcf-stdBox:focus-within{border-color:#0369a18c;box-shadow:0 0 0 3px #0369a124}.stcf-stdBox.is-empty{border-color:#fecaca;background:#fff7f7}.stcf-stdTop{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start}.stcf-stdChips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;flex:1 1 240px;min-width:240px}.stcf-stdEmptyWarn{font-size:var(--fs-xs);color:#b91c1c;font-weight:800;line-height:var(--lh-base);padding:6px 2px}.stcf-stdChip{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;background:#f8fafc;border:1px solid #e2e8f0;color:#0f172a;font-size:var(--fs-xs);font-weight:800;line-height:1;max-width:100%}.stcf-stdChipCode{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stcf-stdChipX{width:28px;height:28px;border-radius:999px;border:1px solid #e2e8f0;background:#fff;color:#334155;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .05s ease}.stcf-stdChipX svg{display:block;width:16px;height:16px}.stcf-stdChipX:hover{border-color:#fecaca;background:#fff1f2;color:#dc2626}.stcf-stdChipX:active{transform:translateY(1px)}.stcf-stdChipX:disabled{opacity:.55;cursor:not-allowed;transform:none;background:#f8fafc}.stcf-stdAdder{display:flex;gap:8px;align-items:center;flex-wrap:wrap;flex:0 0 auto;justify-content:flex-end}.stcf-stdInput{height:38px;border-radius:12px;border:1px solid var(--border);background:#fff;padding:0 10px;font-size:var(--fs-sm);line-height:var(--lh-base);min-width:260px;max-width:360px}.stcf-stdInput::placeholder{color:#94a3b8}.stcf-stdInput:disabled{background:#f8fafc;color:#475569;border-color:var(--border2);opacity:1}.stcf-stdAddBtn{height:38px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:800;font-size:var(--fs-xs);line-height:var(--lh-tight);display:inline-flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:box-shadow .15s ease,transform .05s ease,background .15s ease}.stcf-stdAddBtn svg{width:16px;height:16px;display:block}.stcf-stdAddBtn:hover{box-shadow:var(--shadow-sm)}.stcf-stdAddBtn:active{transform:translateY(1px)}.stcf-stdAddBtn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stcf-stdHint{margin-top:8px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}@media(max-width:640px){.stcf-stdChips{min-width:0;flex:1 1 100%}.stcf-stdAdder{width:100%;justify-content:stretch}.stcf-stdInput{width:100%;min-width:0;max-width:none}.stcf-stdAddBtn{width:100%;justify-content:center}}.stctk-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);overflow:auto}.stctk-mono{font-family:var(--pps-font-mono)}.stctk-strong{font-weight:500}.stctk-muted{color:var(--muted);font-size:var(--fs-sm)}.stctk-dot{margin:0 8px;color:var(--border)}.stctk-errorbar{background:var(--danger-bg);border:1px solid #fecdd3;color:var(--danger);padding:10px 12px;border-radius:12px;margin-bottom:12px;font-weight:700}.stctk-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stctk-titleRow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.stctk-title{font-size:var(--fs-lg);font-weight:700;letter-spacing:.2px;display:flex;align-items:center;gap:10px}.stctk-sub{margin-top:6px;font-size:var(--fs-sm);color:var(--muted);display:flex;flex-wrap:wrap;align-items:center;gap:0}.stctk-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.stctk-btn{height:40px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);display:inline-flex;align-items:center;gap:8px;font-weight:500;cursor:pointer;box-shadow:0 1px #0f172a0a}.stctk-btn:hover{border-color:#cbd5e1}.stctk-btn:disabled{opacity:.55;cursor:not-allowed}.stctk-btn-ghost{background:transparent;box-shadow:none}.stctk-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.stctk-btn-primary:hover{background:var(--primary2);border-color:var(--primary2)}.stctk-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.stctk-tab{height:40px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);display:inline-flex;align-items:center;gap:8px;font-weight:700;cursor:pointer}.stctk-tab:hover{border-color:#cbd5e1}.stctk-tab.is-active{background:var(--soft);border-color:#bae6fd;color:#0c4a6e}.stctk-body{min-height:0}.stctk-grid2{display:grid;grid-template-columns:1fr;gap:12px}@media(max-width:980px){.stctk-grid2{grid-template-columns:1fr}}.stctk-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px;min-height:0}.stctk-cardTitle{font-weight:700;margin-bottom:10px}.stctk-subTitle{font-weight:700;margin:6px 0 8px;font-size:var(--fs-sm);color:#0c4a6e}.stctk-divider{height:1px;background:var(--border2);margin:12px 0}.stctk-kv{display:grid;grid-template-columns:160px 1fr;gap:8px 12px;align-items:start}@media(max-width:720px){.stctk-kv{grid-template-columns:120px 1fr}}.stctk-k{color:var(--muted);font-size:var(--fs-sm)}.stctk-v{font-size:var(--fs-sm)}.stctk-pill{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;border:1px solid var(--border);font-size:var(--fs-xs);font-weight:700;background:#fff}.stctk-pill-gray{background:#f1f5f9;border-color:#e2e8f0;color:#334155}.stctk-pill-amber{background:#fffbeb;border-color:#fde68a;color:#92400e}.stctk-pill-blue{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.stctk-pill-green{background:#ecfdf5;border-color:#bbf7d0;color:#065f46}.stctk-pill-red{background:#fff1f2;border-color:#fecdd3;color:#991b1b}.stctk-miniList{display:flex;flex-direction:column;gap:10px}.stctk-miniRow{display:flex;gap:10px;align-items:flex-start;padding:10px;border:1px solid var(--border2);border-radius:14px;background:#fff}.stctk-miniIcon{width:34px;height:34px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--soft);color:#0c4a6e;flex:0 0 auto}.stctk-miniMain{flex:1;min-width:0}.stctk-miniActions{flex:0 0 auto;display:flex;gap:8px}.stctk-tableWrap{overflow:auto;border:1px solid var(--border2);border-radius:14px}.stctk-table{width:100%;border-collapse:separate;border-spacing:0;min-width:820px}.stctk-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;border-bottom:1px solid var(--border2);padding:10px;text-align:left;font-size:var(--fs-xs);color:#0f172a}.stctk-table tbody td{border-bottom:1px solid var(--border2);padding:10px;font-size:var(--fs-sm);vertical-align:top}.stctk-table tbody tr:hover td{background:#fcfcfd}.stctk-miniKpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media(max-width:520px){.stctk-miniKpis{grid-template-columns:1fr}}.stctk-kpi{border:1px solid var(--border2);border-radius:14px;background:#fff;padding:10px 12px}.stctk-kpiLabel{font-size:var(--fs-xs);color:var(--muted);font-weight:500}.stctk-kpiValue{font-size:var(--fs-20);font-weight:950;margin-top:4px}.stctk-closureBox{border:1px solid var(--border2);border-radius:14px;padding:10px 12px;background:#fff}.stctk-footnote{margin-top:10px;font-size:var(--fs-xs);color:var(--muted)}.stctk-btn-primary{background:var(--primary);color:#fff;border-color:transparent}.stctk-btn-danger{background:#991b1b;color:#fff;border-color:transparent}.stctk-btn-primary:disabled,.stctk-btn-danger:disabled{opacity:.6;cursor:not-allowed}.stctk-btnSoft{background:#0000000a}.stctk-btnRowRight{display:inline-flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.stctk-modalOverlay{position:fixed;inset:0;background:#0000006b;z-index:50;display:flex;align-items:center;justify-content:center;padding:18px}.stctk-modal{width:min(1100px,98vw);max-height:92vh;background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000038;overflow:hidden;display:flex;flex-direction:column}.stctk-modalHead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid rgba(0,0,0,.08)}.stctk-modalTitle{display:inline-flex;align-items:center;gap:8px;font-weight:700}.stctk-modalHeadRight{display:inline-flex;align-items:center;gap:8px}.stctk-previewFrameWrap{padding:12px;background:#00000005;flex:1;overflow:auto}.stctk-previewFrame{width:100%;height:min(72vh,860px);border:0;border-radius:12px;background:#fff}.stctk-modalFoot{padding:12px 14px;border-top:1px solid rgba(0,0,0,.08);display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.stcm-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--warn: #b45309;--warn-bg: #fffbeb;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--lh-tight: 1.2;--lh-base: 1.45;--h-btn: 38px;--h-btn-sm: 34px;--h-field: 40px;--pad-x: 12px;--pad-y: 10px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base);overflow:auto;-webkit-overflow-scrolling:touch}.stcm-headLeft{min-width:0}.stcm-mono{font-family:var(--pps-font-mono)}.stcm-muted{color:var(--muted)}.stcm-strong{font-weight:700}.stcm-tdMuted{color:var(--muted)}.stcm-tdMono{font-family:var(--pps-font-mono);font-weight:500}.stcm-totalText{font-size:var(--fs-xxs)}.stcm-submitted{font-size:var(--fs-xxs);margin-top:2px}.stcm-fieldNote{margin-top:10px}.stcm-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stcm-title{font-size:var(--fs-lg);font-weight:700;line-height:var(--lh-tight);letter-spacing:.2px}.stcm-sub{margin-top:4px;font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stcm-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stcm-btn{height:var(--h-btn);padding:0 var(--pad-x);border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease,filter .12s ease}.stcm-btn:hover{box-shadow:var(--shadow-sm)}.stcm-btn:active{transform:translateY(1px)}.stcm-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stcm-btn-primary{border-color:transparent;background:var(--primary);color:#fff}.stcm-btn-primary:hover{background:var(--primary2)}.stcm-btn-danger{border-color:transparent;background:var(--danger);color:#fff}.stcm-btn-warn{border-color:transparent;background:var(--warn);color:#fff}.stcm-btn-ghost{background:transparent;box-shadow:none}.stcm-iconBtn{width:36px;height:36px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}.stcm-iconBtn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.25}.stcm-iconBtn:hover{background:var(--soft);border-color:#0369a159;box-shadow:var(--shadow-sm)}.stcm-iconBtn:active{transform:translateY(1px)}.stcm-iconBtn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stcm-error{background:var(--danger-bg);border:1px solid #fecdd3;color:#9f1239;border-radius:var(--radius);padding:10px 12px;margin-bottom:12px;font-size:var(--fs-sm);line-height:var(--lh-base);font-weight:700}.stcm-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px;min-height:0}.stcm-sectionHead{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stcm-sectionTitle{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stcm-sectionRight{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stcm-filterRow{display:flex;flex-direction:column;gap:14px}.stcm-tabRow{display:flex;gap:10px;align-items:stretch;flex-wrap:wrap}.stcm-tabBtn{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--card);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;min-width:220px;text-align:left}.stcm-tabBtn:hover{box-shadow:var(--shadow-sm)}.stcm-tabBtn:active{transform:translateY(1px)}.stcm-tabBtn.is-active{background:#e0f2fe73;border-color:#0369a159;box-shadow:var(--shadow-sm)}.stcm-tabIco{width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--soft);color:var(--primary);flex:0 0 auto}.stcm-tabIco svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.25}.stcm-tabText{display:flex;flex-direction:column;gap:2px}.stcm-tabLabel{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stcm-tabHint{font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stcm-filterBar{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}.stcm-field{display:flex;flex-direction:column;gap:6px;min-width:160px}.stcm-fieldGrow{flex:1 1 420px;min-width:240px}.stcm-fieldLimit{flex:0 0 140px}.stcm-field label{font-size:var(--fs-xxs);color:var(--muted);font-weight:700;line-height:var(--lh-tight)}.stcm-field input,.stcm-field select,.stcm-field textarea{border:1px solid var(--border);background:#fff;outline:none;color:var(--text)}.stcm-field input,.stcm-field select{height:var(--h-field);border-radius:12px;padding:0 10px;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stcm-field textarea{border-radius:12px;padding:10px;font-size:var(--fs-sm);line-height:var(--lh-base);min-height:92px;resize:vertical}.stcm-field input:focus,.stcm-field select:focus,.stcm-field textarea:focus{border-color:#0369a18c;box-shadow:0 0 0 3px #0369a124}.stcm-footnote{margin-top:10px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stcm-tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid rgba(226,232,240,.9);border-radius:12px;background:#fff;position:relative;min-height:0;max-height:calc(100vh - 360px)}.stcm-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1100px;background:#fff}.stcm-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;text-align:left;font-size:var(--fs-xxs);color:#334155;font-weight:700;line-height:var(--lh-tight);padding:12px;border-bottom:1px solid var(--border);white-space:nowrap}.stcm-table tbody td{padding:12px;border-bottom:1px solid rgba(226,232,240,.9);vertical-align:top;font-size:var(--fs-xs);line-height:var(--lh-base);color:var(--text)}.stcm-table tbody tr:hover td{background:#e0f2fe66}.stcm-link{color:var(--primary);text-decoration:none;font-weight:700}.stcm-link:hover{text-decoration:underline}.stcm-pill{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:var(--fs-xxs);line-height:var(--lh-tight);font-weight:700;white-space:nowrap}.stcm-pill-gray{background:#64748b14;color:#334155}.stcm-pill-amber{background:#f59e0b1a;border-color:#f59e0b40;color:#92400e}.stcm-pill-blue{background:#0284c71a;border-color:#0284c738;color:#1d4ed8}.stcm-pill-green{background:#16a34a1a;border-color:#16a34a40;color:#065f46}.stcm-pill-red{background:#b91c1c14;border-color:#b91c1c40;color:#9f1239}.stcm-actCell{text-align:right}.stcm-actGroup{display:flex;justify-content:flex-end;align-items:center;gap:10px;flex-wrap:wrap}.stcm-actGroupRight{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap}.stcm-actBtn{height:var(--h-btn-sm);padding:0 10px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;font-size:var(--fs-xxs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;min-width:104px}.stcm-actBtn:hover{box-shadow:var(--shadow-sm)}.stcm-actBtn:active{transform:translateY(1px)}.stcm-actBtn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.stcm-actBtn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.25}.stcm-actBtn-ok{border-color:#16a34a40;color:#065f46;background:#16a34a14}.stcm-actBtn-warn{border-color:#f59e0b40;color:#92400e;background:#f59e0b1a}.stcm-actBtn-bad{border-color:#b91c1c40;color:#9f1239;background:#b91c1c14}.stcm-actSep{display:none}.stcm-pager{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;font-size:var(--fs-sm);line-height:var(--lh-base)}.stcm-modalOverlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.stcm-modal{width:min(640px,100%);background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.stcm-modalHead{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid var(--border2);background:#f8fafc}.stcm-modalTitle{font-weight:700;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stcm-modalBody{padding:12px}.stcm-noteHint{font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stcm-modalFoot{padding:12px;border-top:1px solid var(--border2);display:flex;justify-content:flex-end;gap:8px;background:#fff}.stcm-btn:focus-visible,.stcm-iconBtn:focus-visible,.stcm-actBtn:focus-visible,.stcm-link:focus-visible,.stcm-tabBtn:focus-visible,.stcm-field input:focus-visible,.stcm-field select:focus-visible,.stcm-field textarea:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}@media(max-width:640px){.stcm-page{padding:14px 12px}.stcm-title{font-size:var(--fs-md)}.stcm-actions{gap:6px}.stcm-btn{height:36px}}@media(max-width:768px){.stcm-filterBar{flex-direction:column;align-items:stretch}.stcm-fieldLimit{width:100%;flex:1 1 auto}}@media(max-width:720px){.stcm-tabBtn,.stcm-field{min-width:0;width:100%}.stcm-fieldGrow{min-width:0}}.stci-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--warn: #b45309;--warn-bg: #fffbeb;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--lh-tight: 1.2;--lh-base: 1.45;--h-btn: 38px;--h-btn-sm: 34px;--h-field: 40px;--pad-x: 12px;--pad-y: 10px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base);overflow:auto;-webkit-overflow-scrolling:touch}.stci-headLeft{min-width:0}.stci-tdMuted{color:var(--muted)}.stci-tdMono{font-family:var(--pps-font-mono);font-weight:500}.stci-totalText{font-size:var(--fs-xxs)}.stci-submitted{font-size:var(--fs-xxs);margin-top:2px}.stci-link{color:var(--primary);text-decoration:none;font-weight:700}.stci-link:hover{text-decoration:underline}.stci-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stci-title{font-size:var(--fs-lg);font-weight:700;line-height:var(--lh-tight);letter-spacing:.2px}.stci-sub{margin-top:4px;font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stci-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stci-btn{height:var(--h-btn);padding:0 var(--pad-x);border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease,filter .12s ease}.stci-btn:hover{box-shadow:var(--shadow-sm)}.stci-btn:active{transform:translateY(1px)}.stci-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stci-btn-primary{border-color:transparent;background:var(--primary);color:#fff}.stci-btn-primary:hover{background:var(--primary2)}.stci-btn-danger{border-color:transparent;background:var(--danger);color:#fff}.stci-btn-warn{border-color:transparent;background:var(--warn);color:#fff}.stci-iconBtn{width:36px;height:36px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}.stci-iconBtn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.25}.stci-iconBtn:hover{background:var(--soft);border-color:#0369a159;box-shadow:var(--shadow-sm)}.stci-iconBtn:active{transform:translateY(1px)}.stci-iconBtn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stci-error{background:var(--danger-bg);border:1px solid #fecdd3;color:#9f1239;border-radius:var(--radius);padding:10px 12px;margin-bottom:12px;font-size:var(--fs-sm);line-height:var(--lh-base);font-weight:700}.stci-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px;min-height:0}.stci-sectionHead{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stci-sectionTitle{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stci-sectionRight{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stci-filterRow{display:flex;flex-direction:column;gap:14px}.stci-tabRow{display:flex;gap:10px;align-items:stretch;flex-wrap:wrap}.stci-filterBar{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}.stci-field{display:flex;flex-direction:column;gap:6px;min-width:160px}.stci-fieldGrow{flex:1 1 420px;min-width:240px}.stci-fieldLimit{flex:0 0 140px}.stci-field label{font-size:var(--fs-xxs);color:var(--muted);font-weight:700;line-height:var(--lh-tight)}.stci-field input,.stci-field select,.stci-field textarea{border:1px solid var(--border);background:#fff;outline:none;color:var(--text)}.stci-field input,.stci-field select{height:var(--h-field);border-radius:12px;padding:0 10px;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stci-field textarea{border-radius:12px;padding:10px;font-size:var(--fs-sm);line-height:var(--lh-base);min-height:92px;resize:vertical}.stci-field input:focus,.stci-field select:focus,.stci-field textarea:focus{border-color:#0369a18c;box-shadow:0 0 0 3px #0369a124}.stci-footnote{margin-top:10px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stci-fieldNote{margin-top:10px}.stci-tabBtn{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--card);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;min-width:220px;text-align:left}.stci-tabBtn:hover{box-shadow:var(--shadow-sm)}.stci-tabBtn:active{transform:translateY(1px)}.stci-tabBtn.is-active{background:#e0f2fe73;border-color:#0369a159;box-shadow:var(--shadow-sm)}.stci-tabIco{width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--soft);color:var(--primary);flex:0 0 auto}.stci-tabIco svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.25}.stci-tabText{display:flex;flex-direction:column;gap:2px}.stci-tabLabel{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stci-tabHint{font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stci-tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid rgba(226,232,240,.9);border-radius:12px;background:#fff;position:relative;min-height:0;max-height:calc(100vh - 360px)}.stci-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1100px;background:#fff}.stci-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;text-align:left;font-size:var(--fs-xxs);color:#334155;font-weight:700;line-height:var(--lh-tight);padding:12px;border-bottom:1px solid var(--border);white-space:nowrap}.stci-table tbody td{padding:12px;border-bottom:1px solid rgba(226,232,240,.9);vertical-align:top;font-size:var(--fs-xs);line-height:var(--lh-base);color:var(--text)}.stci-table tbody tr:hover td{background:#e0f2fe66}.stci-actHead{width:240px;text-align:right}.stci-actCell{text-align:right}.stci-actionsGrid{display:grid;grid-template-columns:repeat(1,minmax(120px,140px));justify-content:end;gap:10px}.stci-actionsGrid .stci-actBtn{width:100%;justify-content:center}.stci-actBtn-wide{grid-column:1 / -1}.stci-actBtn{height:var(--h-btn-sm);padding:0 10px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;font-size:var(--fs-xxs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;min-width:104px}.stci-actBtn:hover{box-shadow:var(--shadow-sm)}.stci-actBtn:active{transform:translateY(1px)}.stci-actBtn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.stci-actBtn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.25}.stci-actBtn-ok{border-color:#16a34a40;color:#065f46;background:#16a34a14}.stci-actBtn-warn{border-color:#f59e0b40;color:#92400e;background:#f59e0b1a}.stci-actBtn-bad{border-color:#b91c1c40;color:#9f1239;background:#b91c1c14}.stci-pill{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:var(--fs-xxs);line-height:var(--lh-tight);font-weight:700;white-space:nowrap}.stci-pill-gray{background:#64748b14;color:#334155}.stci-pill-amber{background:#f59e0b1a;border-color:#f59e0b40;color:#92400e}.stci-pill-blue{background:#0284c71a;border-color:#0284c738;color:#1d4ed8}.stci-pill-green{background:#16a34a1a;border-color:#16a34a40;color:#065f46}.stci-pill-red{background:#b91c1c14;border-color:#b91c1c40;color:#9f1239}.stci-pager{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;font-size:var(--fs-sm);line-height:var(--lh-base)}.stci-modalOverlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.stci-modal{width:min(640px,100%);background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.stci-modalHead{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid var(--border2);background:#f8fafc}.stci-modalTitle{font-weight:700;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stci-modalBody{padding:12px}.stci-noteHint{font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stci-modalFoot{padding:12px;border-top:1px solid var(--border2);display:flex;justify-content:flex-end;gap:8px;background:#fff}.stci-btn:focus-visible,.stci-iconBtn:focus-visible,.stci-actBtn:focus-visible,.stci-link:focus-visible,.stci-field input:focus-visible,.stci-field select:focus-visible,.stci-field textarea:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}@media(max-width:640px){.stci-page{padding:14px 12px}.stci-title{font-size:var(--fs-md)}.stci-actions{gap:6px}.stci-btn{height:36px}}@media(max-width:768px){.stci-filterBar{flex-direction:column;align-items:stretch}.stci-fieldLimit{width:100%;flex:1 1 auto}}@media(max-width:720px){.stci-table{min-width:1100px}.stci-tabBtn,.stci-field{min-width:0;width:100%}.stci-fieldGrow{min-width:0}.stci-actionsGrid{grid-template-columns:repeat(2,minmax(120px,1fr))}}.std-block{margin-bottom:10px}.std-list{margin-top:6px}.std-item{margin:2px 0;line-height:1.4}.std-code{font-weight:700}.std-name{font-weight:400}.stce-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--warn: #b45309;--warn-bg: #fffbeb;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--lh-tight: 1.2;--lh-base: 1.45;--h-btn: 38px;--h-btn-sm: 34px;--h-field: 40px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base);overflow:auto;-webkit-overflow-scrolling:touch}.stce-errorBar{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca;border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:12px;font-size:var(--fs-sm);font-weight:500}.stce-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stce-titleRow{display:flex;align-items:center;gap:10px}.stce-title{font-size:var(--fs-lg);font-weight:700;line-height:var(--lh-tight)}.stce-sub{margin-top:4px;color:var(--muted);font-size:var(--fs-xs)}.stce-mono{font-family:var(--pps-font-mono);font-weight:600}.stce-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:var(--fs-xxs);font-weight:600}.stce-pillSoft{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;border:1px solid #bae6fd;background:var(--soft);font-size:var(--fs-xxs);font-weight:600}.stce-headActions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stce-btn,.stce-linkBtn,.stce-iconBtn,.stce-actBtn{display:inline-flex;align-items:center;gap:8px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);height:var(--h-btn);padding:0 12px;font-weight:600;font-size:var(--fs-sm);cursor:pointer;box-shadow:var(--shadow-sm);text-decoration:none}.stce-iconBtn{width:var(--h-btn);padding:0;justify-content:center}.stce-btn:hover,.stce-linkBtn:hover,.stce-iconBtn:hover,.stce-actBtn:hover{border-color:#cbd5e1}.stce-btn:disabled,.stce-linkBtn[aria-disabled=true],.stce-iconBtn:disabled,.stce-actBtn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.stce-linkBtn{background:var(--soft);border-color:#bae6fd;color:var(--primary)}.stce-grid{display:grid;grid-template-columns:1fr;gap:12px;align-items:start}.stce-col{display:flex;flex-direction:column;gap:12px;min-width:0}.stce-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.stce-cardHead{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:12px;border-bottom:1px solid var(--border2);background:#fff}.stce-cardTitle{display:flex;align-items:center;gap:8px;font-weight:700;font-size:var(--fs-sm)}.stce-cardHint{color:var(--muted);font-size:var(--fs-xxs);font-weight:500}.stce-empty{padding:12px;color:var(--muted);font-size:var(--fs-sm)}.stce-kv{padding:10px 12px 12px}.stce-kvRow{display:grid;grid-template-columns:140px 1fr;gap:10px;padding:8px 0;border-bottom:1px dashed var(--border2)}.stce-kvRow:last-child{border-bottom:none}.stce-k{color:var(--muted);font-size:var(--fs-xs);font-weight:600}.stce-v{font-size:var(--fs-sm);font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis}.stce-tableWrap{padding:0 12px 12px;overflow:auto;-webkit-overflow-scrolling:touch}.stce-table{width:100%;border-collapse:separate;border-spacing:0;min-width:520px}.stce-table thead th{position:sticky;top:0;background:#f8fafc;z-index:1;text-align:left;padding:10px;font-size:var(--fs-xs);color:var(--muted);border-bottom:1px solid var(--border)}.stce-table tbody td{padding:10px;border-bottom:1px solid var(--border2);font-size:var(--fs-sm)}.stce-tdMuted{color:var(--muted)}.stce-tdMono{font-family:var(--pps-font-mono);font-weight:600}.stce-attList{padding:10px 12px 12px;display:flex;flex-direction:column;gap:10px}.stce-attItem{border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px;background:#fff}.stce-attName{font-weight:700;font-size:var(--fs-sm);overflow:hidden;text-overflow:ellipsis}.stce-attMeta{margin-top:4px;display:flex;gap:8px;flex-wrap:wrap;align-items:center;font-size:var(--fs-xxs)}.stce-form{padding:12px;display:flex;flex-direction:column;gap:10px}.stce-row2{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:start}.stce-field{display:flex;flex-direction:column;gap:6px;min-width:0}.stce-label{font-size:var(--fs-xs);color:var(--muted);font-weight:600}.stce-field input,.stce-field select,.stce-field textarea{border:1px solid var(--border);border-radius:12px;padding:10px;font-size:var(--fs-sm);background:#fff;color:var(--text);outline:none}.stce-field input,.stce-field select{height:var(--h-field)}.stce-field textarea{resize:vertical;min-height:96px}.stce-noteHint{font-size:var(--fs-xxs);color:var(--muted);font-weight:500}.stce-hintBox{border:1px solid #fde68a;background:var(--warn-bg);border-radius:12px;padding:10px;font-size:var(--fs-xs);color:#7c2d12;font-weight:500;line-height:1.4}.stce-fieldHintOnly{opacity:.98}.stce-formActions{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:4px}.stce-actGroup{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stce-actBtn{min-width:118px;justify-content:center}.stce-actOk{border-color:#bbf7d0;background:#f0fdf4}.stce-actWarn{border-color:#fde68a;background:var(--warn-bg)}.stce-actDanger{border-color:#fecaca;background:var(--danger-bg)}.stce-warningBar{margin-top:10px;border:1px solid #fde68a;background:var(--warn-bg);border-radius:var(--radius-sm);padding:10px 12px;color:#7c2d12;font-size:var(--fs-sm);font-weight:600}.stce-btn:focus-visible,.stce-linkBtn:focus-visible,.stce-iconBtn:focus-visible,.stce-actBtn:focus-visible,.stce-field input:focus-visible,.stce-field select:focus-visible,.stce-field textarea:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}@media(max-width:980px){.stce-grid{grid-template-columns:1fr}.stce-table{min-width:520px}}@media(max-width:640px){.stce-page{padding:14px 12px}.stce-title{font-size:var(--fs-md)}.stce-row2{grid-template-columns:1fr}.stce-actBtn{min-width:110px}.stce-kvRow{grid-template-columns:120px 1fr}}.stce-attItem{display:flex;align-items:center;justify-content:space-between;gap:12px}.stce-attMain{flex:1;min-width:0}.stce-stdChips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.stce-stdChip{display:inline-flex;align-items:center;gap:8px;padding:5px 10px;border-radius:999px;border:1px solid var(--border, rgba(0,0,0,.12));background:var(--soft, rgba(0,0,0,.03));max-width:100%}.stce-stdName{font-size:var(--fs-12);font-weight:600;color:var(--text, #111);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.stce-stdCode{font-size:var(--fs-12);font-family:var(--pps-font-mono);padding:2px 8px;border-radius:999px;border:1px dashed var(--border, rgba(0,0,0,.18));background:#ffffffa6;color:var(--muted, rgba(0,0,0,.65));line-height:1.1}.stcrv-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--soft: #e0f2fe;--ok: #16a34a;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xs: 12px;--fs-sm: 13px;--fs-md: 14px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);overflow:auto}.stcrv-muted{color:var(--muted)}.stcrv-tdMuted{color:var(--muted);font-size:var(--fs-sm)}.stcrv-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.stcrv-headLeft{display:flex;align-items:flex-end;gap:12px;min-width:260px}.stcrv-title{font-size:var(--fs-18);font-weight:500;display:flex;align-items:center}.stcrv-sub{font-size:var(--fs-13);color:var(--muted);margin-top:4px}.stcrv-headRight{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stcrv-btn{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);cursor:pointer;box-shadow:var(--shadow-sm);text-decoration:none;font-weight:800;font-size:var(--fs-13)}.stcrv-btn:hover{filter:brightness(.98)}.stcrv-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.stcrv-btn-primary{background:var(--primary);border-color:transparent;color:#fff}.stcrv-btn-soft{background:var(--soft);border-color:transparent;color:#0c4a6e}.stcrv-btn-ok{background:var(--ok);border-color:transparent;color:#fff}.stcrv-card{background:var(--card);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px;margin-bottom:12px}.stcrv-error{border-color:#fecaca;background:#fff1f2;color:#991b1b}.stcrv-cardHead{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;flex-wrap:wrap}.stcrv-cardTitle{font-size:var(--fs-14);font-weight:500}.stcrv-actions{display:flex;gap:8px;flex-wrap:wrap}.stcrv-tableWrap{overflow:auto;border:1px solid var(--border2);border-radius:14px}.stcrv-table{width:100%;border-collapse:separate;border-spacing:0;min-width:980px}.stcrv-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;border-bottom:1px solid var(--border2);padding:10px;text-align:left;font-size:var(--fs-xs);color:#0f172a}.stcrv-table tbody td{border-bottom:1px solid var(--border2);padding:10px;font-size:var(--fs-sm);vertical-align:top}.stcrv-table tbody tr:hover td{background:#fcfcfd}.stcrv-sampleTitle{font-size:var(--fs-13);font-weight:500}.stcrv-input{width:100%;height:36px;border-radius:10px;border:1px solid var(--border);padding:0 10px;outline:none;background:#fff}.stcrv-input:focus{border-color:#93c5fd;box-shadow:0 0 0 4px #93c5fd59}.stcrv-check{display:flex;gap:8px;align-items:center;font-weight:500}.stcrv-check input{width:16px;height:16px}.stcrv-footnote{margin-top:10px;font-size:var(--fs-xs);color:var(--muted)}.stcrv-uploadRow{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.stcrv-attachList{margin-top:10px;display:flex;flex-direction:column;gap:8px}.stcrv-attachItem{border:1px solid var(--border2);border-radius:12px;padding:10px 12px;background:#fff}.stcrv-attachName{font-size:var(--fs-13)}@media(max-width:560px){.stcrv-headLeft{min-width:unset}.stcrv-title{font-size:var(--fs-16)}.stcrv-btn{height:36px}}.stcrv-mt6{margin-top:6px}.stcrv-mt12{margin-top:12px}.stcrv-fs12{font-size:var(--fs-12)}.stcrv-header{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stcrv-headLeft{display:flex;gap:10px;align-items:flex-start}.stcrv-headRight{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.stcrv-title{font-weight:700;font-size:var(--fs-18);line-height:1.2}.stcrv-sub{margin-top:4px;font-size:var(--fs-13);color:var(--muted)}.stcrv-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm);margin-bottom:12px}.stcrv-cardHead{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stcrv-cardTitle{font-weight:700;font-size:var(--fs-14)}.stcrv-cardRight{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stcrv-muted{color:var(--muted);font-size:var(--fs-13);line-height:1.45}.stcrv-mono{font-family:var(--pps-font-mono)}.stcrv-strong{font-weight:700}.stcrv-tdMuted{color:var(--muted);font-size:var(--fs-13)}.stcrv-check{display:flex;gap:8px;align-items:center}.stcrv-input{width:100%;border:1px solid var(--border);border-radius:12px;padding:10px;font-size:var(--fs-14);outline:none}.stcrv-input:disabled{background:#f8fafc;color:#475569;border-color:var(--border2);opacity:1;cursor:not-allowed}.stcrv-footnote{margin-top:10px;font-size:var(--fs-12);color:var(--muted)}.stcrv-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between;width:100%}.stcrv-actionsLeft,.stcrv-actionsRight{display:flex;gap:8px;flex-wrap:wrap;align-items:center}@media(max-width:560px){.stcrv-actions{justify-content:flex-start}.stcrv-actionsRight{width:100%}.stcrv-actionsRight .stcrv-btn{flex:1;justify-content:center}}.stcrv-attBar{margin-top:12px;padding:0}.stcrv-attGrid{display:grid;grid-template-columns:1fr;gap:10px;align-items:end}@media(min-width:860px){.stcrv-attGrid{grid-template-columns:.2fr 1.5fr auto}}.stcrv-field{display:flex;flex-direction:column;gap:6px;min-width:180px}.stcrv-field label{font-size:var(--fs-12);color:var(--muted);font-weight:700}.stcrv-field input,.stcrv-field select{border:1px solid var(--border);border-radius:12px;background:#fff;padding:10px;outline:none;font-size:var(--fs-14)}.stcrv-field input[type=file]{padding:8px 10px}.stcrv-field input:disabled,.stcrv-field select:disabled{background:#f8fafc;color:#475569;border-color:var(--border2);opacity:1;cursor:not-allowed}.stcrv-attActions{display:flex;justify-content:flex-end;align-items:center}.stcrv-tdActions{text-align:right;white-space:nowrap}.stcrv-tdActions .stcrv-btn+.stcrv-btn{margin-left:6px}.stcrv-error{background:var(--danger-bg);border:1px solid #fecdd3;color:#9f1239;padding:10px 12px;border-radius:12px;font-weight:700;font-size:var(--fs-14);margin:8px 0 12px}.stcrv-attPreview{margin-top:12px}.stcrv-attPreviewHead{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stcrv-imgGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}.stcrv-imgCard{border:1px solid var(--border);border-radius:14px;background:var(--card);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;min-height:0}.stcrv-imgBox{position:relative;background:#0b1220;aspect-ratio:4 / 3;overflow:hidden}.stcrv-img{width:100%;height:100%;object-fit:cover;display:block}.stcrv-imgPlaceholder{width:100%;height:100%;display:flex;gap:8px;align-items:center;justify-content:center;color:#cbd5e1;font-weight:600;font-size:var(--fs-xs)}.stcrv-imgMeta{padding:10px;display:flex;flex-direction:column;gap:8px;min-height:0}.stcrv-imgName{font-weight:600;font-size:var(--fs-xs);line-height:var(--lh-tight);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stcrv-imgActions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.stcrv-loadMore{margin-top:12px;display:flex;justify-content:center}@media(max-width:640px){.stcrv-imgGrid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.stcrv-stdRow{margin-top:6px;display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap}.stcrv-stdLabel{font-size:var(--fs-12);font-weight:800;color:#64748b;line-height:1.35}.stcrv-stdChips{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-width:0}.stcrv-stdChip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;max-width:100%}.stcrv-stdName{font-size:var(--fs-12);font-weight:800;color:#0f172a;line-height:1.2;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stcrv-stdCode{font-size:var(--fs-11);font-weight:800;color:#0369a1;background:#e0f2fe;border:1px solid rgba(3,105,161,.18);padding:2px 6px;border-radius:999px;line-height:1}@media(max-width:640px){.stcrv-stdName{max-width:180px}}.stctm-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--warn: #b45309;--warn-bg: #fffbeb;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--lh-tight: 1.2;--lh-base: 1.45;--h-btn: 38px;--h-btn-sm: 34px;--h-field: 40px;--pad-x: 12px;--pad-y: 10px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base);overflow:auto;-webkit-overflow-scrolling:touch}.stctm-mono{font-family:var(--pps-font-mono)}.stctm-muted,.stctm-tdMuted{color:var(--muted)}.stctm-mutedSmall{font-size:var(--fs-xs);line-height:var(--lh-base)}.stctm-strong{font-weight:700}.stctm-strongSm{font-weight:700;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stctm-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.stctm-headLeft{display:flex;gap:10px;align-items:flex-start;min-width:0}.stctm-title{font-size:var(--fs-lg);font-weight:700;line-height:var(--lh-tight);letter-spacing:.2px}.stctm-sub{margin-top:4px;font-size:var(--fs-sm);line-height:var(--lh-base);color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:72vw}.stctm-headRight{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.stctm-btn{height:var(--h-btn);padding:0 var(--pad-x);border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-sm);line-height:var(--lh-tight);font-weight:700;cursor:pointer;box-shadow:var(--shadow-sm);text-decoration:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}.stctm-btn:hover{border-color:#cbd5e1;transform:translateY(-1px);box-shadow:var(--shadow)}.stctm-btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.stctm-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.stctm-btn svg{width:18px;height:18px}.stctm-btn-icon{width:var(--h-btn);padding:0}.stctm-btn-sm{height:var(--h-btn-sm);padding:0 10px;border-radius:10px;font-size:var(--fs-xs);box-shadow:none}.stctm-btn-sm svg{width:16px;height:16px}.stctm-btn-soft{background:#0369a11a;border-color:#0369a138;color:#0c4a6e}.stctm-btn-primary{background:var(--primary);border-color:#0369a159;color:#fff}.stctm-btn-primary:hover{background:var(--primary2);border-color:#0284c78c}.stctm-btn-warn{background:var(--warn-bg);border-color:#b453094d;color:var(--warn)}.stctm-btn-danger{background:var(--danger);border-color:#991b1b73;color:#fff}.stctm-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.stctm-cardHead{display:flex;justify-content:space-between;gap:10px;padding:12px;border-bottom:1px solid var(--border2);background:#fff}.stctm-cardTitle{font-weight:700;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stctm-error{border:1px solid rgba(153,27,27,.25);background:var(--danger-bg);color:var(--danger);padding:10px 12px;border-radius:var(--radius);font-size:var(--fs-sm);line-height:var(--lh-base);font-weight:700}.stctm-warning{margin:10px 0 14px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid rgba(245,158,11,.35);background:var(--warn-bg);color:var(--warn);font-size:var(--fs-sm);line-height:var(--lh-base);font-weight:700}.stctm-grid{display:grid;grid-template-columns:1fr;gap:12px;align-items:start}.stctm-col{display:flex;flex-direction:column;gap:12px;min-width:0}.stctm-kv{padding:12px}.stctm-kvRow{display:grid;grid-template-columns:140px 1fr;gap:10px;padding:8px 0;border-bottom:1px dashed var(--border2)}.stctm-kvRow:last-child{border-bottom:none}.stctm-k{color:var(--muted);font-size:var(--fs-xs);line-height:var(--lh-base);font-weight:700}.stctm-v{font-size:var(--fs-sm);line-height:var(--lh-base);font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis}.stctm-tableWrap{padding:0 12px 12px;overflow:auto;-webkit-overflow-scrolling:touch}.stctm-table{width:100%;border-collapse:separate;border-spacing:0;min-width:720px}.stctm-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;text-align:left;padding:12px 10px;font-size:var(--fs-xxs);line-height:var(--lh-tight);font-weight:700;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap}.stctm-table tbody td{padding:12px 10px;border-bottom:1px solid var(--border2);font-size:var(--fs-sm);line-height:var(--lh-base);vertical-align:top}.stctm-table tbody tr:hover td{background:#e0f2fe59}.stctm-tdActions{text-align:right;white-space:nowrap}.stctm-tdActions .stctm-btn+.stctm-btn{margin-left:6px}.stctm-footnote{padding:10px 12px 12px;color:var(--muted);font-size:var(--fs-xs);line-height:var(--lh-base);border-top:1px solid var(--border2);background:#fff}.stctm-modal{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.stctm-modalBox{width:min(720px,96vw);max-height:92vh;display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.stctm-modalHead{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px;border-bottom:1px solid var(--border2);background:#f8fafc}.stctm-modalTitle{font-size:var(--fs-md);line-height:var(--lh-tight);font-weight:700}.stctm-modalBody{padding:12px;display:flex;flex-direction:column;gap:12px;overflow:auto}.stctm-modalFoot{padding:12px;border-top:1px solid var(--border2);display:flex;justify-content:flex-end;gap:8px;background:#fff}.stctm-field{display:flex;flex-direction:column;gap:6px}.stctm-label{font-size:var(--fs-xxs);line-height:var(--lh-tight);color:var(--muted);font-weight:700}.stctm-field input,.stctm-field select{width:100%;height:var(--h-field);padding:0 10px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-sm);line-height:var(--lh-tight);outline:none;transition:border .15s ease,box-shadow .15s ease}.stctm-field input:focus,.stctm-field select:focus{border-color:#0284c7a6;box-shadow:0 0 0 3px #0284c724}.stctm-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stctm-noteHint{font-size:var(--fs-xs);line-height:var(--lh-base);color:var(--muted)}@media(max-width:980px){.stctm-table{min-width:640px}}@media(max-width:520px){.stctm-row2{grid-template-columns:1fr}.stctm-sub{max-width:92vw}}.stctm-stdWrap{display:flex;flex-direction:column;gap:6px}.stctm-stdChip{display:inline-flex;align-items:baseline;gap:8px;padding:6px 10px;border-radius:999px;background:#0000000a;width:fit-content;max-width:100%}.stctm-stdName{color:#000000a6;font-size:var(--fs-12);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.stcrm-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--green: #166534;--greenbg: #ecfdf5;--danger: #991b1b;--dangerbg: #fff1f2;--amber: #b45309;--amberbg: #fffbeb;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);overflow:auto;-webkit-overflow-scrolling:touch;font-family:var(--pps-font-main)}.stcrm-mono{font-family:var(--pps-font-mono)}.stcrm-muted{color:var(--muted);font-size:var(--fs-13)}.stcrm-dim{color:var(--muted);font-size:var(--fs-12)}.stcrm-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.stcrm-titleRow{display:flex;align-items:center;gap:10px}.stcrm-title{font-size:var(--fs-16);font-weight:700;line-height:1.1}.stcrm-sub{font-weight:700;color:var(--muted);font-size:var(--fs-12);margin-left:8px}.stcrm-meta{display:flex;align-items:center;gap:10px;margin-top:6px;flex-wrap:wrap}.stcrm-actions{display:flex;gap:8px;flex-wrap:wrap}.stcrm-btn{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:600;font-size:var(--fs-13);cursor:pointer;box-shadow:var(--shadow-sm);text-decoration:none}.stcrm-btn:hover{border-color:#cbd5e1;transform:translateY(-1px)}.stcrm-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stcrm-btnPrimary{background:linear-gradient(180deg,var(--primary2),var(--primary));color:#fff;border-color:transparent}.stcrm-btnGhost{background:var(--soft);border-color:#bae6fd;color:#075985;box-shadow:none}.stcrm-btnGreen{background:linear-gradient(180deg,#22c55e,var(--green));color:#fff;border-color:transparent}.stcrm-btn-icon{width:38px;height:38px;padding:0;border-radius:12px;display:inline-flex;align-items:center;justify-content:center}.stcrm-icoBtn{width:38px;height:38px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm)}.stcrm-icoBtn:hover{border-color:#cbd5e1;transform:translateY(-1px)}.stcrm-icoBtn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stcrm-icoDanger{border-color:#fecaca!important;background:var(--dangerbg)!important;color:var(--danger)!important}.stcrm-alert{border:1px solid #fecaca;background:var(--dangerbg);color:#7f1d1d;border-radius:14px;padding:10px 12px;font-size:var(--fs-13);font-weight:600;margin-bottom:12px}.stcrm-grid{display:grid;grid-template-columns:1fr;gap:12px}@media(max-width:980px){.stcrm-grid{grid-template-columns:1fr}}.stcrm-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px;min-height:0}.stcrm-cardHead{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.stcrm-cardTitle{font-weight:700;font-size:var(--fs-14)}.stcrm-cardHint{color:var(--muted);font-size:var(--fs-12)}.stcrm-divider{height:1px;background:var(--border2);margin:10px 0}.stcrm-kv{display:grid;grid-template-columns:120px 1fr;gap:8px 10px}@media(max-width:560px){.stcrm-kv{grid-template-columns:1fr}}.stcrm-k{color:var(--muted);font-size:var(--fs-12);font-weight:600}.stcrm-v{font-size:var(--fs-13);font-weight:600}.stcrm-field{display:flex;flex-direction:column;gap:6px;margin-top:10px}.stcrm-label{font-size:var(--fs-12);color:var(--muted);font-weight:700}.stcrm-field textarea{min-height:110px;resize:vertical;border:1px solid var(--border);border-radius:14px;padding:10px;font-size:var(--fs-13);outline:none}.stcrm-field textarea:focus{border-color:#7dd3fc;box-shadow:0 0 0 4px #7dd3fc59}.stcrm-page select{height:38px;border:1px solid var(--border);border-radius:12px;padding:0 10px;font-size:var(--fs-13);font-weight:600;background:#fff;color:var(--text);outline:none}.stcrm-page select:focus{border-color:#7dd3fc;box-shadow:0 0 0 4px #7dd3fc40}.stcrm-page select:disabled{opacity:.7;cursor:not-allowed}.stcrm-row{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}.stcrm-tip{margin-top:10px;border:1px solid #fde68a;background:var(--amberbg);color:#7c2d12;border-radius:14px;padding:10px 12px;font-size:var(--fs-13);font-weight:600}.stcrm-section{margin-top:6px}.stcrm-sectionTitle{display:flex;align-items:center;gap:8px;font-weight:700;font-size:var(--fs-13);margin-bottom:8px}.stcrm-uploader{display:grid;grid-template-columns:1fr 220px;align-items:center;gap:10px}.stcrm-uploader input[type=file]{border:1px solid var(--border);border-radius:12px;padding:7px 10px;background:#fff;width:100%}.stcrm-fileRow{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--border2);border-radius:14px;padding:10px;background:#fff}.stcrm-fileName{display:flex;align-items:center;gap:10px;min-width:0;flex-wrap:wrap}.stcrm-tableWrap{margin-top:10px;border:1px solid var(--border);border-radius:14px;overflow:auto}.stcrm-table{width:100%;border-collapse:separate;border-spacing:0;min-width:720px}.stcrm-table thead th{position:sticky;top:0;background:#f1f5f9;border-bottom:1px solid var(--border);font-size:var(--fs-12);color:#0f172a;text-align:left;padding:10px;z-index:1}.stcrm-table tbody td{border-bottom:1px solid var(--border2);padding:10px;font-size:var(--fs-13);vertical-align:top}.stcrm-tdName{font-weight:700;max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stcrm-thAct{width:120px}.stcrm-tdAct{display:flex;gap:8px;align-items:center}.stcrm-pill{display:inline-flex;align-items:center;height:22px;padding:0 9px;border-radius:999px;font-size:var(--fs-12);font-weight:700;border:1px solid var(--border);background:#fff}.stcrm-pill-gray{background:#f1f5f9;color:#334155;border-color:#e2e8f0}.stcrm-pill-amber{background:var(--amberbg);color:#7c2d12;border-color:#fde68a}.stcrm-pill-green{background:var(--greenbg);color:var(--green);border-color:#a7f3d0}.stcrm-pill-red{background:var(--dangerbg);color:var(--danger);border-color:#fecaca}.stcrm-pill-blue{background:var(--soft);color:#075985;border-color:#bae6fd}.stcrm-footNote{margin-top:10px;color:var(--muted);font-size:var(--fs-12);font-weight:600}.stcrm-btn-soft{background:#0369a11a;border-color:#0369a138;color:#0c4a6e}.stcrm-modalOverlay{position:fixed;inset:0;background:#0000006b;z-index:60;display:flex;align-items:center;justify-content:center;padding:18px}.stcrm-modal{width:min(1100px,98vw);max-height:92vh;background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000038;overflow:hidden;display:flex;flex-direction:column}.stcrm-modalHead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid rgba(0,0,0,.08)}.stcrm-modalTitle{display:inline-flex;align-items:center;gap:8px;font-weight:700}.stcrm-modalHeadRight{display:inline-flex;align-items:center;gap:8px}.stcrm-previewWrap{padding:12px;background:#00000005;flex:1;overflow:auto}.stcrm-previewFrame{width:100%;height:min(72vh,860px);border:0;border-radius:12px;background:#fff}.stcrm-modalFoot{padding:12px 14px;border-top:1px solid rgba(0,0,0,.08);display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.stcrd-box{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border-2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary-2: #0284c7;--success: #166534;--success-bg: #f0fdf4;--warn: #b45309;--warn-bg: #fffbeb;--danger: #991b1b;--danger-bg: #fef2f2;--soft: #eff6ff;--shadow: 0 10px 24px rgba(15, 23, 42, .06);--shadow-sm: 0 4px 14px rgba(15, 23, 42, .05);--radius: 18px;--radius-sm: 12px;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--lh: 1.45;min-height:0;background:var(--bg);color:var(--text);font-family:var(--pps-font-main)}.stcrd-box,.stcrd-box *{box-sizing:border-box}.stcrd-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stcrd-titleRow{display:flex;align-items:center;gap:8px}.stcrd-title{margin:0;font-size:var(--fs-lg);line-height:1.2;font-weight:700}.stcrd-subtitle{margin-top:4px;color:var(--muted);font-size:var(--fs-xs)}.stcrd-headerActions,.stcrd-createActions,.stcrd-detailActions,.stcrd-replyActions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:8px}.stcrd-btn{height:38px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);padding:0 12px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:var(--fs-xs);font-weight:700;cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .12s ease}.stcrd-btn:hover{box-shadow:var(--shadow-sm)}.stcrd-btn:active{transform:translateY(1px)}.stcrd-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.stcrd-btn-primary{color:#fff;background:var(--primary);border-color:transparent}.stcrd-btn-primary:hover{background:var(--primary-2)}.stcrd-btn-success{color:#fff;background:var(--success);border-color:transparent}.stcrd-btn-warn{color:#fff;background:var(--warn);border-color:transparent}.stcrd-createCard,.stcrd-sidebar,.stcrd-detailPane{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.stcrd-createCard{padding:14px;margin-bottom:12px}.stcrd-formGrid{display:grid;grid-template-columns:1fr;gap:12px}.stcrd-field{display:flex;flex-direction:column;gap:6px;min-width:0}.stcrd-field span{font-size:var(--fs-xs);color:var(--muted);font-weight:700}.stcrd-field input,.stcrd-field select,.stcrd-field textarea{width:100%;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font:inherit;padding:10px 12px;outline:none}.stcrd-field textarea{resize:vertical;min-height:96px}.stcrd-field input:focus,.stcrd-field select:focus,.stcrd-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0369a11f}.stcrd-body{display:grid;grid-template-columns:1fr;gap:12px;min-height:0}.stcrd-sidebar,.stcrd-detailPane{min-height:0}.stcrd-sidebar{padding:12px}.stcrd-sidebarHead{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.stcrd-sidebarTitle{font-weight:700}.stcrd-sidebarMeta{color:var(--muted);font-size:var(--fs-xs)}.stcrd-threadList{display:flex;flex-direction:column;gap:10px}.stcrd-threadCard{width:100%;text-align:left;border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.stcrd-threadCard:hover,.stcrd-threadCard.is-active{border-color:#0369a166;box-shadow:var(--shadow-sm);background:#fcfdff}.stcrd-threadTop,.stcrd-threadTitleWrap,.stcrd-threadMeta{display:flex;gap:8px;flex-wrap:wrap}.stcrd-threadTop,.stcrd-threadTitleWrap{align-items:flex-start;justify-content:space-between}.stcrd-threadTitle{font-weight:700;font-size:var(--fs-sm);line-height:1.25}.stcrd-threadStage,.stcrd-chip,.stcrd-threadUnread{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 8px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--muted);font-size:var(--fs-12);font-weight:700}.stcrd-threadUnread{min-width:24px;color:#fff;background:var(--primary);border-color:transparent}.stcrd-threadRef,.stcrd-threadFooter,.stcrd-msgRole,.stcrd-messageTime,.stcrd-readOnlyHint{color:var(--muted);font-size:var(--fs-xs)}.stcrd-threadPreview{margin-top:6px;font-size:var(--fs-sm);line-height:var(--lh);color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.stcrd-threadFooter{margin-top:8px;display:flex;align-items:center;justify-content:space-between;gap:8px}.stcrd-detailPane{padding:12px;display:flex;flex-direction:column;gap:12px}.stcrd-detailHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.stcrd-detailTitle{font-size:var(--fs-17);font-weight:700;line-height:1.3}.stcrd-detailMetaRow{margin-top:6px;display:flex;flex-wrap:wrap;gap:8px}.stcrd-messageList{display:flex;flex-direction:column;gap:10px;min-height:180px}.stcrd-message{border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px}.stcrd-message.is-own{border-color:#0369a159;background:#f8fcff}.stcrd-message.is-system{background:#f8fafc}.stcrd-messageTop{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:6px}.stcrd-messageSender{display:inline-flex;align-items:center;gap:8px;min-width:0}.stcrd-messageBody{white-space:pre-wrap;word-break:break-word;font-size:var(--fs-sm);line-height:1.55}.stcrd-replyBox{border-top:1px dashed var(--border);padding-top:12px}.stcrd-status{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 8px;border-radius:999px;font-size:var(--fs-12);font-weight:700;border:1px solid transparent}.stcrd-status-open{color:var(--warn);background:var(--warn-bg);border-color:#b453091f}.stcrd-status-answered{color:var(--primary);background:#eff6ff;border-color:#0369a11f}.stcrd-status-reopened{color:var(--danger);background:var(--danger-bg);border-color:#991b1b1f}.stcrd-status-resolved{color:var(--success);background:var(--success-bg);border-color:#1665341f}.stcrd-emptyCard,.stcrd-detailEmpty,.stcrd-readOnlyHint{min-height:88px;border:1px dashed var(--border);border-radius:14px;background:#fff;color:var(--muted);display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;text-align:center}@media(min-width:900px){.stcrd-formGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.stcrd-field-span2{grid-column:span 2}.stcrd-body{grid-template-columns:minmax(280px,360px) minmax(0,1fr);align-items:start}.stcrd-sidebar{position:sticky;top:0}}.stcrd-threadParticipants{margin-top:6px;color:var(--primary);font-size:var(--fs-xs);font-weight:700}.stcrd-chip-private{color:var(--primary);background:var(--soft);border-color:#0369a147}.stca1-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--warn: #b45309;--warn-bg: #fffbeb;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--lh-tight: 1.2;--lh-base: 1.45;--h-btn: 38px;--h-btn-sm: 34px;--h-field: 40px;--pad-x: 12px;--pad-y: 10px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base);overflow:auto;-webkit-overflow-scrolling:touch}.stca1-headLeft{min-width:0}.stca1-mono{font-family:var(--pps-font-mono)}.stca1-muted{color:var(--muted)}.stca1-strong{font-weight:700}.stca1-tdMuted{color:var(--muted)}.stca1-tdMono{font-family:var(--pps-font-mono);font-weight:800}.stca1-totalText{font-size:var(--fs-xxs)}.stca1-submitted{font-size:var(--fs-xxs);margin-top:2px}.stca1-fieldNote{margin-top:10px}.stca1-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stca1-title{font-size:var(--fs-lg);font-weight:700;line-height:var(--lh-tight);letter-spacing:.2px}.stca1-sub{margin-top:4px;font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stca1-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stca1-btn{height:var(--h-btn);padding:0 var(--pad-x);border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease,filter .12s ease}.stca1-btn:hover{box-shadow:var(--shadow-sm)}.stca1-btn:active{transform:translateY(1px)}.stca1-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stca1-btn-primary{border-color:transparent;background:var(--primary);color:#fff}.stca1-btn-primary:hover{background:var(--primary2)}.stca1-btn-danger{border-color:transparent;background:var(--danger);color:#fff}.stca1-btn-warn{border-color:transparent;background:var(--warn);color:#fff}.stca1-btn-ghost{background:transparent;box-shadow:none}.stca1-iconBtn{width:36px;height:36px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}.stca1-iconBtn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.25}.stca1-iconBtn:hover{background:var(--soft);border-color:#0369a159;box-shadow:var(--shadow-sm)}.stca1-iconBtn:active{transform:translateY(1px)}.stca1-iconBtn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stca1-error{background:var(--danger-bg);border:1px solid #fecdd3;color:#9f1239;border-radius:var(--radius);padding:10px 12px;margin-bottom:12px;font-size:var(--fs-sm);line-height:var(--lh-base);font-weight:700}.stca1-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px;min-height:0}.stca1-sectionHead{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stca1-sectionTitle{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stca1-sectionRight{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stca1-filterRow{display:flex;flex-direction:column;gap:14px}.stca1-tabRow{display:flex;gap:10px;align-items:stretch;flex-wrap:wrap}.stca1-tabBtn{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--card);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;min-width:220px;text-align:left}.stca1-tabBtn:hover{box-shadow:var(--shadow-sm)}.stca1-tabBtn:active{transform:translateY(1px)}.stca1-tabBtn.is-active{background:#e0f2fe73;border-color:#0369a159;box-shadow:var(--shadow-sm)}.stca1-tabIco{width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--soft);color:var(--primary);flex:0 0 auto}.stca1-tabIco svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.25}.stca1-tabText{display:flex;flex-direction:column;gap:2px}.stca1-tabLabel{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stca1-tabHint{font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stca1-filterBar{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}.stca1-field{display:flex;flex-direction:column;gap:6px;min-width:160px}.stca1-fieldGrow{flex:1 1 420px;min-width:240px}.stca1-fieldLimit{flex:0 0 140px}.stca1-field label{font-size:var(--fs-xxs);color:var(--muted);font-weight:700;line-height:var(--lh-tight)}.stca1-field input,.stca1-field select,.stca1-field textarea{border:1px solid var(--border);background:#fff;outline:none;color:var(--text)}.stca1-field input,.stca1-field select{height:var(--h-field);border-radius:12px;padding:0 10px;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stca1-field textarea{border-radius:12px;padding:10px;font-size:var(--fs-sm);line-height:var(--lh-base);min-height:92px;resize:vertical}.stca1-field input:focus,.stca1-field select:focus,.stca1-field textarea:focus{border-color:#0369a18c;box-shadow:0 0 0 3px #0369a124}.stca1-footnote{margin-top:10px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stca1-tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid rgba(226,232,240,.9);border-radius:12px;background:#fff;position:relative;min-height:0;max-height:calc(100vh - 360px)}.stca1-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1100px;background:#fff}.stca1-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;text-align:left;font-size:var(--fs-xxs);color:#334155;font-weight:700;line-height:var(--lh-tight);padding:12px;border-bottom:1px solid var(--border);white-space:nowrap}.stca1-table tbody td{padding:12px;border-bottom:1px solid rgba(226,232,240,.9);vertical-align:top;font-size:var(--fs-xs);line-height:var(--lh-base);color:var(--text)}.stca1-table tbody tr:hover td{background:#e0f2fe66}.stca1-link{color:var(--primary);text-decoration:none;font-weight:700}.stca1-link:hover{text-decoration:underline}.stca1-pill{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:var(--fs-xxs);line-height:var(--lh-tight);font-weight:700;white-space:nowrap}.stca1-pill-gray{background:#64748b14;color:#334155}.stca1-pill-amber{background:#f59e0b1a;border-color:#f59e0b40;color:#92400e}.stca1-pill-blue{background:#0284c71a;border-color:#0284c738;color:#1d4ed8}.stca1-pill-green{background:#16a34a1a;border-color:#16a34a40;color:#065f46}.stca1-pill-red{background:#b91c1c14;border-color:#b91c1c40;color:#9f1239}.stca1-actCell{text-align:right}.stca1-actGroup{display:flex;justify-content:flex-end;align-items:center;gap:10px;flex-wrap:wrap}.stca1-actGroupRight{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap}.stca1-actBtn{height:var(--h-btn-sm);padding:0 10px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;font-size:var(--fs-xxs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;min-width:104px}.stca1-actBtn:hover{box-shadow:var(--shadow-sm)}.stca1-actBtn:active{transform:translateY(1px)}.stca1-actBtn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.stca1-actBtn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.25}.stca1-actBtn-ok{border-color:#16a34a40;color:#065f46;background:#16a34a14}.stca1-actBtn-warn{border-color:#f59e0b40;color:#92400e;background:#f59e0b1a}.stca1-actBtn-bad{border-color:#b91c1c40;color:#9f1239;background:#b91c1c14}.stca1-pager{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;font-size:var(--fs-sm);line-height:var(--lh-base)}.stca1-modalOverlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.stca1-modal{width:min(640px,100%);background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.stca1-modalHead{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid var(--border2);background:#f8fafc}.stca1-modalTitle{font-weight:700;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stca1-modalBody{padding:12px}.stca1-noteHint{font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stca1-modalFoot{padding:12px;border-top:1px solid var(--border2);display:flex;justify-content:flex-end;gap:8px;background:#fff}.stca1-btn:focus-visible,.stca1-iconBtn:focus-visible,.stca1-actBtn:focus-visible,.stca1-link:focus-visible,.stca1-tabBtn:focus-visible,.stca1-field input:focus-visible,.stca1-field select:focus-visible,.stca1-field textarea:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}@media(max-width:640px){.stca1-page{padding:14px 12px}.stca1-title{font-size:var(--fs-md)}.stca1-actions{gap:6px}.stca1-btn{height:36px}}@media(max-width:768px){.stca1-filterBar{flex-direction:column;align-items:stretch}.stca1-fieldLimit{width:100%;flex:1 1 auto}}@media(max-width:720px){.stca1-tabBtn,.stca1-field{min-width:0;width:100%}.stca1-fieldGrow{min-width:0}}.stca1-previewWrap{background:#00000005;border-radius:12px;padding:10px}.stca1-previewFrame{width:100%;height:min(72vh,860px);border:0;border-radius:10px;background:#fff}.stca1-modalHeadRight{display:inline-flex;align-items:center;gap:8px}.stca2-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--warn: #b45309;--warn-bg: #fffbeb;--shadow: 0 10px 26px rgba(0,0,0,.06);--shadow-sm: 0 6px 16px rgba(0,0,0,.05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--lh-tight: 1.2;--lh-base: 1.45;--h-btn: 38px;--h-btn-sm: 34px;--h-field: 40px;--pad-x: 12px;--pad-y: 10px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base);overflow:auto;-webkit-overflow-scrolling:touch}.stca2-headLeft{min-width:0}.stca2-mono{font-family:var(--pps-font-mono)}.stca2-muted{color:var(--muted)}.stca2-strong{font-weight:700}.stca2-tdMuted{color:var(--muted)}.stca2-tdMono{font-family:var(--pps-font-mono);font-weight:800}.stca2-totalText{font-size:var(--fs-xxs)}.stca2-submitted{font-size:var(--fs-xxs);margin-top:2px}.stca2-fieldNote{margin-top:10px}.stca2-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stca2-title{font-size:var(--fs-lg);font-weight:700;line-height:var(--lh-tight);letter-spacing:.2px}.stca2-sub{margin-top:4px;font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stca2-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stca2-btn{height:var(--h-btn);padding:0 var(--pad-x);border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:700;font-size:var(--fs-xs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease,filter .12s ease}.stca2-btn:hover{box-shadow:var(--shadow-sm)}.stca2-btn:active{transform:translateY(1px)}.stca2-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stca2-btn-primary{border-color:transparent;background:var(--primary);color:#fff}.stca2-btn-primary:hover{background:var(--primary2)}.stca2-btn-danger{border-color:transparent;background:var(--danger);color:#fff}.stca2-btn-warn{border-color:transparent;background:var(--warn);color:#fff}.stca2-btn-ghost{background:transparent;box-shadow:none}.stca2-iconBtn{width:36px;height:36px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease}.stca2-iconBtn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.25}.stca2-iconBtn:hover{background:var(--soft);border-color:#0369a159;box-shadow:var(--shadow-sm)}.stca2-iconBtn:active{transform:translateY(1px)}.stca2-iconBtn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.stca2-error{background:var(--danger-bg);border:1px solid #fecdd3;color:#9f1239;border-radius:var(--radius);padding:10px 12px;margin-bottom:12px;font-size:var(--fs-sm);line-height:var(--lh-base);font-weight:700}.stca2-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:12px;min-height:0}.stca2-sectionHead{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stca2-sectionTitle{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stca2-sectionRight{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stca2-filterRow{display:flex;flex-direction:column;gap:14px}.stca2-tabRow{display:flex;gap:10px;align-items:stretch;flex-wrap:wrap}.stca2-tabBtn{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--card);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;min-width:220px;text-align:left}.stca2-tabBtn:hover{box-shadow:var(--shadow-sm)}.stca2-tabBtn:active{transform:translateY(1px)}.stca2-tabBtn.is-active{background:#e0f2fe73;border-color:#0369a159;box-shadow:var(--shadow-sm)}.stca2-tabIco{width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--soft);color:var(--primary);flex:0 0 auto}.stca2-tabIco svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.25}.stca2-tabText{display:flex;flex-direction:column;gap:2px}.stca2-tabLabel{font-size:var(--fs-sm);font-weight:700;line-height:var(--lh-tight)}.stca2-tabHint{font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stca2-filterBar{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}.stca2-field{display:flex;flex-direction:column;gap:6px;min-width:160px}.stca2-fieldGrow{flex:1 1 420px;min-width:240px}.stca2-fieldLimit{flex:0 0 140px}.stca2-field label{font-size:var(--fs-xxs);color:var(--muted);font-weight:700;line-height:var(--lh-tight)}.stca2-field input,.stca2-field select,.stca2-field textarea{border:1px solid var(--border);background:#fff;outline:none;color:var(--text)}.stca2-field input,.stca2-field select{height:var(--h-field);border-radius:12px;padding:0 10px;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stca2-field textarea{border-radius:12px;padding:10px;font-size:var(--fs-sm);line-height:var(--lh-base);min-height:92px;resize:vertical}.stca2-field input:focus,.stca2-field select:focus,.stca2-field textarea:focus{border-color:#0369a18c;box-shadow:0 0 0 3px #0369a124}.stca2-footnote{margin-top:10px;font-size:var(--fs-xxs);color:var(--muted);line-height:var(--lh-base)}.stca2-tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid rgba(226,232,240,.9);border-radius:12px;background:#fff;position:relative;min-height:0;max-height:calc(100vh - 360px)}.stca2-table{width:100%;border-collapse:separate;border-spacing:0;min-width:1100px;background:#fff}.stca2-table thead th{position:sticky;top:0;z-index:2;background:#f8fafc;text-align:left;font-size:var(--fs-xxs);color:#334155;font-weight:700;line-height:var(--lh-tight);padding:12px;border-bottom:1px solid var(--border);white-space:nowrap}.stca2-table tbody td{padding:12px;border-bottom:1px solid rgba(226,232,240,.9);vertical-align:top;font-size:var(--fs-xs);line-height:var(--lh-base);color:var(--text)}.stca2-table tbody tr:hover td{background:#e0f2fe66}.stca2-link{color:var(--primary);text-decoration:none;font-weight:700}.stca2-link:hover{text-decoration:underline}.stca2-pill{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:var(--fs-xxs);line-height:var(--lh-tight);font-weight:700;white-space:nowrap}.stca2-pill-gray{background:#64748b14;color:#334155}.stca2-pill-amber{background:#f59e0b1a;border-color:#f59e0b40;color:#92400e}.stca2-pill-blue{background:#0284c71a;border-color:#0284c738;color:#1d4ed8}.stca2-pill-green{background:#16a34a1a;border-color:#16a34a40;color:#065f46}.stca2-pill-red{background:#b91c1c14;border-color:#b91c1c40;color:#9f1239}.stca2-actCell{text-align:right}.stca2-actGroup{display:flex;justify-content:flex-end;align-items:center;gap:10px;flex-wrap:wrap}.stca2-actGroupRight{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap}.stca2-actBtn{height:var(--h-btn-sm);padding:0 10px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;font-size:var(--fs-xxs);line-height:var(--lh-tight);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:none;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease;min-width:104px}.stca2-actBtn:hover{box-shadow:var(--shadow-sm)}.stca2-actBtn:active{transform:translateY(1px)}.stca2-actBtn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.stca2-actBtn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.25}.stca2-actBtn-ok{border-color:#16a34a40;color:#065f46;background:#16a34a14}.stca2-actBtn-warn{border-color:#f59e0b40;color:#92400e;background:#f59e0b1a}.stca2-actBtn-bad{border-color:#b91c1c40;color:#9f1239;background:#b91c1c14}.stca2-pager{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;font-size:var(--fs-sm);line-height:var(--lh-base)}.stca2-modalOverlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.stca2-modal{width:min(640px,100%);background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.stca2-modalHead{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid var(--border2);background:#f8fafc}.stca2-modalTitle{font-weight:700;font-size:var(--fs-sm);line-height:var(--lh-tight)}.stca2-modalBody{padding:12px}.stca2-noteHint{font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-base)}.stca2-modalFoot{padding:12px;border-top:1px solid var(--border2);display:flex;justify-content:flex-end;gap:8px;background:#fff}.stca2-btn:focus-visible,.stca2-iconBtn:focus-visible,.stca2-actBtn:focus-visible,.stca2-link:focus-visible,.stca2-tabBtn:focus-visible,.stca2-field input:focus-visible,.stca2-field select:focus-visible,.stca2-field textarea:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}@media(max-width:640px){.stca2-page{padding:14px 12px}.stca2-title{font-size:var(--fs-md)}.stca2-actions{gap:6px}.stca2-btn{height:36px}}@media(max-width:768px){.stca2-filterBar{flex-direction:column;align-items:stretch}.stca2-fieldLimit{width:100%;flex:1 1 auto}}@media(max-width:720px){.stca2-tabBtn,.stca2-field{min-width:0;width:100%}.stca2-fieldGrow{min-width:0}}.stca2-previewWrap{background:#00000005;border-radius:12px;padding:10px}.stca2-previewFrame{width:100%;height:min(72vh,860px);border:0;border-radius:10px;background:#fff}.stcrd-page{--bg: #f6f9fc;--card: #ffffff;--card-soft: #f8fafc;--border: #dbe7f3;--border2: #edf2f7;--text: #0f172a;--muted: #64748b;--muted2: #94a3b8;--primary: #075985;--primary2: #0284c7;--primary-soft: #e0f2fe;--ok: #15803d;--ok-bg: #ecfdf5;--warn: #b45309;--warn-bg: #fffbeb;--danger: #be123c;--danger-bg: #fff1f2;--shadow: 0 14px 36px rgba(15, 23, 42, .07);--shadow-sm: 0 7px 18px rgba(15, 23, 42, .055);--radius: 18px;--radius-sm: 13px;--fs-11x: var(--fs-11, 11px);--fs-12x: var(--fs-12, 12px);--fs-13x: var(--fs-13, 13px);--fs-14x: var(--fs-14, 14px);--fs-18x: var(--fs-18, 18px);background:radial-gradient(circle at 0 0,rgba(14,165,233,.08),transparent 32rem),var(--bg);min-height:100vh;padding:18px;color:var(--text);font-family:var(--pps-font-main, "Sora", "Noto Sans Thai", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);box-sizing:border-box}.stcrd-page *,.stcrd-page *:before,.stcrd-page *:after{box-sizing:border-box}.stcrd-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;position:sticky;top:0;z-index:20;padding:10px 0;background:linear-gradient(180deg,#f6f9fcfa,#f6f9fcdb);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.stcrd-title{display:flex;align-items:center;min-width:0;gap:10px;font-weight:800;font-size:var(--fs-18x);letter-spacing:-.01em}.stcrd-sub{margin-left:8px;font-size:var(--fs-12x);font-weight:700;color:var(--muted)}.stcrd-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.stcrd-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border:1px solid var(--border);background:#fff;color:var(--text);padding:10px 14px;border-radius:13px;box-shadow:var(--shadow-sm);cursor:pointer;font-weight:800;font-size:var(--fs-13x);line-height:1.15;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease,background .15s ease}.stcrd-btn svg{flex:0 0 auto;font-size:1.05em}.stcrd-btn:hover:not(:disabled){border-color:#bfdbfe;background:#f8fbff;transform:translateY(-1px);box-shadow:0 12px 24px #0f172a14}.stcrd-btn:active:not(:disabled){transform:translateY(0)}.stcrd-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.stcrd-btn-icon{width:42px;padding:0}.stcrd-btn-primary,.stcrd-formActions .stcrd-btn:first-child{border-color:transparent;background:linear-gradient(180deg,var(--primary2),var(--primary));color:#fff}.stcrd-btn-primary:hover:not(:disabled),.stcrd-formActions .stcrd-btn:first-child:hover:not(:disabled){background:linear-gradient(180deg,#0ea5e9,#0369a1);border-color:transparent}.stcrd-btnSoft{background:#f8fafc;color:#075985}.stcrd-btnSm{min-height:34px;padding:7px 10px;border-radius:11px}.stcrd-grid{display:grid;grid-template-columns:1fr;gap:16px}@media(min-width:1180px){.stcrd-grid{grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);align-items:start}.stcrd-span2{grid-column:1 / span 2}}.stcrd-card{background:#fffffff5;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;overflow:hidden}.stcrd-cardDashed{border-style:dashed!important;background:linear-gradient(180deg,#fff,#f8fbff)}.stcrd-cardHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:12px}.stcrd-cardTitle{display:flex;align-items:center;min-width:0;gap:10px;font-weight:850;font-size:var(--fs-14x)}.stcrd-cardTitle svg{color:var(--primary);flex:0 0 auto}.stcrd-kv{display:grid;grid-template-columns:1fr;gap:10px}@media(min-width:680px){.stcrd-kv{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1180px){.stcrd-span2 .stcrd-kv{grid-template-columns:repeat(4,minmax(0,1fr))}}.stcrd-k{border:1px dashed var(--border2);border-radius:14px;padding:11px 12px;background:#fff;min-width:0}.stcrd-kLabel{font-size:var(--fs-12x);color:var(--muted);font-weight:800;margin-bottom:5px}.stcrd-kValue{font-weight:800;font-size:var(--fs-14x);overflow-wrap:anywhere}.stcrd-hint,.stcrd-foot,.stcrd-mini{font-size:var(--fs-12x);color:var(--muted)}.stcrd-hint,.stcrd-foot{margin-top:10px}.stcrd-alert{border-radius:14px;padding:10px 12px;border:1px solid var(--border);background:#fff;font-weight:800;font-size:var(--fs-13x);margin-bottom:12px;overflow-wrap:anywhere}.stcrd-alert-danger{border-color:#fecaca;background:var(--danger-bg);color:var(--danger)}.stcrd-alert-warn{border-color:#fde68a;background:var(--warn-bg);color:var(--warn)}.stcrd-alert-ok{border-color:#bbf7d0;background:var(--ok-bg);color:var(--ok);display:flex;align-items:center;gap:8px}.stcrd-form{display:flex;flex-direction:column;gap:12px}.stcrd-field{display:flex;flex-direction:column;min-width:0;gap:7px}.stcrd-label{font-size:var(--fs-12x);font-weight:850;color:var(--text)}.stcrd-input{width:100%;border:1px solid var(--border);border-radius:14px;padding:11px 13px;font-size:var(--fs-13x);outline:none;background:#fff;color:var(--text);min-height:44px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.stcrd-input:focus{border-color:#7dd3fc;box-shadow:0 0 0 4px #0ea5e924}.stcrd-input:disabled{background:#f8fafc;color:var(--muted)}.stcrd-textarea{min-height:96px;resize:vertical}.stcrd-row2{display:grid;grid-template-columns:1fr;gap:10px}@media(min-width:720px){.stcrd-row2{grid-template-columns:repeat(2,minmax(0,1fr))}}.stcrd-formActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px;padding-top:10px;border-top:1px solid var(--border2)}.stcrd-inlineCheck{display:flex;align-items:center;gap:10px;-webkit-user-select:none;user-select:none}.stcrd-inlineCheck input{width:18px;height:18px;accent-color:var(--primary2)}.stcrd-ul{margin:6px 0 0 18px;padding:0}.stcrd-ul li{margin:3px 0;overflow-wrap:anywhere}.stcrd-mt6{margin-top:6px}.stcrd-mt8{margin-top:8px}.stcrd-mt10{margin-top:10px}.stcrd-mono{font-family:var(--pps-font-mono, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace);font-size:var(--fs-12x);overflow-wrap:anywhere}.stcrd-tableWrap{overflow:auto;border:1px solid var(--border2);border-radius:14px;background:#fff;max-width:100%}.stcrd-table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px}.stcrd-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;border-bottom:1px solid var(--border2);padding:11px 12px;text-align:left;font-size:var(--fs-12x);font-weight:850;color:#334155;white-space:nowrap}.stcrd-table tbody td{border-bottom:1px solid var(--border2);padding:11px 12px;font-size:var(--fs-13x);vertical-align:top}.stcrd-table tbody tr:hover td{background:#f8fbff}.stcrd-table tbody tr:last-child td{border-bottom:0}.stcrd-tdMuted{color:var(--muted);font-size:var(--fs-12x)}.stcrd-tdStack{display:flex;flex-direction:column;gap:3px}.stcrd-empty{padding:22px 12px!important;color:var(--muted);text-align:center;font-weight:800}.stcrd-loading{margin-top:14px;text-align:center;color:var(--muted);font-weight:800}.stcrd-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 11px;border:1px solid var(--border);font-weight:850;font-size:var(--fs-12x);white-space:nowrap;line-height:1.15}.stcrd-pill-gray{background:#f1f5f9;color:#334155;border-color:#e2e8f0}.stcrd-pill-amber{background:#fffbeb;color:#92400e;border-color:#fde68a}.stcrd-pill-blue{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.stcrd-pill-green{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.stcrd-pill-red{background:#fff1f2;color:#991b1b;border-color:#fecaca}.stcrd-previewCard{margin-top:12px;border:1px dashed var(--border);border-radius:16px;padding:12px;background:linear-gradient(180deg,#fff,#f8fbff)}.stcrd-previewHead{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.stcrd-previewTitle{display:inline-flex;align-items:center;min-width:0;gap:8px;font-weight:850}.stcrd-previewTitle .stcrd-mono{max-width:min(680px,70vw);display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;vertical-align:bottom}.stcrd-previewRight{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.stcrd-previewFrameWrap{margin-top:10px;border:1px solid var(--border2);border-radius:14px;overflow:hidden;background:var(--bg);min-height:360px}.stcrd-previewFrame{width:100%;height:min(72vh,860px);min-height:360px;border:0;display:block;background:#fff}@media(max-width:720px){.stcrd-page{padding:12px}.stcrd-topbar{align-items:stretch;flex-direction:column;position:static;padding-top:0}.stcrd-actions,.stcrd-formActions{width:100%}.stcrd-btn{flex:1 1 auto}.stcrd-card{padding:13px;border-radius:16px}.stcrd-cardHeader{align-items:flex-start;flex-direction:column}.stcrd-previewTitle .stcrd-mono{max-width:82vw}}@media print{.stcrd-page{background:#fff;padding:0}.stcrd-topbar,.stcrd-formActions,.stcrd-previewRight{display:none!important}.stcrd-card{box-shadow:none;break-inside:avoid}}.stcpd-page{min-height:100vh;padding:24px;background:#f4f7fb;color:#0f172a}.stcpd-topbar,.stcpd-hero,.stcpd-card{max-width:1480px;margin-left:auto;margin-right:auto}.stcpd-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.stcpd-title{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:800;letter-spacing:-.02em}.stcpd-actions{display:flex;gap:10px;flex-wrap:wrap}.stcpd-btn{border:1px solid #cbd5e1;background:#fff;color:#0f172a;min-height:42px;padding:0 14px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;cursor:pointer;box-shadow:0 8px 22px #0f172a0f}.stcpd-btn:hover:not(:disabled){transform:translateY(-1px)}.stcpd-btn:disabled{opacity:.55;cursor:not-allowed}.stcpd-btn-icon{width:48px;padding:0}.stcpd-btn-primary{background:#0b6aa2;border-color:#0b6aa2;color:#fff}.stcpd-hero{background:linear-gradient(135deg,#fff,#eaf6ff);border:1px solid #dbeafe;border-radius:24px;padding:22px;display:flex;align-items:center;justify-content:space-between;gap:20px;box-shadow:0 18px 40px #0f172a14;margin-bottom:16px}.stcpd-heroTitle{font-size:22px;font-weight:900;margin-bottom:6px}.stcpd-heroText{color:#475569;line-height:1.55}.stcpd-stats{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.stcpd-stat{min-width:104px;border:1px solid #bfdbfe;background:#ffffffd1;border-radius:18px;padding:12px 14px;text-align:center}.stcpd-stat span{display:block;font-size:26px;font-weight:900;color:#075985}.stcpd-stat label{display:block;margin-top:2px;color:#64748b;font-size:12px;font-weight:800}.stcpd-card{background:#fff;border:1px solid #e2e8f0;border-radius:22px;padding:16px;box-shadow:0 14px 34px #0f172a0f;margin-bottom:16px}.stcpd-filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.stcpd-searchBox{flex:1 1 420px;min-height:44px;border:1px solid #cbd5e1;border-radius:14px;display:flex;align-items:center;gap:10px;padding:0 14px;background:#f8fafc}.stcpd-searchBox input{width:100%;border:0;background:transparent;outline:none;font:inherit;font-weight:700}.stcpd-check{display:inline-flex;align-items:center;gap:8px;color:#334155;font-weight:800}.stcpd-tableWrap{overflow-x:auto}.stcpd-table{width:100%;border-collapse:separate;border-spacing:0 10px;min-width:1080px}.stcpd-table th{text-align:left;font-size:12px;color:#64748b;font-weight:900;text-transform:uppercase;padding:0 14px 4px}.stcpd-table td{background:#f8fafc;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;padding:14px;vertical-align:middle}.stcpd-table td:first-child{border-left:1px solid #e2e8f0;border-radius:16px 0 0 16px}.stcpd-table td:last-child{border-right:1px solid #e2e8f0;border-radius:0 16px 16px 0}.stcpd-mainText{font-weight:900;font-size:16px}.stcpd-muted{color:#64748b;font-size:12px;margin-top:4px;display:flex;align-items:center;gap:5px}.stcpd-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.stcpd-line{display:flex;align-items:center;gap:7px;font-weight:800}.stcpd-right{text-align:right}.stcpd-badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900;border:1px solid transparent}.stcpd-badge-report{color:#075985;background:#e0f2fe;border-color:#bae6fd}.stcpd-badge-trc{color:#92400e;background:#fef3c7;border-color:#fde68a}.stcpd-alert{border-radius:16px;padding:12px 14px;margin-bottom:14px;font-weight:800}.stcpd-alert-danger{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.stcpd-empty{text-align:center;color:#64748b;font-weight:800;padding:30px!important}.stcpd-loading{position:fixed;right:18px;bottom:18px;background:#0f172a;color:#fff;border-radius:999px;padding:10px 14px;font-weight:900;box-shadow:0 16px 32px #0f172a40}@media(max-width:768px){.stcpd-page{padding:14px}.stcpd-topbar,.stcpd-hero{align-items:stretch;flex-direction:column}.stcpd-title{font-size:20px}.stcpd-stats{justify-content:stretch}.stcpd-stat{flex:1 1 90px}}.stcrri-page{padding:18px;color:#0f172a}.stcrri-topbar,.stcrri-cardHeader,.stcrri-actions,.stcrri-rowActions,.stcrri-stats{display:flex;align-items:center;gap:10px}.stcrri-topbar{justify-content:space-between;margin-bottom:14px}.stcrri-title{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:800}.stcrri-card{background:#fff;border:1px solid #dbe3ee;border-radius:18px;box-shadow:0 10px 28px #0f172a14;padding:18px;margin-bottom:16px}.stcrri-cardHeader{justify-content:space-between;margin-bottom:12px}.stcrri-cardTitle{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:800}.stcrri-btn{border:1px solid #cbd5e1;background:#fff;color:#0f172a;border-radius:12px;padding:9px 12px;min-height:44px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;white-space:nowrap;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,transform .12s ease}.stcrri-btn:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8}.stcrri-btn:active:not(:disabled){transform:translateY(1px)}.stcrri-btn:disabled{opacity:.55;cursor:not-allowed}.stcrri-btnIcon{width:44px;height:44px;padding:0}.stcrri-btnPrimary{border-color:#0b6aa2;background:#0b6aa2;color:#fff;box-shadow:0 8px 18px #0b6aa22e}.stcrri-btnPrimary:hover:not(:disabled){background:#075985;border-color:#075985}.stcrri-btnSoft{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.stcrri-filterRow{display:grid;grid-template-columns:minmax(360px,1fr) auto auto;align-items:center;gap:12px}.stcrri-searchBox{width:100%;min-width:0;height:52px;border:1px solid #cbd5e1;border-radius:16px;padding:0 14px;display:flex;align-items:center;gap:10px;background:#fff;color:#64748b;box-shadow:inset 0 1px #0f172a08;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.stcrri-searchBox:focus-within{border-color:#0b6aa2;box-shadow:0 0 0 4px #0b6aa21f;background:#fff}.stcrri-searchBox svg{flex:0 0 auto;color:#0f172a;font-size:19px}.stcrri-searchBox input{border:0;outline:0;flex:1;min-width:0;height:100%;background:transparent;color:#0f172a;font:inherit;font-size:15px}.stcrri-searchBox input::placeholder{color:#94a3b8}.stcrri-check{height:52px;padding:0 14px;border:1px solid #dbe3ee;border-radius:16px;background:#f8fafc;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;color:#0f172a;white-space:nowrap}.stcrri-check input{width:16px;height:16px;accent-color:#0b6aa2;cursor:pointer}.stcrri-filterRow>.stcrri-btnPrimary{height:52px;min-width:120px;border-radius:16px;font-size:15px}.stcrri-stats{margin-top:14px;flex-wrap:wrap;color:#475569;font-size:14px}.stcrri-stats span{display:inline-flex;align-items:center;gap:4px}.stcrri-tableWrap{width:100%;overflow:auto}.stcrri-table{width:100%;border-collapse:separate;border-spacing:0;min-width:980px}.stcrri-table th,.stcrri-table td{text-align:left;padding:12px 14px;border-bottom:1px solid #e2e8f0;vertical-align:top}.stcrri-table th{font-size:13px;color:#475569;background:#f8fafc;font-weight:800}.stcrri-stack{display:flex;flex-direction:column;gap:4px}.stcrri-muted{color:#64748b;font-size:13px}.stcrri-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:12.5px}.stcrri-pill{display:inline-flex;align-items:center;justify-content:center;width:fit-content;border-radius:999px;border:1px solid #cbd5e1;color:#334155;background:#f8fafc;padding:5px 10px;font-size:12px;font-weight:800}.stcrri-pill-green{border-color:#bbf7d0;color:#047857;background:#ecfdf5}.stcrri-pill-blue{border-color:#bfdbfe;color:#1d4ed8;background:#eff6ff}.stcrri-pill-amber{border-color:#fde68a;color:#92400e;background:#fffbeb}.stcrri-pill-red{border-color:#fecaca;color:#b91c1c;background:#fef2f2}.stcrri-linkBtn{border:0;background:transparent;padding:0;color:#0b6aa2;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:5px;width:fit-content}.stcrri-linkBtn:disabled{opacity:.5;cursor:not-allowed}.stcrri-alert{border-radius:14px;padding:12px 14px;margin-bottom:14px;font-weight:700}.stcrri-alertDanger{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.stcrri-empty{color:#64748b;text-align:center!important;padding:34px!important}.stcrri-foot{margin-top:12px;color:#64748b;font-size:13px}.stcrri-loading{position:fixed;right:18px;bottom:18px;background:#0f172a;color:#fff;border-radius:999px;padding:10px 14px;font-weight:800;box-shadow:0 12px 30px #0f172a40}@media(max-width:1024px){.stcrri-filterRow{grid-template-columns:1fr auto}.stcrri-searchBox{grid-column:1 / -1}.stcrri-filterRow>.stcrri-btnPrimary{min-width:110px}}@media(max-width:760px){.stcrri-page{padding:12px}.stcrri-topbar{align-items:stretch;flex-direction:column}.stcrri-title{font-size:20px}.stcrri-filterRow{grid-template-columns:1fr}.stcrri-searchBox,.stcrri-check,.stcrri-filterRow>.stcrri-btnPrimary{width:100%}.stcrri-check{justify-content:flex-start}}.stcrt-page{padding:18px}.stcrt-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.stcrt-headLeft,.stcrt-headRight{display:flex;align-items:center;gap:10px}.stcrt-headMeta{display:flex;flex-direction:column;gap:4px}.stcrt-title{font-size:var(--fs-18);font-weight:800;letter-spacing:.2px}.stcrt-sub{font-size:var(--fs-13);opacity:.85}.stcrt-mt6{margin-top:6px}.stcrt-mt12{margin-top:12px}.stcrt-mb8{margin-bottom:8px}.stcrt-muted{opacity:.75;font-size:var(--fs-12)}.stcrt-strong{font-weight:800}.stcrt-mono{font-family:var(--pps-font-mono)}.stcrt-fs12{font-size:var(--fs-12)}.stcrt-card{background:#fff;border-radius:14px;padding:16px;margin-bottom:14px;box-shadow:0 2px 10px #0000000f}.stcrt-cardHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.stcrt-cardTitle{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800}.stcrt-cardRight{display:flex;align-items:center;gap:8px;text-align:right}.stcrt-btn{display:inline-flex;align-items:center;gap:8px;border:0;padding:8px 12px;border-radius:10px;background:#0000000a;color:inherit;cursor:pointer;-webkit-user-select:none;user-select:none}.stcrt-btn:hover{background:#00000012}.stcrt-btn:disabled{opacity:.55;cursor:not-allowed}.stcrt-btn-icon{padding:8px 10px}.stcrt-btn-primary{background:#1976d224}.stcrt-btn-primary:hover{background:#1976d238}.stcrt-btn-warn{background:#ffc1072e}.stcrt-btn-warn:hover{background:#ffc10742}.stcrt-btn-ok{background:#2e7d3229}.stcrt-btn-ok:hover{background:#2e7d323d}.stcrt-btn-danger{background:#d32f2f24}.stcrt-btn-danger:hover{background:#d32f2f33}.stcrt-error{background:#d32f2f17;border:1px solid rgba(211,47,47,.22);color:#b71c1c;padding:10px 12px;border-radius:12px;margin:10px 0 14px}.stcrt-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:10px}.stcrt-footnote{margin-top:10px;font-size:var(--fs-12);opacity:.8}.stcrt-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:var(--fs-12);font-weight:800;white-space:nowrap}.stcrt-pill-gray{background:#0000000f}.stcrt-pill-amber{background:#ffc10740}.stcrt-pill-blue{background:#1976d22e}.stcrt-pill-green{background:#2e7d322e}.stcrt-attBar{background:#00000008;border-radius:12px;padding:12px}.stcrt-attGrid{display:grid;grid-template-columns:200px 1fr auto;gap:10px;align-items:end}.stcrt-field label{display:block;font-size:var(--fs-12);opacity:.8;margin-bottom:6px}.stcrt-field select,.stcrt-field input[type=file]{width:100%;padding:8px 10px;border-radius:10px;border:1px solid rgba(0,0,0,.12);background:#fff}.stcrt-attActions{display:inline-flex;gap:8px}.stcrt-attPreview{margin-top:12px}.stcrt-attPreviewHead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.stcrt-fileList{display:flex;flex-direction:column;gap:8px}.stcrt-fileRow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;background:#00000008}.stcrt-fileMain{min-width:0}.stcrt-fileName{font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:720px}.stcrt-fileActions{display:inline-flex;gap:8px}.stcrt-imgGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.stcrt-imgCard{background:#00000008;border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.stcrt-imgBox{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden;border:0;padding:0;background:transparent}.stcrt-imgBtn{cursor:pointer}.stcrt-imgBox img{width:100%;height:100%;object-fit:cover;display:block}.stcrt-imgMeta{padding:10px}.stcrt-imgName{font-weight:800;font-size:var(--fs-12);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stcrt-loadMore{display:flex;justify-content:center;margin-top:12px}.stcrt-sampleList{display:flex;flex-direction:column;gap:10px}.stcrt-sampleRow{background:#00000008;border-radius:12px;padding:12px}.stcrt-sampleTop{display:flex;align-items:center;gap:8px}.stcrt-dot{opacity:.5}.stcrt-sampleCat{font-weight:800}.stcrt-sampleModel{font-weight:700}.stcrt-sampleSub{margin-top:4px;font-size:var(--fs-12);opacity:.8}.stcrt-lightbox{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:9999}.stcrt-lightboxInner{width:min(980px,100%);background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 10px 30px #00000040}.stcrt-lightboxHead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;border-bottom:1px solid rgba(0,0,0,.08)}.stcrt-lightboxTitle{max-width:82%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stcrt-lightboxBody{padding:12px}.stcrt-lightboxBody img{width:100%;height:auto;display:block;border-radius:10px}@media(max-width:920px){.stcrt-attGrid{grid-template-columns:1fr}.stcrt-imgGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.stcrt-fileName{max-width:52vw}}.stcwi-page{--stcwi-bg: #f8fafc;--stcwi-surface: #ffffff;--stcwi-surface-soft: #f8fbff;--stcwi-border: #e2e8f0;--stcwi-border-strong: #cbd5e1;--stcwi-text: #0f172a;--stcwi-soft: #475569;--stcwi-muted: #64748b;--stcwi-primary: #0369a1;--stcwi-primary-dark: #075985;--stcwi-primary-soft: #e0f2fe;--stcwi-success: #166534;--stcwi-success-soft: #ecfdf5;--stcwi-warning: #a16207;--stcwi-warning-soft: #fffbeb;--stcwi-shadow: 0 8px 24px rgba(15, 23, 42, .06);min-height:100%;padding:max(16px,env(safe-area-inset-top)) max(18px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(18px,env(safe-area-inset-left));background:linear-gradient(180deg,#fbfdff 0%,var(--stcwi-bg) 100%);color:var(--stcwi-text);font-family:var(--pps-font-main);font-size:1rem;line-height:1.45;overflow:auto;-webkit-overflow-scrolling:touch;box-sizing:border-box}.stcwi-page,.stcwi-page *{box-sizing:border-box}.stcwi-header{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:14px;flex-wrap:wrap}.stcwi-kicker{margin:0 0 4px;color:var(--stcwi-primary);font-size:.75rem;font-weight:900;letter-spacing:0;text-transform:uppercase}.stcwi-header h1{margin:0;color:var(--stcwi-text);font-size:clamp(1.2rem,1rem + .8vw,1.7rem);line-height:1.2;font-weight:900;letter-spacing:0}.stcwi-sub{max-width:820px;margin:6px 0 0;color:var(--stcwi-soft);font-size:.9rem;line-height:1.55}.stcwi-headerActions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.stcwi-btn,.stcwi-link{min-height:40px;border:1px solid var(--stcwi-border);border-radius:10px;background:var(--stcwi-surface);color:var(--stcwi-text);text-decoration:none;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.stcwi-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;font-size:.82rem;font-weight:900;white-space:nowrap}.stcwi-btnPrimary{color:#fff;border-color:transparent;background:var(--stcwi-primary)}.stcwi-btn:hover,.stcwi-link:hover{border-color:var(--stcwi-border-strong);box-shadow:var(--stcwi-shadow);transform:translateY(-1px)}.stcwi-quickGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}.stcwi-link{display:flex;align-items:center;gap:10px;min-width:0;padding:12px}.stcwi-linkIcon{width:38px;min-width:38px;height:38px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:var(--stcwi-primary);background:var(--stcwi-primary-soft)}.stcwi-link strong,.stcwi-link small{display:block;line-height:1.35}.stcwi-link strong{font-size:.86rem;font-weight:900}.stcwi-link small{margin-top:2px;color:var(--stcwi-muted);font-size:.76rem}.stcwi-section{margin-bottom:14px;padding:14px;border:1px solid var(--stcwi-border);border-radius:14px;background:var(--stcwi-surface);box-shadow:var(--stcwi-shadow)}.stcwi-sectionHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.stcwi-sectionHead svg{width:22px;min-width:22px;height:22px;color:var(--stcwi-primary)}.stcwi-section h2{margin:0;font-size:1rem;line-height:1.25;color:var(--stcwi-text);font-weight:900}.stcwi-sectionHead p{margin:4px 0 0;color:var(--stcwi-muted);font-size:.82rem;line-height:1.45}.stcwi-timeline{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.stcwi-step,.stcwi-role{display:flex;align-items:flex-start;gap:10px;min-width:0;padding:12px;border:1px solid var(--stcwi-border);border-radius:12px;background:var(--stcwi-surface-soft)}.stcwi-stepNo{width:30px;min-width:30px;height:30px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;background:var(--stcwi-primary);color:#fff;font-weight:900;font-size:.78rem}.stcwi-status{display:inline-flex;max-width:100%;padding:4px 8px;border-radius:999px;background:var(--stcwi-primary-soft);color:var(--stcwi-primary-dark);font-size:.68rem;font-weight:900;line-height:1.2;word-break:break-word}.stcwi-step h3{margin:8px 0 4px;font-size:.92rem;line-height:1.3;font-weight:900}.stcwi-step p,.stcwi-role p{margin:0;color:var(--stcwi-soft);font-size:.82rem;line-height:1.5}.stcwi-step small{display:block;margin-top:8px;color:var(--stcwi-muted);font-size:.75rem;font-weight:800}.stcwi-gridTwo{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.stcwi-roleList,.stcwi-actionList{display:grid;gap:8px}.stcwi-role span:first-child{width:34px;min-width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:var(--stcwi-success);background:var(--stcwi-success-soft)}.stcwi-role strong{display:block;margin-bottom:2px;font-size:.86rem;font-weight:900}.stcwi-action{display:grid;grid-template-columns:minmax(150px,.55fr) minmax(0,1fr);gap:10px;align-items:center;padding:10px 12px;border:1px solid var(--stcwi-border);border-radius:10px;background:var(--stcwi-surface-soft)}.stcwi-action code{color:var(--stcwi-primary-dark);font-size:.75rem;font-weight:900;white-space:normal;word-break:break-word}.stcwi-action span{color:var(--stcwi-soft);font-size:.82rem;line-height:1.45}.stcwi-sectionTable{display:grid;gap:8px}.stcwi-row{display:grid;grid-template-columns:130px 170px minmax(0,1fr);gap:10px;align-items:start;padding:10px 12px;border:1px solid var(--stcwi-border);border-radius:10px;background:var(--stcwi-surface-soft)}.stcwi-row strong{color:var(--stcwi-primary-dark);font-size:.8rem;font-weight:900}.stcwi-row span{color:var(--stcwi-text);font-size:.84rem;font-weight:900}.stcwi-row p{margin:0;color:var(--stcwi-soft);font-size:.82rem;line-height:1.45}.stcwi-numberList,.stcwi-bulletList{margin:0;padding-left:20px;color:var(--stcwi-soft);font-size:.86rem;line-height:1.6}.stcwi-numberList li+li,.stcwi-bulletList li+li{margin-top:6px}.stcwi-warning{background:linear-gradient(180deg,#ffffff 0%,var(--stcwi-warning-soft) 100%)}.stcwi-warning .stcwi-sectionHead svg{color:var(--stcwi-warning)}.stcwi-footer{display:flex;align-items:center;gap:8px;margin-top:2px;padding:12px 14px;border:1px solid var(--stcwi-border);border-radius:12px;background:#fff;color:var(--stcwi-muted);font-size:.82rem;line-height:1.45}.stcwi-footer svg{color:var(--stcwi-primary);min-width:18px}@media(max-width:1180px){.stcwi-quickGrid,.stcwi-timeline{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:860px){.stcwi-header{align-items:stretch}.stcwi-headerActions,.stcwi-btn{width:100%}.stcwi-gridTwo{grid-template-columns:1fr;gap:0}.stcwi-row{grid-template-columns:1fr;gap:4px}}@media(max-width:640px){.stcwi-page{padding:max(12px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.stcwi-quickGrid,.stcwi-timeline{grid-template-columns:1fr}.stcwi-section{padding:12px;border-radius:12px}.stcwi-action{grid-template-columns:1fr;gap:4px}}@media(min-width:1800px){.stcwi-page{max-width:1720px;margin:0 auto}.stcwi-timeline{grid-template-columns:repeat(6,minmax(0,1fr))}}.stcsig-page{--stcsig-bg: #f6f8fb;--stcsig-card: #ffffff;--stcsig-border: #dbe5f0;--stcsig-border-soft: #edf2f7;--stcsig-text: #0f172a;--stcsig-muted: #64748b;--stcsig-primary: #0369a1;--stcsig-primary-2: #0284c7;--stcsig-danger: #991b1b;--stcsig-danger-bg: #fff1f2;--stcsig-shadow: 0 12px 34px rgba(15, 23, 42, .07);--stcsig-shadow-sm: 0 6px 18px rgba(15, 23, 42, .06);min-height:100vh;padding:18px;background:radial-gradient(circle at top right,rgba(3,105,161,.08),transparent 28rem),var(--stcsig-bg);color:var(--stcsig-text);font-family:var(--pps-font-main, "Sora", "Noto Sans Thai", system-ui, sans-serif);font-size:var(--fs-14, 14px)}.stcsig-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.stcsig-title{display:flex;align-items:center;gap:12px;font-size:var(--fs-22, 22px);font-weight:800;letter-spacing:-.02em}.stcsig-subtitle{margin-top:2px;font-size:var(--fs-12, 12px);font-weight:600;color:var(--stcsig-muted);letter-spacing:normal}.stcsig-actions,.stcsig-actionsWrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.stcsig-btn{border:1px solid var(--stcsig-border);background:#fff;color:var(--stcsig-text);min-height:38px;padding:9px 13px;border-radius:12px;box-shadow:var(--stcsig-shadow-sm);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;cursor:pointer;text-decoration:none;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.stcsig-btn:hover:not(:disabled){border-color:#94a3b8;transform:translateY(-1px)}.stcsig-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.stcsig-btnIcon{width:42px;padding:0}.stcsig-btnPrimary{border-color:transparent;background:linear-gradient(180deg,var(--stcsig-primary-2),var(--stcsig-primary));color:#fff}.stcsig-grid{display:grid;grid-template-columns:minmax(0,.78fr) minmax(0,1.22fr);gap:14px;align-items:start}.stcsig-span2{grid-column:1 / span 2}.stcsig-card{background:#fffffff5;border:1px solid var(--stcsig-border);border-radius:18px;box-shadow:var(--stcsig-shadow);padding:16px}.stcsig-cardHead,.stcsig-cardTitle{display:flex;align-items:center;gap:10px}.stcsig-cardHead{justify-content:space-between;margin-bottom:12px}.stcsig-cardTitle{font-size:var(--fs-16, 16px);font-weight:900;margin-bottom:12px}.stcsig-cardHead .stcsig-cardTitle{margin-bottom:0}.stcsig-drop{min-height:126px;border:1px dashed #93c5fd;background:#f8fbff;border-radius:16px;padding:18px;display:flex;align-items:center;gap:14px;cursor:pointer}.stcsig-drop input{display:none}.stcsig-drop svg{width:34px;height:34px;color:var(--stcsig-primary);flex:0 0 auto}.stcsig-drop b,.stcsig-drop span{display:block}.stcsig-drop b{word-break:break-word}.stcsig-drop span{color:var(--stcsig-muted);font-size:var(--fs-12, 12px);margin-top:4px}.stcsig-note,.stcsig-mini{color:var(--stcsig-muted);font-size:var(--fs-12, 12px);font-weight:650;line-height:1.55}.stcsig-note{margin-top:10px}.stcsig-checks{margin-top:12px;display:grid;gap:8px}.stcsig-checks label{display:inline-flex;align-items:center;gap:8px;color:var(--stcsig-text);font-weight:700}.stcsig-controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.stcsig-field{display:flex;flex-direction:column;gap:6px}.stcsig-field span{font-size:var(--fs-12, 12px);color:var(--stcsig-muted);font-weight:800}.stcsig-field input{border:1px solid var(--stcsig-border);border-radius:12px;padding:10px 12px;font-weight:800;outline:none;background:#fff}.stcsig-field input:focus{border-color:#38bdf8;box-shadow:0 0 0 4px #38bdf826}.stcsig-actionsWrap{margin-top:12px}.stcsig-env{margin:0;padding:14px;border-radius:14px;border:1px solid var(--stcsig-border-soft);background:#0f172a;color:#e0f2fe;overflow:auto;font-family:var(--pps-font-mono, ui-monospace, SFMono-Regular, Menlo, Consolas, monospace);font-size:var(--fs-12, 12px);line-height:1.7}.stcsig-preview{width:100%;height:min(78vh,900px);border:1px solid var(--stcsig-border-soft);border-radius:16px;background:#fff}.stcsig-empty{min-height:320px;border:1px dashed var(--stcsig-border);border-radius:16px;background:#f8fafc;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--stcsig-muted);padding:24px}.stcsig-alert{border-radius:14px;padding:12px 14px;margin-bottom:14px;font-weight:800}.stcsig-alertDanger{border:1px solid #fecaca;background:var(--stcsig-danger-bg);color:var(--stcsig-danger)}.stcsig-loading{margin-top:14px;text-align:center;color:var(--stcsig-muted);font-weight:800}@media(max-width:980px){.stcsig-grid{grid-template-columns:1fr}.stcsig-span2{grid-column:auto}.stcsig-controls{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.stcsig-page{padding:12px}.stcsig-topbar{flex-direction:column}.stcsig-title{font-size:var(--fs-18, 18px)}.stcsig-card{padding:13px;border-radius:16px}.stcsig-controls{grid-template-columns:1fr}.stcsig-actions,.stcsig-actionsWrap{width:100%}.stcsig-btn{flex:1 1 auto}.stcsig-preview{height:70vh}}.wpd-page{--wpd-bg: #f3f6fb;--wpd-surface: #ffffff;--wpd-surface-2: #f8fbff;--wpd-border: #dbe4ee;--wpd-border-strong: #c4d2e1;--wpd-text: #0f172a;--wpd-text-soft: #334155;--wpd-muted: #64748b;--wpd-primary: #0b6aa2;--wpd-primary-strong: #075985;--wpd-primary-soft: #e0f2fe;--wpd-success: #047857;--wpd-success-soft: #ecfdf5;--wpd-success-border: #a7f3d0;--wpd-warning: #b45309;--wpd-warning-soft: #fffbeb;--wpd-warning-border: #fcd34d;--wpd-info: #1d4ed8;--wpd-info-soft: #eff6ff;--wpd-info-border: #bfdbfe;--wpd-danger: #be123c;--wpd-danger-soft: #fff1f2;--wpd-danger-border: #fecdd3;--wpd-shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--wpd-shadow-sm: 0 8px 24px rgba(15, 23, 42, .06);--wpd-shadow-md: 0 14px 34px rgba(15, 23, 42, .08);--wpd-radius-sm: 12px;--wpd-radius-md: 16px;--wpd-radius-lg: 20px;--wpd-radius-pill: 999px;--wpd-fs-2xs: .6875rem;--wpd-fs-xs: .8125rem;--wpd-fs-sm: .875rem;--wpd-fs-md: 1rem;--wpd-fs-lg: 1.125rem;--wpd-fs-xl: 1.375rem;--wpd-fs-2xl: 1.875rem;--wpd-lh-tight: 1.2;--wpd-lh-base: 1.45;--wpd-gap-1: 6px;--wpd-gap-2: 8px;--wpd-gap-3: 10px;--wpd-gap-4: 12px;--wpd-gap-5: 16px;--wpd-gap-6: 20px;--wpd-gap-7: 24px;min-height:100%;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));background:radial-gradient(circle at top right,rgba(14,165,233,.08),transparent 24%),linear-gradient(180deg,#f8fbff 0%,var(--wpd-bg) 100%);color:var(--wpd-text);overflow:auto;-webkit-overflow-scrolling:touch;font-family:var(--pps-font-main);font-size:var(--wpd-fs-md);line-height:var(--wpd-lh-base);box-sizing:border-box}.wpd-page,.wpd-page *{box-sizing:border-box}.wpd-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--wpd-gap-4);flex-wrap:wrap;margin-bottom:var(--wpd-gap-4)}.wpd-title{font-size:clamp(1.125rem,1rem + .6vw,1.5rem);font-weight:800;line-height:var(--wpd-lh-tight);letter-spacing:-.01em;color:var(--wpd-text)}.wpd-sub,.wpd-muted{font-size:var(--wpd-fs-xs);color:var(--wpd-muted)}.wpd-sub{margin-top:4px}.wpd-actions,.wpd-sectionRight{display:flex;align-items:center;gap:var(--wpd-gap-2);flex-wrap:wrap}.wpd-btn{min-height:40px;padding:0 14px;border:1px solid var(--wpd-border);border-radius:var(--wpd-radius-sm);background:linear-gradient(180deg,#fff,#f8fafc);color:var(--wpd-text);box-shadow:var(--wpd-shadow-xs);font-size:var(--wpd-fs-xs);font-weight:800;line-height:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease,color .16s ease}.wpd-btn:hover:not(:disabled){border-color:var(--wpd-border-strong);box-shadow:var(--wpd-shadow-sm);transform:translateY(-1px)}.wpd-btn:active:not(:disabled){transform:translateY(0);box-shadow:var(--wpd-shadow-xs)}.wpd-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.wpd-btn-primary{color:#fff;border-color:transparent;background:linear-gradient(180deg,var(--wpd-primary) 0%,var(--wpd-primary-strong) 100%)}.wpd-btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#0a77b7,#0a5f91)}.wpd-btn-icon{width:40px;min-width:40px;padding:0}.wpd-error,.wpd-note{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;margin:8px 0 12px;border-radius:14px;font-size:var(--wpd-fs-sm);line-height:1.4}.wpd-error{color:var(--wpd-danger);background:linear-gradient(180deg,#fff7f8 0%,var(--wpd-danger-soft) 100%);border:1px solid var(--wpd-danger-border);box-shadow:var(--wpd-shadow-xs);font-weight:700}.wpd-note{color:#9a3412;background:linear-gradient(180deg,#fffdf7,#fff7ed);border:1px solid #fed7aa;box-shadow:var(--wpd-shadow-xs);font-weight:600}.wpd-section{background:linear-gradient(180deg,var(--wpd-surface) 0%,#fcfdff 100%);border:1px solid var(--wpd-border);border-radius:var(--wpd-radius-lg);padding:14px;box-shadow:var(--wpd-shadow-sm);margin-bottom:14px}.wpd-sectionHead{display:flex;align-items:center;justify-content:space-between;gap:var(--wpd-gap-3);flex-wrap:wrap;margin-bottom:12px}.wpd-sectionTitle{font-size:var(--wpd-fs-sm);font-weight:800;color:var(--wpd-text);letter-spacing:.01em}.wpd-modeToggle{display:flex;flex-wrap:wrap;gap:8px;padding:6px;border:1px solid var(--wpd-border);border-radius:14px;background:linear-gradient(180deg,#fff,#f8fbff)}.wpd-modeBtn{min-height:38px;padding:0 12px;border:1px solid transparent;border-radius:10px;background:transparent;color:var(--wpd-muted);font-size:var(--wpd-fs-xs);font-weight:800;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:background .16s ease,color .16s ease,border-color .16s ease,transform .16s ease}.wpd-modeBtn:hover:not(:disabled){color:var(--wpd-text-soft);background:#f8fafc}.wpd-modeBtn.is-active{color:var(--wpd-primary-strong);background:linear-gradient(180deg,#edf8ff 0%,var(--wpd-primary-soft) 100%);border-color:#bae6fd;box-shadow:inset 0 0 0 1px #0284c70f}.wpd-modeIcon{display:inline-flex;align-items:center;justify-content:center;line-height:1}.wpd-kpiRow,.wpd-typeGrid,.wpd-actionGrid,.wpd-statusGrid{display:grid;grid-template-columns:1fr;gap:12px;padding-bottom:12px}.wpd-kpiCard,.wpd-typeCard,.wpd-statusCard{position:relative;background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--wpd-border);border-radius:16px;padding:14px;box-shadow:var(--wpd-shadow-xs)}.wpd-kpiCard:hover,.wpd-typeCard:hover,.wpd-statusCard:hover{box-shadow:var(--wpd-shadow-sm)}.wpd-statusCard{text-align:left;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.wpd-statusCard:hover:not(:disabled){transform:translateY(-1px);border-color:#c7d7e8;background:linear-gradient(180deg,#fff,#f9fcff)}.wpd-statusCard:disabled{cursor:not-allowed;opacity:.7}.wpd-kpiLabel,.wpd-statusLabel,.wpd-typeCode{font-size:var(--wpd-fs-2xs);color:var(--wpd-muted);font-weight:800;letter-spacing:.02em}.wpd-kpiLabel{display:flex;align-items:center;gap:6px}.wpd-kpiValue{margin-top:6px;font-size:clamp(1.625rem,1.2rem + 1vw,var(--wpd-fs-2xl));font-weight:800;line-height:var(--wpd-lh-tight);color:var(--wpd-text)}.wpd-kpiHint,.wpd-statusHint{margin-top:6px;font-size:var(--wpd-fs-2xs);color:var(--wpd-muted)}.wpd-statusTop{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.wpd-statusCount,.wpd-typeValue{font-size:clamp(1.125rem,1rem + .5vw,var(--wpd-fs-xl));font-weight:800;line-height:var(--wpd-lh-tight);color:var(--wpd-text)}.wpd-typeLabel{font-size:var(--wpd-fs-sm);font-weight:800;color:var(--wpd-text-soft)}.wpd-typeCode{margin-top:6px}.wpd-tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--wpd-border);border-radius:16px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:inset 0 1px #ffffffbf;max-height:420px}.wpd-table{width:100%;min-width:760px;border-collapse:separate;border-spacing:0;background:transparent}.wpd-table thead th{position:sticky;top:0;z-index:2;padding:11px 12px;border-bottom:1px solid var(--wpd-border);background:linear-gradient(180deg,#f8fbff,#f1f6fb);color:var(--wpd-text-soft);font-size:var(--wpd-fs-2xs);font-weight:800;text-align:left;white-space:nowrap;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.wpd-table tbody td{padding:11px 12px;border-bottom:1px solid #edf2f7;font-size:var(--wpd-fs-xs);vertical-align:top;background:transparent}.wpd-table tbody tr:last-child td{border-bottom:0}.wpd-table tbody tr:hover td{background:#f9fcff}.wpd-tdMuted{color:var(--wpd-muted)}.wpd-link{color:var(--wpd-primary);font-weight:700;text-decoration:none;transition:color .16s ease,text-decoration-color .16s ease}.wpd-link:hover{color:var(--wpd-primary-strong);text-decoration:underline}.wpd-pill{display:inline-flex;align-items:center;min-height:26px;padding:3px 10px;border-radius:var(--wpd-radius-pill);border:1px solid var(--wpd-border);background:#fff;color:var(--wpd-text-soft);white-space:nowrap;font-size:var(--wpd-fs-2xs);font-weight:800;line-height:1}.wpd-pill-gray{background:#f1f5f9;color:#334155;border-color:#d8e1ea}.wpd-pill-amber{background:var(--wpd-warning-soft);color:var(--wpd-warning);border-color:var(--wpd-warning-border)}.wpd-pill-blue{background:var(--wpd-info-soft);color:var(--wpd-info);border-color:var(--wpd-info-border)}.wpd-pill-green{background:var(--wpd-success-soft);color:var(--wpd-success);border-color:var(--wpd-success-border)}.wpd-pill-red{background:var(--wpd-danger-soft);color:var(--wpd-danger);border-color:var(--wpd-danger-border)}.wpd-footnote{margin-top:10px;font-size:var(--wpd-fs-2xs);color:var(--wpd-muted)}.wpd-btn:focus-visible,.wpd-modeBtn:focus-visible,.wpd-statusCard:focus-visible,.wpd-link:focus-visible{outline:2px solid #7dd3fc;outline-offset:2px}@media(max-width:479px){.wpd-page{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}.wpd-section{padding:12px;border-radius:16px}.wpd-btn{width:100%}.wpd-btn-icon{width:40px;min-width:40px}.wpd-actions{width:100%}.wpd-actions .wpd-btn:not(.wpd-btn-icon){flex:1 1 100%}.wpd-modeToggle{gap:6px}.wpd-modeBtn{flex:1 1 calc(50% - 6px);justify-content:center}.wpd-statusTop{align-items:flex-start;flex-direction:column;gap:4px}}@media(min-width:640px){.wpd-typeGrid,.wpd-statusGrid,.wpd-actionGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px){.wpd-page{padding:18px 20px 24px}.wpd-kpiRow{grid-template-columns:repeat(3,minmax(0,1fr))}.wpd-section{padding:16px}}@media(min-width:1100px){.wpd-statusGrid{grid-template-columns:repeat(5,minmax(0,1fr))}.wpd-typeGrid,.wpd-actionGrid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(prefers-reduced-motion:reduce){.wpd-btn,.wpd-modeBtn,.wpd-statusCard,.wpd-link{transition:none}}.wpl-page{--wpl-bg: #f3f6fb;--wpl-surface: #ffffff;--wpl-surface-2: #f8fbff;--wpl-border: #dbe4ee;--wpl-border-strong: #c4d2e1;--wpl-text: #0f172a;--wpl-text-soft: #334155;--wpl-muted: #64748b;--wpl-primary: #0b6aa2;--wpl-primary-strong: #075985;--wpl-primary-soft: #e0f2fe;--wpl-success: #047857;--wpl-success-soft: #ecfdf5;--wpl-success-border: #a7f3d0;--wpl-warning: #b45309;--wpl-warning-soft: #fffbeb;--wpl-warning-border: #fcd34d;--wpl-info: #1d4ed8;--wpl-info-soft: #eff6ff;--wpl-info-border: #bfdbfe;--wpl-danger: #be123c;--wpl-danger-soft: #fff1f2;--wpl-danger-border: #fecdd3;--wpl-shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--wpl-shadow-sm: 0 8px 24px rgba(15, 23, 42, .06);--wpl-shadow-md: 0 14px 34px rgba(15, 23, 42, .08);--wpl-radius-sm: 12px;--wpl-radius-md: 16px;--wpl-radius-lg: 20px;--wpl-radius-pill: 999px;--wpl-fs-2xs: .6875rem;--wpl-fs-xs: .8125rem;--wpl-fs-sm: .875rem;--wpl-fs-md: 1rem;--wpl-fs-lg: 1.125rem;--wpl-fs-xl: 1.375rem;--wpl-lh-tight: 1.2;--wpl-lh-base: 1.45;--wpl-gap-1: 6px;--wpl-gap-2: 8px;--wpl-gap-3: 10px;--wpl-gap-4: 12px;--wpl-gap-5: 16px;--wpl-gap-6: 20px;--wpl-gap-7: 24px;min-height:100%;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));background:radial-gradient(circle at top right,rgba(14,165,233,.08),transparent 24%),linear-gradient(180deg,#f8fbff 0%,var(--wpl-bg) 100%);color:var(--wpl-text);overflow:auto;-webkit-overflow-scrolling:touch;font-family:var(--pps-font-main);font-size:var(--wpl-fs-md);line-height:var(--wpl-lh-base);box-sizing:border-box}.wpl-page,.wpl-page *{box-sizing:border-box}.wpl-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--wpl-gap-4);flex-wrap:wrap;margin-bottom:var(--wpl-gap-4)}.wpl-title{font-size:clamp(1.125rem,1rem + .6vw,1.5rem);font-weight:800;line-height:var(--wpl-lh-tight);letter-spacing:-.01em;color:var(--wpl-text)}.wpl-sub,.wpl-muted{font-size:var(--wpl-fs-xs);color:var(--wpl-muted)}.wpl-sub{margin-top:4px}.wpl-actions,.wpl-sectionRight{display:flex;align-items:center;gap:var(--wpl-gap-2);flex-wrap:wrap}.wpl-btn{min-height:40px;padding:0 14px;border:1px solid var(--wpl-border);border-radius:var(--wpl-radius-sm);background:linear-gradient(180deg,#fff,#f8fafc);color:var(--wpl-text);box-shadow:var(--wpl-shadow-xs);font-size:var(--wpl-fs-xs);font-weight:800;line-height:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease,color .16s ease}.wpl-btn:hover:not(:disabled){border-color:var(--wpl-border-strong);box-shadow:var(--wpl-shadow-sm);transform:translateY(-1px)}.wpl-btn:active:not(:disabled){transform:translateY(0);box-shadow:var(--wpl-shadow-xs)}.wpl-btn:disabled,.wpl-iconBtn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.wpl-btn-primary{color:#fff;border-color:transparent;background:linear-gradient(180deg,var(--wpl-primary) 0%,var(--wpl-primary-strong) 100%)}.wpl-btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#0a77b7,#0a5f91)}.wpl-btn-icon{width:40px;min-width:40px;padding:0}.wpl-iconBtn{width:40px;min-width:40px;height:40px;padding:0;border:1px solid var(--wpl-border);border-radius:var(--wpl-radius-sm);background:linear-gradient(180deg,#fff,#f8fafc);color:var(--wpl-primary);box-shadow:var(--wpl-shadow-xs);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease,color .16s ease}.wpl-iconBtn:hover:not(:disabled){border-color:#bae6fd;background:linear-gradient(180deg,#f0f9ff 0%,var(--wpl-primary-soft) 100%);box-shadow:var(--wpl-shadow-sm);transform:translateY(-1px)}.wpl-error,.wpl-note{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;margin:8px 0 12px;border-radius:14px;font-size:var(--wpl-fs-sm);line-height:1.4}.wpl-error{color:var(--wpl-danger);background:linear-gradient(180deg,#fff7f8 0%,var(--wpl-danger-soft) 100%);border:1px solid var(--wpl-danger-border);box-shadow:var(--wpl-shadow-xs);font-weight:700}.wpl-note{color:#9a3412;background:linear-gradient(180deg,#fffdf7,#fff7ed);border:1px solid #fed7aa;box-shadow:var(--wpl-shadow-xs);font-weight:600}.wpl-section{background:linear-gradient(180deg,var(--wpl-surface) 0%,#fcfdff 100%);border:1px solid var(--wpl-border);border-radius:var(--wpl-radius-lg);padding:14px;box-shadow:var(--wpl-shadow-sm);margin-bottom:14px}.wpl-sectionHead{display:flex;align-items:center;justify-content:space-between;gap:var(--wpl-gap-3);flex-wrap:wrap;margin-bottom:12px}.wpl-sectionTitle{font-size:var(--wpl-fs-sm);font-weight:800;color:var(--wpl-text);letter-spacing:.01em}.wpl-modeToggle{display:flex;flex-wrap:wrap;gap:8px;padding:6px;border:1px solid var(--wpl-border);border-radius:14px;background:linear-gradient(180deg,#fff,#f8fbff)}.wpl-modeBtn{min-height:38px;padding:0 12px;border:1px solid transparent;border-radius:10px;background:transparent;color:var(--wpl-muted);font-size:var(--wpl-fs-xs);font-weight:800;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:background .16s ease,color .16s ease,border-color .16s ease,transform .16s ease}.wpl-modeBtn:hover:not(:disabled){color:var(--wpl-text-soft);background:#f8fafc}.wpl-modeBtn.is-active{color:var(--wpl-primary-strong);background:linear-gradient(180deg,#edf8ff 0%,var(--wpl-primary-soft) 100%);border-color:#bae6fd;box-shadow:inset 0 0 0 1px #0284c70f}.wpl-modeIcon{display:inline-flex;align-items:center;justify-content:center;line-height:1}.wpl-filterRow{display:grid;grid-template-columns:1fr;gap:12px;align-items:end}.wpl-field{display:flex;flex-direction:column;gap:6px;min-width:0}.wpl-fieldGrow{min-width:0}.wpl-field label{font-size:var(--wpl-fs-2xs);color:var(--wpl-muted);font-weight:800;letter-spacing:.02em}.wpl-field input,.wpl-field select{width:100%;min-height:40px;border:1px solid var(--wpl-border);border-radius:12px;background:linear-gradient(180deg,#fff,#fbfdff);color:var(--wpl-text);padding:0 12px;outline:none;font-size:var(--wpl-fs-sm);box-shadow:var(--wpl-shadow-xs);transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.wpl-field input:focus,.wpl-field select:focus{border-color:#0b6aa273;box-shadow:0 0 0 3px #0b6aa21f;background:#fff}.wpl-field input:disabled,.wpl-field select:disabled{background:#f8fafc;color:#94a3b8;cursor:not-allowed}.wpl-searchWrap{display:flex;align-items:center;gap:8px}.wpl-searchWrap input{flex:1 1 auto;min-width:0}.wpl-tableWrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--wpl-border);border-radius:16px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:inset 0 1px #ffffffbf;max-height:calc(100vh - 340px)}.wpl-table{width:100%;min-width:1080px;border-collapse:separate;border-spacing:0;background:transparent}.wpl-table thead th{position:sticky;top:0;z-index:2;padding:11px 12px;border-bottom:1px solid var(--wpl-border);background:linear-gradient(180deg,#f8fbff,#f1f6fb);color:var(--wpl-text-soft);font-size:var(--wpl-fs-2xs);font-weight:800;text-align:left;white-space:nowrap;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.wpl-table tbody td{padding:11px 12px;border-bottom:1px solid #edf2f7;font-size:var(--wpl-fs-xs);vertical-align:top;background:transparent}.wpl-table tbody tr:last-child td{border-bottom:0}.wpl-table tbody tr:hover td{background:#f9fcff}.wpl-tdMuted{color:var(--wpl-muted)}.wpl-link{color:var(--wpl-primary);font-weight:700;text-decoration:none;transition:color .16s ease,text-decoration-color .16s ease}.wpl-link:hover{color:var(--wpl-primary-strong);text-decoration:underline}.wpl-pill{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:3px 10px;border-radius:var(--wpl-radius-pill);border:1px solid var(--wpl-border);background:#fff;color:var(--wpl-text-soft);white-space:nowrap;font-size:var(--wpl-fs-2xs);font-weight:800;line-height:1;gap:6px}.wpl-pill-gray{background:#f1f5f9;color:#334155;border-color:#d8e1ea}.wpl-pill-amber{background:var(--wpl-warning-soft);color:var(--wpl-warning);border-color:var(--wpl-warning-border)}.wpl-pill-blue{background:var(--wpl-info-soft);color:var(--wpl-info);border-color:var(--wpl-info-border)}.wpl-pill-green{background:var(--wpl-success-soft);color:var(--wpl-success);border-color:var(--wpl-success-border)}.wpl-pill-red{background:var(--wpl-danger-soft);color:var(--wpl-danger);border-color:var(--wpl-danger-border)}.wpl-pager{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:12px;font-size:var(--wpl-fs-sm)}.wpl-footnote{margin-top:10px;font-size:var(--wpl-fs-2xs);color:var(--wpl-muted)}.wpl-btn:focus-visible,.wpl-modeBtn:focus-visible,.wpl-link:focus-visible,.wpl-iconBtn:focus-visible,.wpl-field input:focus-visible,.wpl-field select:focus-visible{outline:2px solid #7dd3fc;outline-offset:2px}@media(max-width:479px){.wpl-page{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}.wpl-section{padding:12px;border-radius:16px}.wpl-btn{width:100%}.wpl-btn-icon{width:40px;min-width:40px}.wpl-actions{width:100%}.wpl-actions .wpl-btn:not(.wpl-btn-icon){flex:1 1 100%}.wpl-modeToggle{gap:6px}.wpl-modeBtn{flex:1 1 calc(50% - 6px);justify-content:center}.wpl-pager{flex-direction:column;align-items:stretch}.wpl-pager .wpl-btn{width:100%}}@media(min-width:640px){.wpl-filterRow{grid-template-columns:repeat(2,minmax(0,1fr))}.wpl-fieldGrow{grid-column:span 2}}@media(min-width:900px){.wpl-page{padding:18px 20px 24px}.wpl-section{padding:16px}.wpl-filterRow{grid-template-columns:170px 180px minmax(280px,1fr) 120px}.wpl-fieldGrow{grid-column:auto}}@media(prefers-reduced-motion:reduce){.wpl-btn,.wpl-modeBtn,.wpl-iconBtn,.wpl-link,.wpl-field input,.wpl-field select{transition:none}}.wpf-page{--wpf-bg: #f3f6fb;--wpf-surface: #ffffff;--wpf-surface-2: #f8fbff;--wpf-surface-3: #fcfdff;--wpf-border: #dbe4ee;--wpf-border-strong: #c4d2e1;--wpf-text: #0f172a;--wpf-text-soft: #334155;--wpf-muted: #64748b;--wpf-placeholder: #94a3b8;--wpf-primary: #0b6aa2;--wpf-primary-strong: #075985;--wpf-primary-soft: #e0f2fe;--wpf-primary-ring: rgba(11, 106, 162, .12);--wpf-success: #047857;--wpf-success-soft: #ecfdf5;--wpf-success-border: #a7f3d0;--wpf-warning: #b45309;--wpf-warning-soft: #fffbeb;--wpf-warning-border: #fcd34d;--wpf-info: #1d4ed8;--wpf-info-soft: #eff6ff;--wpf-info-border: #bfdbfe;--wpf-danger: #be123c;--wpf-danger-soft: #fff1f2;--wpf-danger-border: #fecdd3;--wpf-gray-soft: #f1f5f9;--wpf-shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--wpf-shadow-sm: 0 8px 24px rgba(15, 23, 42, .06);--wpf-shadow-md: 0 14px 34px rgba(15, 23, 42, .08);--wpf-shadow-lg: 0 22px 54px rgba(15, 23, 42, .16);--wpf-radius-sm: 12px;--wpf-radius-md: 16px;--wpf-radius-lg: 20px;--wpf-radius-pill: 999px;--wpf-fs-2xs: .6625rem;--wpf-fs-xs: .7625rem;--wpf-fs-sm: .8375rem;--wpf-fs-md: .9375rem;--wpf-fs-lg: 1.0375rem;--wpf-fs-xl: 1.25rem;--wpf-fs-2xl: 1.65rem;--wpf-lh-tight: 1.2;--wpf-lh-base: 1.45;--wpf-gap-1: 6px;--wpf-gap-2: 8px;--wpf-gap-3: 10px;--wpf-gap-4: 12px;--wpf-gap-5: 16px;--wpf-gap-6: 20px;--wpf-gap-7: 24px;min-height:100%;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));background:radial-gradient(circle at top right,rgba(14,165,233,.08),transparent 24%),linear-gradient(180deg,#f8fbff 0%,var(--wpf-bg) 100%);color:var(--wpf-text);overflow:auto;-webkit-overflow-scrolling:touch;font-family:var(--pps-font-main);font-size:var(--wpf-fs-md);line-height:var(--wpf-lh-base);box-sizing:border-box}.wpf-page,.wpf-page *,.wpf-page *:before,.wpf-page *:after{box-sizing:border-box}.wpf-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--wpf-gap-4);flex-wrap:wrap;margin-bottom:var(--wpf-gap-4)}.wpf-title{font-size:clamp(1.05rem,.95rem + .45vw,1.375rem);font-weight:800;line-height:var(--wpf-lh-tight);letter-spacing:-.01em;color:var(--wpf-text)}.wpf-sub,.wpf-sectionSub,.wpf-miniLabel,.wpf-listMeta,.wpf-checkMeta,.wpf-noteText,.wpf-modalSub,.wpf-summaryItem span,.wpf-kpiLabel{font-size:var(--wpf-fs-xs);color:var(--wpf-muted)}.wpf-sub{margin-top:4px}.wpf-actions,.wpf-sectionRight,.wpf-modalActions{display:flex;align-items:center;gap:var(--wpf-gap-2);flex-wrap:wrap}.wpf-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:14px}.wpf-main{min-width:0}.wpf-side{display:grid;gap:12px;align-self:start}@media(min-width:1200px){.wpf-layout{grid-template-columns:minmax(0,1fr) 340px}.wpf-side{position:sticky;top:16px}}.wpf-section,.wpf-sideCard,.wpf-modalCard{background:linear-gradient(180deg,var(--wpf-surface) 0%,var(--wpf-surface-3) 100%);border:1px solid var(--wpf-border);border-radius:var(--wpf-radius-lg);box-shadow:var(--wpf-shadow-sm)}.wpf-section{padding:14px;margin-bottom:14px}.wpf-sideCard{padding:14px}.wpf-sectionHead,.wpf-modalHead{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap;margin-bottom:12px}.wpf-sectionTitle,.wpf-sideTitle,.wpf-subTitle,.wpf-modalTitle{font-size:var(--wpf-fs-sm);font-weight:800;line-height:var(--wpf-lh-tight);color:var(--wpf-text);letter-spacing:.01em}.wpf-divider{height:1px;background:linear-gradient(90deg,transparent 0%,var(--wpf-border) 12%,var(--wpf-border) 88%,transparent 100%);margin:14px 0}.wpf-grid{display:grid;grid-template-columns:1fr;gap:12px}.wpf-field{display:flex;flex-direction:column;gap:6px;min-width:0}.wpf-field-full{grid-column:1 / -1}.wpf-field label{display:inline-flex;align-items:center;gap:6px;font-size:var(--wpf-fs-2xs);color:var(--wpf-muted);font-weight:800;letter-spacing:.02em}.wpf-field input,.wpf-field select,.wpf-field textarea{width:100%;border:1px solid var(--wpf-border);border-radius:12px;background:linear-gradient(180deg,#fff,#fbfdff);color:var(--wpf-text);padding:9px 11px;outline:none;font-size:var(--wpf-fs-sm);font-family:inherit;box-shadow:var(--wpf-shadow-xs);transition:border-color .16s ease,box-shadow .16s ease,background .16s ease,color .16s ease}.wpf-field select{min-height:38px;appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,#64748b 50%),linear-gradient(135deg,#64748b 50%,transparent 50%),linear-gradient(180deg,#fff,#fbfdff);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px),0 0;background-size:6px 6px,6px 6px,100% 100%;background-repeat:no-repeat;padding-right:34px}.wpf-field textarea{resize:vertical;min-height:96px}.wpf-field input::placeholder,.wpf-field textarea::placeholder{color:var(--wpf-placeholder)}.wpf-field input:hover,.wpf-field select:hover,.wpf-field textarea:hover{border-color:var(--wpf-border-strong)}.wpf-field input:focus,.wpf-field select:focus,.wpf-field textarea:focus{border-color:#0b6aa273;box-shadow:0 0 0 3px var(--wpf-primary-ring);background:#fff}.wpf-field input[readonly],.wpf-field textarea[readonly]{background:#f8fafc;color:var(--wpf-text-soft)}.wpf-field input:disabled,.wpf-field select:disabled,.wpf-field textarea:disabled{background:#f8fafc;color:#64748b;cursor:not-allowed;opacity:1;box-shadow:none}.wpf-btn,.wpf-iconBtn{min-height:38px;padding:0 14px;border:1px solid var(--wpf-border);border-radius:var(--wpf-radius-sm);background:linear-gradient(180deg,#fff,#f8fafc);color:var(--wpf-text);box-shadow:var(--wpf-shadow-xs);font-size:var(--wpf-fs-xs);font-weight:800;line-height:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;cursor:pointer;text-decoration:none;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease,color .16s ease}.wpf-btn:hover:not(:disabled),.wpf-iconBtn:hover:not(:disabled){border-color:var(--wpf-border-strong);box-shadow:var(--wpf-shadow-sm);transform:translateY(-1px)}.wpf-btn:active:not(:disabled),.wpf-iconBtn:active:not(:disabled){transform:translateY(0);box-shadow:var(--wpf-shadow-xs)}.wpf-btn:disabled,.wpf-iconBtn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.wpf-btn-primary{color:#fff;border-color:transparent;background:linear-gradient(180deg,var(--wpf-primary) 0%,var(--wpf-primary-strong) 100%)}.wpf-btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#0a77b7,#0a5f91);border-color:transparent}.wpf-btn-danger{color:var(--wpf-danger);border-color:var(--wpf-danger-border);background:linear-gradient(180deg,#fff7f8 0%,var(--wpf-danger-soft) 100%)}.wpf-btn-danger:hover:not(:disabled){background:linear-gradient(180deg,#fff1f4,#ffe4e6);border-color:#fda4af}.wpf-iconBtn{width:38px;min-width:38px;padding:0}.wpf-error,.wpf-noteBox{box-shadow:var(--wpf-shadow-xs)}.wpf-error{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;margin:8px 0 12px;border-radius:14px;color:var(--wpf-danger);background:linear-gradient(180deg,#fff7f8 0%,var(--wpf-danger-soft) 100%);border:1px solid var(--wpf-danger-border);font-size:var(--wpf-fs-sm);line-height:1.4;font-weight:700}.wpf-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--wpf-radius-pill);background:linear-gradient(180deg,#edf8ff 0%,var(--wpf-primary-soft) 100%);color:var(--wpf-primary-strong);font-size:var(--wpf-fs-2xs);font-weight:800;white-space:nowrap;border:1px solid #bae6fd}.wpf-pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--wpf-radius-pill);font-size:var(--wpf-fs-2xs);font-weight:800;border:1px solid var(--wpf-border);background:#fff;white-space:nowrap}.wpf-pill-gray{background:var(--wpf-gray-soft);color:#334155}.wpf-pill-amber{background:var(--wpf-warning-soft);border-color:var(--wpf-warning-border);color:var(--wpf-warning)}.wpf-pill-green{background:var(--wpf-success-soft);border-color:var(--wpf-success-border);color:var(--wpf-success)}.wpf-pill-blue{background:var(--wpf-info-soft);border-color:var(--wpf-info-border);color:var(--wpf-info)}.wpf-pill-red{background:var(--wpf-danger-soft);border-color:var(--wpf-danger-border);color:var(--wpf-danger)}.wpf-checklist{display:grid;gap:10px}.wpf-checkItem{display:grid;grid-template-columns:minmax(0,1fr);gap:10px;padding:12px;border:1px solid var(--wpf-border);border-radius:var(--wpf-radius-md);background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--wpf-shadow-xs);transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.wpf-checkItem:hover{border-color:var(--wpf-border-strong);box-shadow:var(--wpf-shadow-sm)}@media(min-width:980px){.wpf-checkItem{grid-template-columns:minmax(0,1fr) 180px 240px;align-items:start}}.wpf-checkItemMain{display:flex;gap:10px;min-width:0}.wpf-checkIndex{flex:0 0 28px;height:28px;border-radius:999px;background:linear-gradient(180deg,#edf8ff 0%,var(--wpf-primary-soft) 100%);color:var(--wpf-primary-strong);display:flex;align-items:center;justify-content:center;font-size:var(--wpf-fs-xs);font-weight:800;border:1px solid #bae6fd}.wpf-checkText{font-size:var(--wpf-fs-sm);font-weight:700;color:var(--wpf-text);word-break:break-word}.wpf-checkControls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;min-height:38px}.wpf-radio,.wpf-closeoutOpt{display:inline-flex;gap:8px;align-items:center;font-size:var(--wpf-fs-sm);font-weight:700;color:var(--wpf-text)}.wpf-radio input,.wpf-closeoutOpt input{margin:0;accent-color:var(--wpf-primary)}.wpf-checkNote{min-width:0}.wpf-checkNote input,.wpf-checkNote textarea{width:100%;padding:10px 12px}.wpf-checkNote textarea{min-height:92px}.wpf-ppeGrid{display:grid;grid-template-columns:1fr;gap:10px}@media(min-width:860px){.wpf-ppeGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}.wpf-ppeCard{display:flex;flex-direction:column;gap:10px;padding:12px;border:1px solid var(--wpf-border);border-radius:var(--wpf-radius-md);background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--wpf-shadow-xs);transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.wpf-ppeCard:hover{border-color:var(--wpf-border-strong);box-shadow:var(--wpf-shadow-sm)}.wpf-ppeCard input[type=text],.wpf-ppeCard input:not([type]){width:100%}.wpf-ppeHead{display:flex;gap:8px;align-items:flex-start;font-size:var(--wpf-fs-sm);font-weight:700;color:var(--wpf-text)}.wpf-ppeHead input{margin-top:2px;flex:0 0 auto;accent-color:var(--wpf-primary)}.wpf-approvalGrid{display:grid;grid-template-columns:1fr;gap:10px}@media(min-width:920px){.wpf-approvalGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}.wpf-approvalCard{display:flex;gap:10px;padding:12px;border-radius:var(--wpf-radius-md);border:1px solid var(--wpf-border);background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--wpf-shadow-xs);transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.wpf-approvalCard:hover{box-shadow:var(--wpf-shadow-sm)}.wpf-approvalCard.is-active{background:linear-gradient(180deg,#edf8ff 0%,var(--wpf-primary-soft) 100%);border-color:#7dd3fc}.wpf-approvalCard.is-done{background:linear-gradient(180deg,#f4fff9 0%,var(--wpf-success-soft) 100%);border-color:var(--wpf-success-border)}.wpf-approvalCard.is-warn{background:linear-gradient(180deg,#fffdf5 0%,var(--wpf-warning-soft) 100%);border-color:var(--wpf-warning-border)}.wpf-approvalCard.is-reject{background:linear-gradient(180deg,#fff7f8 0%,var(--wpf-danger-soft) 100%);border-color:var(--wpf-danger-border)}.wpf-approvalIcon{width:38px;height:38px;border-radius:999px;background:#fff;border:1px solid var(--wpf-border);box-shadow:var(--wpf-shadow-xs);display:flex;align-items:center;justify-content:center;color:var(--wpf-primary);flex:0 0 auto}.wpf-approvalBody{min-width:0}.wpf-approvalTitle,.wpf-summaryItem b,.wpf-noteTitle{font-size:var(--wpf-fs-sm);font-weight:800;color:var(--wpf-text)}.wpf-approvalPerson,.wpf-approvalMine,.wpf-listTitle,.wpf-listNote{font-size:var(--wpf-fs-xs)}.wpf-approvalPerson,.wpf-listTitle,.wpf-listNote{word-break:break-word}.wpf-approvalMine{margin-top:4px;color:var(--wpf-primary-strong);font-weight:800}.wpf-actionRow{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:12px}.wpf-closeoutOptions{display:flex;gap:12px;flex-wrap:wrap;margin:12px 0}.wpf-subCard{border:1px solid var(--wpf-border);border-radius:var(--wpf-radius-md);padding:12px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--wpf-shadow-xs)}.wpf-subTitle{display:inline-flex;align-items:center;gap:8px;margin-bottom:10px}.wpf-list{display:grid;gap:10px;max-height:320px;overflow:auto;padding-right:4px}.wpf-listItem{padding:10px;border:1px solid var(--wpf-border);border-radius:12px;background:var(--wpf-surface-2)}.wpf-empty{padding:12px;border:1px dashed var(--wpf-border-strong);border-radius:12px;color:var(--wpf-muted);font-size:var(--wpf-fs-sm);background:#fcfcfd}.wpf-kpiRow{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;margin-top:10px}.wpf-kpiCard{padding:12px;border:1px solid var(--wpf-border);border-radius:var(--wpf-radius-md);background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--wpf-shadow-xs)}.wpf-kpiValue{font-size:clamp(1.125rem,1rem + .5vw,var(--wpf-fs-xl));font-weight:800;line-height:var(--wpf-lh-tight);margin-top:4px;color:var(--wpf-text);word-break:break-word}.wpf-summaryList,.wpf-anchorList{display:grid;gap:8px}.wpf-summaryItem{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.wpf-summaryItem span{flex:0 0 110px}.wpf-summaryItem b{text-align:right;word-break:break-word}.wpf-noteBox{display:flex;gap:10px;align-items:flex-start;padding:9px 11px;border-radius:12px;background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--wpf-border);margin-top:10px}.wpf-noteBox svg{flex:0 0 auto;margin-top:2px;color:var(--wpf-primary)}.wpf-modalBack{position:fixed;inset:0;background:#0f172a75;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:18px;z-index:1000}.wpf-modalCard{width:min(100%,560px);max-height:min(88vh,760px);overflow:auto;padding:14px;box-shadow:var(--wpf-shadow-lg)}.wpf-modalActions{justify-content:flex-end;margin-top:12px}.wpf-btn:focus-visible,.wpf-iconBtn:focus-visible,.wpf-field input:focus-visible,.wpf-field select:focus-visible,.wpf-field textarea:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}.wpf-list::-webkit-scrollbar{width:10px}.wpf-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px;border:2px solid transparent;background-clip:padding-box}.wpf-list::-webkit-scrollbar-track{background:transparent}@media(max-width:900px){.wpf-checkItem{grid-template-columns:1fr}}@media(max-width:640px){.wpf-page{padding:14px 12px}.wpf-title{font-size:var(--wpf-fs-lg)}.wpf-actions{width:100%}.wpf-actions .wpf-btn{flex:1 1 calc(50% - 8px);min-width:0}.wpf-section,.wpf-sideCard{padding:12px}.wpf-kpiRow{grid-template-columns:1fr}.wpf-summaryItem{flex-direction:column;align-items:stretch}.wpf-summaryItem span,.wpf-summaryItem b{text-align:left;flex:unset}.wpf-closeoutOptions{gap:10px}.wpf-modalBack{padding:12px;align-items:flex-end}.wpf-modalCard{width:100%;max-height:min(92vh,820px);border-bottom-left-radius:0;border-bottom-right-radius:0}}@media(max-width:420px){.wpf-actions .wpf-btn{flex:1 1 100%}.wpf-closeoutOptions,.wpf-actionRow,.wpf-actions{flex-direction:column;align-items:stretch}.wpf-actionRow .wpf-btn,.wpf-closeoutOpt,.wpf-actions .wpf-btn{width:100%;justify-content:center}.wpf-checkControls{flex-direction:column;align-items:flex-start}}.wpf-searchSelect{position:relative;display:grid;grid-template-columns:minmax(0,1fr) 40px;gap:8px}.wpf-searchSelect.is-disabled{opacity:1}.wpf-searchSelectBtn{min-height:38px;border:1px solid var(--wpf-border);border-radius:12px;background:linear-gradient(180deg,#fff,#fbfdff);color:var(--wpf-text);box-shadow:var(--wpf-shadow-xs);cursor:pointer;font:inherit}.wpf-searchSelectBtn:hover:not(:disabled){border-color:var(--wpf-border-strong)}.wpf-searchSelectBtn:disabled{background:#f8fafc;color:#64748b;cursor:not-allowed;box-shadow:none}.wpf-searchSelectMenu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;max-height:320px;overflow:auto;padding:6px;border:1px solid var(--wpf-border);border-radius:14px;background:#fff;box-shadow:var(--wpf-shadow-md)}.wpf-searchSelectItem{width:100%;border:0;background:transparent;border-radius:10px;padding:9px 11px;text-align:left;cursor:pointer;display:block}.wpf-searchSelectItem:hover{background:var(--wpf-primary-soft)}.wpf-searchSelectItem.is-active{background:var(--wpf-primary-soft);outline:1px solid #bae6fd}.wpf-searchSelectLabel{font-size:var(--wpf-fs-sm);font-weight:700;color:var(--wpf-text);word-break:break-word}.wpf-searchSelectMeta{margin-top:2px;font-size:var(--wpf-fs-xs);color:var(--wpf-muted);word-break:break-word}.wpf-searchSelectEmpty{padding:12px;font-size:var(--wpf-fs-sm);color:var(--wpf-muted)}.wpf-page{--wpf-fs-2xs: .8125rem;--wpf-fs-xs: .9375rem;--wpf-fs-sm: 1.0625rem;--wpf-fs-md: 1.125rem;--wpf-fs-lg: 1.35rem;--wpf-fs-xl: 1.65rem;--wpf-fs-2xl: 2.25rem;--wpf-lh-base: 1.55;--wpf-gap-4: 14px;--wpf-gap-5: 18px;--wpf-gap-6: 24px;--wpf-gap-7: 30px;padding:24px 28px 42px;font-size:var(--wpf-fs-md)}.wpf-header{align-items:center;margin-bottom:24px;padding:4px 0}.wpf-title{font-size:clamp(1.65rem,1.25rem + 1.1vw,2.35rem);letter-spacing:-.025em}.wpf-sub{margin-top:8px;font-size:1.05rem;color:#64748b}.wpf-layout{grid-template-columns:minmax(0,1fr);gap:22px}@media(min-width:1200px){.wpf-layout{grid-template-columns:minmax(0,1fr) 360px;gap:26px}.wpf-side{top:22px}}.wpf-section,.wpf-sideCard,.wpf-modalCard{border-radius:24px;border-color:#d3dfec;box-shadow:0 12px 34px #0f172a13}.wpf-section{padding:24px;margin-bottom:22px}.wpf-sideCard{padding:20px}.wpf-sectionHead,.wpf-modalHead{margin-bottom:18px;gap:16px}.wpf-sectionTitle,.wpf-sideTitle,.wpf-subTitle,.wpf-modalTitle{font-size:1.28rem;letter-spacing:-.01em}.wpf-sectionSub,.wpf-miniLabel,.wpf-listMeta,.wpf-checkMeta,.wpf-noteText,.wpf-modalSub,.wpf-summaryItem span,.wpf-kpiLabel{font-size:.98rem}.wpf-grid{gap:18px 22px}.wpf-grid-2{grid-template-columns:1fr}@media(min-width:900px){.wpf-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.wpf-field{gap:8px}.wpf-field label{font-size:1rem;color:#53657e;letter-spacing:.01em}.wpf-field input,.wpf-field select,.wpf-field textarea,.wpf-searchSelectBtn{min-height:54px;border-radius:16px;padding:14px 18px;font-size:1.12rem;border-color:#ccd9e8}.wpf-field select{min-height:54px;padding-right:44px;background-position:calc(100% - 23px) calc(50% - 2px),calc(100% - 16px) calc(50% - 2px),0 0}.wpf-field textarea{min-height:128px}.wpf-field input[readonly],.wpf-field textarea[readonly],.wpf-field input:disabled,.wpf-field select:disabled,.wpf-field textarea:disabled{background:#f8fbff;color:#334155}.wpf-btn,.wpf-iconBtn{min-height:50px;border-radius:16px;padding:0 20px;font-size:1.05rem;gap:10px}.wpf-iconBtn{width:50px;min-width:50px;padding:0}.wpf-badge,.wpf-pill{font-size:.9rem;padding:6px 12px}.wpf-error,.wpf-noteBox{border-radius:18px}.wpf-error{padding:16px 18px;margin:12px 0 18px;font-size:1.08rem}.wpf-checklist,.wpf-ppeGrid,.wpf-approvalGrid,.wpf-list,.wpf-summaryList,.wpf-anchorList{gap:14px}.wpf-checkItem,.wpf-ppeCard,.wpf-approvalCard,.wpf-subCard,.wpf-listItem,.wpf-kpiCard{border-radius:18px;padding:18px;border-color:#d3dfec}@media(min-width:980px){.wpf-checkItem{grid-template-columns:minmax(0,1fr) 220px minmax(260px,320px);gap:18px}}@media(min-width:860px){.wpf-ppeGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}}@media(min-width:920px){.wpf-approvalGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}}.wpf-checkIndex{width:38px;height:38px;flex-basis:38px;font-size:1rem}.wpf-checkText,.wpf-ppeHead,.wpf-radio,.wpf-closeoutOpt,.wpf-approvalPerson,.wpf-approvalMine,.wpf-listTitle,.wpf-listNote,.wpf-empty{font-size:1.04rem}.wpf-approvalTitle,.wpf-summaryItem b,.wpf-noteTitle{font-size:1.1rem}.wpf-approvalIcon{width:48px;height:48px}.wpf-actionRow,.wpf-closeoutOptions,.wpf-actions,.wpf-sectionRight,.wpf-modalActions{gap:12px}.wpf-kpiRow{gap:14px}.wpf-kpiValue{font-size:clamp(1.45rem,1.15rem + .7vw,1.9rem);margin-top:8px}.wpf-summaryItem{gap:14px}.wpf-summaryItem span{flex:0 0 135px}.wpf-noteBox{padding:14px 16px;margin-top:14px}.wpf-searchSelect{grid-template-columns:minmax(0,1fr) 58px;gap:12px}.wpf-searchSelectBtn{padding:0;display:inline-flex;align-items:center;justify-content:center}.wpf-searchSelectMenu{top:calc(100% + 8px);max-height:380px;padding:8px;border-radius:18px}.wpf-searchSelectItem{border-radius:14px;padding:14px 16px}.wpf-searchSelectLabel{font-size:1.1rem;font-weight:800}.wpf-searchSelectMeta{margin-top:4px;font-size:.98rem}.wpf-searchSelectEmpty{padding:16px;font-size:1.02rem}.wpf-modalCard{width:min(100%,640px);padding:22px}@media(max-width:900px){.wpf-page{padding:20px 18px 34px}.wpf-section{padding:20px}.wpf-field input,.wpf-field select,.wpf-field textarea,.wpf-searchSelectBtn{font-size:1.06rem}}@media(max-width:640px){.wpf-page{padding:16px 12px 28px;--wpf-fs-md: .9375rem}.wpf-title{font-size:1.55rem}.wpf-sub{font-size:.98rem}.wpf-section,.wpf-sideCard{padding:16px;border-radius:20px}.wpf-sectionTitle,.wpf-sideTitle,.wpf-subTitle,.wpf-modalTitle{font-size:1.15rem}.wpf-grid{gap:14px}.wpf-field input,.wpf-field select,.wpf-field textarea,.wpf-searchSelectBtn{min-height:50px;padding:12px 14px;font-size:1rem;border-radius:14px}.wpf-searchSelect{grid-template-columns:minmax(0,1fr) 52px;gap:8px}.wpf-btn,.wpf-iconBtn{min-height:48px;font-size:1rem}}.wpf-field label{font-size:.72rem}.wpf-field input,.wpf-field select,.wpf-field textarea,.wpf-btn,.wpf-searchSelectBtn{font-size:.9rem}.wpf-sectionTitle,.wpf-sideTitle,.wpf-subTitle,.wpf-modalTitle{font-size:.95rem}.wpf-checkText,.wpf-ppeHead,.wpf-approvalTitle,.wpf-summaryItem b,.wpf-noteTitle,.wpf-searchSelectLabel{font-size:.9rem}.wpf-sub,.wpf-sectionSub,.wpf-miniLabel,.wpf-listMeta,.wpf-checkMeta,.wpf-noteText,.wpf-modalSub,.wpf-summaryItem span,.wpf-kpiLabel,.wpf-searchSelectMeta{font-size:.78rem}@media(max-width:640px){.wpf-title{font-size:1.05rem}}.wpf-selectedPreview,.wpf-gallery{margin-top:12px;padding:12px;border:1px solid var(--wpf-border);border-radius:16px;background:#ffffffc7}.wpf-galleryHead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;font-weight:800}.wpf-attachmentRow{display:grid;grid-template-columns:72px minmax(0,1fr) auto;align-items:center;gap:12px}.wpf-attachmentThumb,.wpf-attachmentIcon,.wpf-imageBox{border:1px solid var(--wpf-border);border-radius:14px;background:#f7fafc;overflow:hidden}.wpf-attachmentThumb{width:72px;height:58px;padding:0;cursor:pointer;color:var(--wpf-muted);font-size:var(--wpf-fs-xs)}.wpf-attachmentThumb:disabled{cursor:wait;opacity:.72}.wpf-attachmentThumb img,.wpf-imageBox img{width:100%;height:100%;object-fit:cover;display:block}.wpf-attachmentIcon{width:72px;height:58px;display:grid;place-items:center;color:var(--wpf-muted);font-size:22px}.wpf-attachmentInfo{min-width:0}.wpf-attachmentActions{justify-content:flex-end;flex-wrap:nowrap}.wpf-imageGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.wpf-imageCard{border:1px solid var(--wpf-border);border-radius:14px;overflow:hidden;background:#fff}.wpf-imageBox{width:100%;aspect-ratio:4 / 3;padding:0;display:block}.wpf-imageBtn{cursor:pointer}.wpf-imageMeta{padding:9px 10px}.wpf-imageName{font-weight:800;font-size:var(--wpf-fs-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wpf-lightbox{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:18px;background:#0f172a9e}.wpf-lightboxInner{width:min(980px,100%);max-height:calc(100vh - 36px);display:flex;flex-direction:column;overflow:hidden;border-radius:18px;background:#fff;box-shadow:0 18px 42px #0f172a57}.wpf-lightboxHead{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--wpf-border)}.wpf-lightboxTitle{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:900}.wpf-lightboxBody{padding:14px;overflow:auto}.wpf-lightboxBody img{width:100%;height:auto;max-height:calc(100vh - 140px);object-fit:contain;display:block;border-radius:12px}@media(max-width:980px){.wpf-imageGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.wpf-attachmentRow{grid-template-columns:64px minmax(0,1fr)}.wpf-attachmentActions{grid-column:1 / -1;justify-content:flex-start}.wpf-attachmentThumb,.wpf-attachmentIcon{width:64px;height:54px}}.wpf-attachmentTrackingGrid{display:grid;grid-template-columns:minmax(0,1fr);gap:18px}@media(min-width:1320px){.wpf-attachmentTrackingGrid{grid-template-columns:minmax(0,1.35fr) minmax(360px,.65fr);align-items:start}}.wpf-attachmentsCard{overflow:hidden}.wpf-requiredPhotoGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0 0 16px}.wpf-requiredPhotoCard{display:flex;align-items:center;gap:12px;min-width:0;padding:13px 14px;border-radius:18px;border:1px solid var(--wpf-border);background:#fff}.wpf-requiredPhotoCard.is-ok{border-color:var(--wpf-success-border);background:linear-gradient(180deg,#f6fff9 0%,var(--wpf-success-soft) 100%)}.wpf-requiredPhotoCard.is-missing{border-color:var(--wpf-warning-border);background:linear-gradient(180deg,#fffdf5 0%,var(--wpf-warning-soft) 100%)}.wpf-requiredIcon{width:34px;height:34px;flex:0 0 34px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-weight:900;border:1px solid currentColor}.wpf-requiredPhotoCard.is-ok .wpf-requiredIcon{color:var(--wpf-success)}.wpf-requiredPhotoCard.is-missing .wpf-requiredIcon{color:var(--wpf-warning)}.wpf-requiredTitle{font-size:.95rem;font-weight:900;color:var(--wpf-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wpf-requiredText{margin-top:2px;font-size:.82rem;color:var(--wpf-muted)}.wpf-attachmentUploadGrid{display:grid;grid-template-columns:minmax(220px,1fr) minmax(220px,1fr) auto;gap:12px;align-items:end;margin-bottom:16px;padding:14px;border:1px solid var(--wpf-border);border-radius:18px;background:linear-gradient(180deg,#fff,#f8fbff)}.wpf-attachmentUploadGrid .wpf-actionRow{margin-top:0}.wpf-attachmentsList{max-height:none;overflow:visible;padding-right:0}.wpf-attachmentRow{grid-template-columns:118px minmax(0,1fr) auto;align-items:center;gap:16px;min-width:0}.wpf-attachmentThumb,.wpf-attachmentIcon{width:118px;height:86px;border-radius:18px}.wpf-attachmentThumb{box-shadow:inset 0 0 0 1px #0f172a0a}.wpf-attachmentInfo,.wpf-listTitle,.wpf-listMeta,.wpf-listNote{min-width:0}.wpf-attachmentInfo .wpf-listTitle{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1rem;font-weight:900;line-height:1.35}.wpf-attachmentInfo .wpf-listMeta{overflow-wrap:anywhere;word-break:normal;line-height:1.45}.wpf-attachmentActions{margin-top:0;gap:10px}.wpf-attachmentActions .wpf-btn{min-width:50px;width:50px;min-height:50px;padding:0;border-radius:16px}.wpf-selectedPreview .wpf-imageBox{max-width:360px;aspect-ratio:16 / 10}.wpf-gallery{margin-top:18px}.wpf-imageGrid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.wpf-imageCard{border-radius:18px;box-shadow:var(--wpf-shadow-xs)}.wpf-imageBox{aspect-ratio:16 / 10;border-radius:0;background:#eef4fb}.wpf-imageName{font-size:.95rem;line-height:1.35}@media(max-width:920px){.wpf-attachmentUploadGrid,.wpf-requiredPhotoGrid{grid-template-columns:1fr}.wpf-attachmentUploadGrid .wpf-btn{width:100%}}@media(max-width:780px){.wpf-attachmentRow{grid-template-columns:104px minmax(0,1fr);align-items:start}.wpf-attachmentThumb,.wpf-attachmentIcon{width:104px;height:78px}.wpf-attachmentActions{grid-column:1 / -1;justify-content:flex-start}.wpf-attachmentActions .wpf-btn{flex:0 0 52px}.wpf-imageGrid{grid-template-columns:repeat(auto-fill,minmax(145px,1fr))}}.wpf-main{display:block;width:100%;min-width:0}.wpf-bottomSummary{display:grid;grid-template-columns:1fr;gap:16px}.wpf-bottomSummary>.wpf-sideCard{margin:0;box-shadow:none}@media(min-width:980px){.wpf-bottomSummary{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start}}@media(min-width:1200px){.wpf-main{max-width:none}}.wpf-layout{display:block;width:100%}.wpf-attachmentTrackingGrid{grid-template-columns:minmax(0,1fr)!important;align-items:stretch}.wpf-attachmentsCard{width:100%}.wpf-bottomSummary{align-items:stretch}.wpf-bottomSummary>.wpf-subCard,.wpf-bottomSummary>.wpf-sideCard{margin:0;min-width:0;box-shadow:none}.wpf-eventTimelineCard{display:flex;flex-direction:column}.wpf-eventTimelineList{max-height:520px;overflow:auto;padding-right:4px}@media(min-width:980px){.wpf-bottomSummary{grid-template-columns:repeat(2,minmax(0,1fr))}.wpf-eventTimelineCard{grid-column:1 / -1}}@media(min-width:1320px){.wpf-bottomSummary{grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr) minmax(360px,.85fr)}.wpf-eventTimelineCard{grid-column:auto}}.wpf-galleryGroups{display:grid;gap:14px}.wpf-galleryGroup{border:1px solid var(--wpf-border);border-radius:16px;padding:12px;background:#f8fafcdb}.wpf-galleryGroupHead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.wpf-galleryGroupTitle{display:inline-flex;align-items:center;gap:8px;min-width:0;font-weight:800;color:var(--wpf-text)}.wpf-galleryPurposeDot{width:10px;height:10px;border-radius:999px;background:#64748b;box-shadow:0 0 0 4px #64748b24;flex:0 0 auto}.wpf-galleryCount{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-width:58px;padding:5px 10px;border-radius:999px;border:1px solid var(--wpf-border);background:#fff;color:var(--wpf-muted);font-size:var(--wpf-fs-xs);font-weight:800}.wpf-galleryGroup.is-work-area-photo-before .wpf-galleryPurposeDot{background:#16a34a;box-shadow:0 0 0 4px #16a34a24}.wpf-galleryGroup.is-work-area-photo-after .wpf-galleryPurposeDot,.wpf-galleryGroup.is-closeout-evidence .wpf-galleryPurposeDot{background:#d97706;box-shadow:0 0 0 4px #d9770624}.wpf-galleryGroup.is-checklist-evidence .wpf-galleryPurposeDot{background:#2563eb;box-shadow:0 0 0 4px #2563eb24}.wpf-galleryGroup.is-request-doc .wpf-galleryPurposeDot{background:#7c3aed;box-shadow:0 0 0 4px #7c3aed24}@media(max-width:640px){.wpf-galleryGroup{padding:10px}.wpf-galleryGroupHead{align-items:flex-start;flex-direction:column}}.wpf-reportPage .wpf-header{align-items:flex-start}.wpf-reportApprovedBanner{display:flex;align-items:center;gap:10px;margin:8px 0 16px;padding:14px 16px;border:1px solid var(--wpf-success-border);border-radius:18px;background:linear-gradient(180deg,#f6fff9 0%,var(--wpf-success-soft) 100%);color:var(--wpf-success);font-weight:900;box-shadow:var(--wpf-shadow-xs)}.wpf-reportSheetPreview{background:#fff}.wpf-reportPreviewHead{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:18px;margin-bottom:16px;border-radius:20px;background:linear-gradient(135deg,#075985,#0b6aa2);color:#fff}.wpf-reportKicker{font-size:.78rem;font-weight:900;letter-spacing:.08em;opacity:.9}.wpf-reportPreviewHead h1{margin:4px 0;font-size:clamp(1.25rem,1rem + .8vw,1.85rem);line-height:1.2}.wpf-reportPreviewHead p{margin:0;font-size:.95rem;opacity:.92}.wpf-reportNoBox{min-width:180px;padding:12px 14px;border-radius:16px;background:#fff;color:#075985;text-align:right;box-shadow:var(--wpf-shadow-xs)}.wpf-reportNoBox span{display:block;font-size:.75rem;font-weight:900;letter-spacing:.05em}.wpf-reportNoBox b{display:block;margin-top:4px;font-size:1.15rem}.wpf-reportStatusStrip{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 16px;padding:12px 14px;border:1px solid var(--wpf-success-border);border-radius:16px;background:var(--wpf-success-soft);color:#065f46}.wpf-reportStatusStrip span{color:#047857;font-size:.88rem;font-weight:700}.wpf-reportInfoBox{min-width:0;padding:14px;border:1px solid var(--wpf-border);border-radius:18px;background:linear-gradient(180deg,#fff,#f8fbff)}.wpf-reportFullBox{margin-top:18px}.wpf-reportInfoRow{display:grid;grid-template-columns:120px minmax(0,1fr);gap:12px;padding:8px 0;border-bottom:1px dashed var(--wpf-border)}.wpf-reportInfoRow:last-child{border-bottom:0}.wpf-reportInfoRow span{color:var(--wpf-muted);font-size:.82rem;font-weight:800}.wpf-reportInfoRow b{color:var(--wpf-text);font-size:.9rem;font-weight:800;overflow-wrap:anywhere}.wpf-reportChecklistGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.wpf-reportChecklistGrid b{display:block;margin-bottom:8px;color:var(--wpf-primary-strong)}.wpf-reportCheckLine{padding:7px 0;border-bottom:1px dashed var(--wpf-border);color:var(--wpf-text-soft);font-size:.88rem}@media(max-width:760px){.wpf-reportPreviewHead,.wpf-reportStatusStrip{flex-direction:column;align-items:stretch}.wpf-reportNoBox{min-width:0;text-align:left}.wpf-reportInfoRow{grid-template-columns:1fr;gap:3px}.wpf-reportChecklistGrid{grid-template-columns:1fr}}.wpai-page{--wpai-bg: #f3f6fb;--wpai-surface: #ffffff;--wpai-surface-2: #f8fbff;--wpai-surface-3: #fcfdff;--wpai-border: #dbe4ee;--wpai-border-strong: #c4d2e1;--wpai-text: #0f172a;--wpai-text-soft: #334155;--wpai-muted: #64748b;--wpai-placeholder: #94a3b8;--wpai-primary: #0b6aa2;--wpai-primary-strong: #075985;--wpai-primary-soft: #e0f2fe;--wpai-primary-ring: rgba(11, 106, 162, .12);--wpai-success: #047857;--wpai-success-soft: #ecfdf5;--wpai-success-border: #a7f3d0;--wpai-warning: #b45309;--wpai-warning-soft: #fffbeb;--wpai-warning-border: #fcd34d;--wpai-danger: #be123c;--wpai-danger-soft: #fff1f2;--wpai-danger-border: #fecdd3;--wpai-info: #1d4ed8;--wpai-info-soft: #eff6ff;--wpai-info-border: #bfdbfe;--wpai-gray-soft: #f1f5f9;--wpai-shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--wpai-shadow-sm: 0 8px 24px rgba(15, 23, 42, .06);--wpai-shadow-md: 0 14px 34px rgba(15, 23, 42, .08);--wpai-shadow-lg: 0 22px 54px rgba(15, 23, 42, .16);--wpai-radius-sm: 12px;--wpai-radius-md: 16px;--wpai-radius-lg: 20px;--wpai-radius-pill: 999px;--wpai-fs-2xs: .6875rem;--wpai-fs-xs: .8125rem;--wpai-fs-sm: .875rem;--wpai-fs-md: 1rem;--wpai-fs-lg: 1.125rem;--wpai-fs-xl: 1.375rem;--wpai-fs-2xl: 1.875rem;--wpai-lh-tight: 1.2;--wpai-lh-base: 1.45;--wpai-gap-1: 6px;--wpai-gap-2: 8px;--wpai-gap-3: 10px;--wpai-gap-4: 12px;--wpai-gap-5: 16px;--wpai-gap-6: 20px;--wpai-gap-7: 24px;min-height:100%;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));background:radial-gradient(circle at top right,rgba(14,165,233,.08),transparent 24%),linear-gradient(180deg,#f8fbff 0%,var(--wpai-bg) 100%);color:var(--wpai-text);overflow:auto;-webkit-overflow-scrolling:touch;font-family:var(--pps-font-main);font-size:var(--wpai-fs-md);line-height:var(--wpai-lh-base);box-sizing:border-box}.wpai-page,.wpai-page *,.wpai-page *:before,.wpai-page *:after{box-sizing:border-box}.wpai-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--wpai-gap-4);flex-wrap:wrap;margin-bottom:var(--wpai-gap-4)}.wpai-title{margin:0;font-size:clamp(1.125rem,1rem + .6vw,1.5rem);font-weight:800;line-height:var(--wpai-lh-tight);letter-spacing:-.01em;color:var(--wpai-text)}.wpai-sub,.wpai-muted,.wpai-help,.wpai-label,.wpai-empty{color:var(--wpai-muted);font-size:var(--wpai-fs-xs)}.wpai-sub{margin-top:4px}.wpai-actions,.wpai-toolbar,.wpai-rowTop,.wpai-rowMeta,.wpai-cardActions,.wpai-modalActions{display:flex;gap:var(--wpai-gap-2);flex-wrap:wrap}.wpai-actions,.wpai-rowMeta,.wpai-modalActions{align-items:center}.wpai-toolbar,.wpai-rowTop{align-items:flex-start;justify-content:space-between}.wpai-section,.wpai-card,.wpai-summaryCard,.wpai-modalCard{background:linear-gradient(180deg,var(--wpai-surface) 0%,var(--wpai-surface-3) 100%);border:1px solid var(--wpai-border);border-radius:var(--wpai-radius-lg);box-shadow:var(--wpai-shadow-sm)}.wpai-section,.wpai-modalCard{padding:14px}.wpai-section{margin-bottom:14px}.wpai-card,.wpai-summaryCard{padding:14px}.wpai-btn,.wpai-iconBtn,.wpai-select,.wpai-input,.wpai-textarea{min-height:40px;border:1px solid var(--wpai-border);border-radius:var(--wpai-radius-sm);font:inherit}.wpai-btn,.wpai-iconBtn{background:linear-gradient(180deg,#fff,#f8fafc);color:var(--wpai-text);box-shadow:var(--wpai-shadow-xs);font-size:var(--wpai-fs-xs);font-weight:800;line-height:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease,color .16s ease}.wpai-btn{padding:0 14px;white-space:nowrap}.wpai-iconBtn{width:40px;min-width:40px;padding:0}.wpai-btn:hover:not(:disabled),.wpai-iconBtn:hover:not(:disabled){border-color:var(--wpai-border-strong);box-shadow:var(--wpai-shadow-sm);transform:translateY(-1px)}.wpai-btn:active:not(:disabled),.wpai-iconBtn:active:not(:disabled){transform:translateY(0);box-shadow:var(--wpai-shadow-xs)}.wpai-btn:disabled,.wpai-iconBtn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.wpai-btn-primary{color:#fff;border-color:transparent;background:linear-gradient(180deg,var(--wpai-primary) 0%,var(--wpai-primary-strong) 100%)}.wpai-btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#0a77b7,#0a5f91);border-color:transparent}.wpai-btn-ghost{background:#fff}.wpai-btn-danger{color:var(--wpai-danger);border-color:var(--wpai-danger-border);background:linear-gradient(180deg,#fff7f8 0%,var(--wpai-danger-soft) 100%)}.wpai-btn-danger:hover:not(:disabled){background:linear-gradient(180deg,#fff1f4,#ffe4e6);border-color:#fda4af}.wpai-input,.wpai-select,.wpai-textarea{width:100%;background:linear-gradient(180deg,#fff,#fbfdff);color:var(--wpai-text);padding:10px 12px;outline:none;box-shadow:var(--wpai-shadow-xs);transition:border-color .16s ease,box-shadow .16s ease,background .16s ease,color .16s ease}.wpai-input::placeholder,.wpai-textarea::placeholder{color:var(--wpai-placeholder)}.wpai-input:hover,.wpai-select:hover,.wpai-textarea:hover{border-color:var(--wpai-border-strong)}.wpai-input:focus,.wpai-select:focus,.wpai-textarea:focus{border-color:#0b6aa273;box-shadow:0 0 0 3px var(--wpai-primary-ring);background:#fff}.wpai-input:disabled,.wpai-select:disabled,.wpai-textarea:disabled{background:#f8fafc;color:var(--wpai-muted);cursor:not-allowed;opacity:1;box-shadow:none}.wpai-select{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,#64748b 50%),linear-gradient(135deg,#64748b 50%,transparent 50%),linear-gradient(180deg,#fff,#fbfdff);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px),0 0;background-size:6px 6px,6px 6px,100% 100%;background-repeat:no-repeat;padding-right:34px}.wpai-textarea{min-height:100px;resize:vertical}.wpai-summaryGrid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px}@media(min-width:768px){.wpai-summaryGrid{grid-template-columns:repeat(4,minmax(0,1fr))}}.wpai-summaryNumber{font-size:clamp(1.375rem,1.2rem + .9vw,var(--wpai-fs-2xl));font-weight:900;line-height:var(--wpai-lh-tight);color:var(--wpai-text)}.wpai-summaryTitle{margin-top:4px;font-size:var(--wpai-fs-sm);font-weight:800;color:var(--wpai-text-soft)}.wpai-searchRow{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:900px){.wpai-searchRow{grid-template-columns:minmax(260px,1fr) auto;align-items:end}}.wpai-list{display:grid;gap:12px}.wpai-card{transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.wpai-card:hover{border-color:var(--wpai-border-strong);box-shadow:var(--wpai-shadow-md)}.wpai-cardHead{display:grid;gap:10px}.wpai-badge,.wpai-pill{display:inline-flex;align-items:center;min-height:24px;padding:4px 10px;border-radius:var(--wpai-radius-pill);font-size:var(--wpai-fs-2xs);font-weight:800;white-space:nowrap}.wpai-badge{color:var(--wpai-primary-strong);border:1px solid #bae6fd;background:linear-gradient(180deg,#edf8ff 0%,var(--wpai-primary-soft) 100%)}.wpai-pill{color:var(--wpai-text-soft);border:1px solid var(--wpai-border);background:#fff}.wpai-pill-amber{color:var(--wpai-warning);border-color:var(--wpai-warning-border);background:var(--wpai-warning-soft)}.wpai-pill-green{color:var(--wpai-success);border-color:var(--wpai-success-border);background:var(--wpai-success-soft)}.wpai-pill-red{color:var(--wpai-danger);border-color:var(--wpai-danger-border);background:var(--wpai-danger-soft)}.wpai-cardTitle{color:var(--wpai-text);font-size:var(--fs-16);font-weight:800;line-height:1.35;word-break:break-word}.wpai-cardDesc{margin-top:6px;color:var(--wpai-text-soft);font-size:var(--wpai-fs-sm);line-height:1.45;word-break:break-word}.wpai-help{word-break:break-word}.wpai-metaGrid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:10px;margin-top:12px}@media(min-width:900px){.wpai-metaGrid{grid-template-columns:repeat(3,minmax(0,1fr))}}.wpai-metaItem{padding:10px 12px;background:linear-gradient(180deg,#ffffff 0%,var(--wpai-surface-2) 100%);border:1px solid var(--wpai-border);border-radius:14px}.wpai-metaItem strong{display:block;margin-top:2px;color:var(--wpai-text);font-size:var(--wpai-fs-sm);font-weight:800;line-height:1.4;word-break:break-word}.wpai-cardActions{margin-top:12px}.wpai-error,.wpai-note{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;margin:8px 0 12px;border-radius:14px;font-size:var(--wpai-fs-sm);line-height:1.4;box-shadow:var(--wpai-shadow-xs)}.wpai-error{color:var(--wpai-danger);background:linear-gradient(180deg,#fff7f8 0%,var(--wpai-danger-soft) 100%);border:1px solid var(--wpai-danger-border);font-weight:700}.wpai-note{color:#9a3412;background:linear-gradient(180deg,#fffdf7,#fff7ed);border:1px solid #fed7aa;font-weight:600}.wpai-empty{text-align:center;padding:28px 16px;border:1px dashed var(--wpai-border-strong);border-radius:16px;background:linear-gradient(180deg,#fff,#fbfdff)}.wpai-modalWrap{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:16px;background:#0f172a6b;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.wpai-modalCard{width:min(100%,560px);box-shadow:var(--wpai-shadow-lg)}.wpai-modalTitle{margin:0;font-size:var(--fs-16);font-weight:800;color:var(--wpai-text)}.wpai-field{display:grid;gap:6px;margin-top:12px}.wpai-modalActions{justify-content:flex-end;margin-top:14px}.wpai-btn:focus-visible,.wpai-iconBtn:focus-visible,.wpai-input:focus-visible,.wpai-select:focus-visible,.wpai-textarea:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}.wpai-list::-webkit-scrollbar,.wpai-textarea::-webkit-scrollbar{width:10px;height:10px}.wpai-list::-webkit-scrollbar-thumb,.wpai-textarea::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px;border:2px solid transparent;background-clip:padding-box}.wpai-list::-webkit-scrollbar-track,.wpai-textarea::-webkit-scrollbar-track{background:transparent}@media(max-width:767px){.wpai-page{padding:14px 12px}.wpai-title{font-size:var(--wpai-fs-lg)}.wpai-header,.wpai-toolbar,.wpai-rowTop{align-items:stretch}.wpai-actions{width:100%}.wpai-actions .wpai-btn{flex:1 1 calc(50% - 8px);min-width:0}.wpai-section,.wpai-card,.wpai-summaryCard,.wpai-modalCard{padding:12px}.wpai-cardActions .wpai-btn,.wpai-cardActions a.wpai-btn{flex:1 1 100%}}@media(max-width:480px){.wpai-actions,.wpai-cardActions,.wpai-modalActions{flex-direction:column;align-items:stretch}.wpai-actions .wpai-btn,.wpai-actions .wpai-iconBtn,.wpai-cardActions .wpai-btn,.wpai-cardActions a.wpai-btn,.wpai-modalActions .wpai-btn{width:100%}.wpai-modalWrap{padding:12px;align-items:flex-end}.wpai-modalCard{width:100%;border-bottom-left-radius:0;border-bottom-right-radius:0}}.wpwi-page{--wpwi-bg: #f4f7fb;--wpwi-surface: #ffffff;--wpwi-surface-soft: #f8fbff;--wpwi-border: #dbe4ee;--wpwi-border-strong: #c2cfdd;--wpwi-text: #0f172a;--wpwi-soft: #475569;--wpwi-muted: #64748b;--wpwi-primary: #0b6aa2;--wpwi-primary-dark: #075985;--wpwi-primary-soft: #e0f2fe;--wpwi-success: #047857;--wpwi-success-soft: #ecfdf5;--wpwi-warning: #a16207;--wpwi-warning-soft: #fffbeb;--wpwi-shadow: 0 8px 24px rgba(15, 23, 42, .06);min-height:100%;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));background:radial-gradient(circle at top right,rgba(14,165,233,.08),transparent 24%),linear-gradient(180deg,#fbfdff 0%,var(--wpwi-bg) 100%);color:var(--wpwi-text);font-family:var(--pps-font-main);box-sizing:border-box}.wpwi-page,.wpwi-page *{box-sizing:border-box}.wpwi-header{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:14px;flex-wrap:wrap}.wpwi-kicker{margin:0 0 4px;color:var(--wpwi-primary);font-size:.75rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.wpwi-header h1{margin:0;color:var(--wpwi-text);font-size:clamp(1.2rem,1rem + .8vw,1.7rem);line-height:1.2;font-weight:900;letter-spacing:0}.wpwi-sub{max-width:760px;margin:6px 0 0;color:var(--wpwi-soft);font-size:.9rem;line-height:1.55}.wpwi-headerActions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.wpwi-btn,.wpwi-link{min-height:40px;border:1px solid var(--wpwi-border);border-radius:10px;background:linear-gradient(180deg,#fff,#f8fafc);color:var(--wpwi-text);text-decoration:none;box-shadow:0 1px 2px #0f172a0d;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.wpwi-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;font-size:.82rem;font-weight:900;white-space:nowrap}.wpwi-btnPrimary{color:#fff;border-color:transparent;background:linear-gradient(180deg,var(--wpwi-primary) 0%,var(--wpwi-primary-dark) 100%)}.wpwi-btn:hover,.wpwi-link:hover{border-color:var(--wpwi-border-strong);box-shadow:var(--wpwi-shadow);transform:translateY(-1px)}.wpwi-quickGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}.wpwi-link{display:flex;align-items:center;gap:10px;min-width:0;padding:12px}.wpwi-linkIcon{width:38px;min-width:38px;height:38px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:var(--wpwi-primary);background:var(--wpwi-primary-soft)}.wpwi-link strong,.wpwi-link small{display:block;line-height:1.35}.wpwi-link strong{font-size:.86rem;font-weight:900}.wpwi-link small{margin-top:2px;color:var(--wpwi-muted);font-size:.76rem}.wpwi-section{margin-bottom:14px;padding:14px;border:1px solid var(--wpwi-border);border-radius:14px;background:linear-gradient(180deg,var(--wpwi-surface) 0%,#fcfdff 100%);box-shadow:var(--wpwi-shadow)}.wpwi-sectionHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.wpwi-sectionHead svg{width:22px;min-width:22px;height:22px;color:var(--wpwi-primary)}.wpwi-section h2{margin:0;font-size:1rem;line-height:1.25;color:var(--wpwi-text);font-weight:900}.wpwi-sectionHead p{margin:4px 0 0;color:var(--wpwi-muted);font-size:.82rem;line-height:1.45}.wpwi-timeline{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.wpwi-step,.wpwi-role{display:flex;align-items:flex-start;gap:10px;min-width:0;padding:12px;border:1px solid var(--wpwi-border);border-radius:12px;background:var(--wpwi-surface-soft)}.wpwi-stepNo{width:30px;min-width:30px;height:30px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;background:var(--wpwi-primary);color:#fff;font-weight:900;font-size:.78rem}.wpwi-status{display:inline-flex;max-width:100%;padding:4px 8px;border-radius:999px;background:var(--wpwi-primary-soft);color:var(--wpwi-primary-dark);font-size:.68rem;font-weight:900;line-height:1.2;word-break:break-word}.wpwi-step h3{margin:8px 0 4px;font-size:.92rem;line-height:1.3;font-weight:900}.wpwi-step p,.wpwi-role p{margin:0;color:var(--wpwi-soft);font-size:.82rem;line-height:1.5}.wpwi-step small{display:block;margin-top:8px;color:var(--wpwi-muted);font-size:.75rem;font-weight:800}.wpwi-gridTwo{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.wpwi-roleList,.wpwi-actionList{display:grid;gap:8px}.wpwi-role span:first-child{width:34px;min-width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:var(--wpwi-success);background:var(--wpwi-success-soft)}.wpwi-role strong{display:block;margin-bottom:2px;font-size:.86rem;font-weight:900}.wpwi-action{display:grid;grid-template-columns:minmax(130px,.55fr) minmax(0,1fr);gap:10px;align-items:center;padding:10px 12px;border:1px solid var(--wpwi-border);border-radius:10px;background:var(--wpwi-surface-soft)}.wpwi-action code{color:var(--wpwi-primary-dark);font-size:.75rem;font-weight:900;white-space:normal;word-break:break-word}.wpwi-action span{color:var(--wpwi-soft);font-size:.82rem;line-height:1.45}.wpwi-sectionTable{display:grid;gap:8px}.wpwi-row{display:grid;grid-template-columns:110px 180px minmax(0,1fr);gap:10px;align-items:start;padding:10px 12px;border:1px solid var(--wpwi-border);border-radius:10px;background:var(--wpwi-surface-soft)}.wpwi-row strong{color:var(--wpwi-primary-dark);font-size:.8rem;font-weight:900}.wpwi-row span{color:var(--wpwi-text);font-size:.84rem;font-weight:900}.wpwi-row p{margin:0;color:var(--wpwi-soft);font-size:.82rem;line-height:1.45}.wpwi-numberList,.wpwi-bulletList{margin:0;padding-left:20px;color:var(--wpwi-soft);font-size:.86rem;line-height:1.6}.wpwi-numberList li+li,.wpwi-bulletList li+li{margin-top:6px}.wpwi-warning{background:linear-gradient(180deg,#ffffff 0%,var(--wpwi-warning-soft) 100%)}.wpwi-warning .wpwi-sectionHead svg{color:var(--wpwi-warning)}.wpwi-footer{display:flex;align-items:center;gap:8px;margin-top:2px;padding:12px 14px;border:1px solid var(--wpwi-border);border-radius:12px;background:#fff;color:var(--wpwi-muted);font-size:.82rem;line-height:1.45}.wpwi-footer svg{color:var(--wpwi-primary);min-width:18px}@media(max-width:1180px){.wpwi-quickGrid,.wpwi-timeline{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:860px){.wpwi-header{align-items:stretch}.wpwi-headerActions,.wpwi-btn{width:100%}.wpwi-gridTwo{grid-template-columns:1fr;gap:0}.wpwi-row{grid-template-columns:1fr;gap:4px}}@media(max-width:640px){.wpwi-page{padding:max(12px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.wpwi-quickGrid,.wpwi-timeline{grid-template-columns:1fr}.wpwi-section{padding:12px;border-radius:12px}.wpwi-action{grid-template-columns:1fr;gap:4px}}@media(min-width:1800px){.wpwi-page{max-width:1720px;margin:0 auto}.wpwi-timeline{grid-template-columns:repeat(6,minmax(0,1fr))}}.stcadm-page{--bg: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border2: #eef2f7;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary2: #0284c7;--soft: #e0f2fe;--danger: #991b1b;--danger-bg: #fff1f2;--warn: #b45309;--warn-bg: #fffbeb;--green: #166534;--green-bg: #ecfdf5;--shadow: 0 10px 26px rgba(0, 0, 0, .06);--shadow-sm: 0 6px 16px rgba(0, 0, 0, .05);--radius: 16px;--radius-sm: 12px;--fs-xxs: .75rem;--fs-xs: .8125rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--lh-tight: 1.2;--lh-base: 1.45;--h-btn: 38px;--h-btn-sm: 34px;--h-field: 40px;--pad-x: 12px;--pad-y: 10px;height:100%;min-height:0;padding:16px 18px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-md);line-height:var(--lh-base);overflow:auto;-webkit-overflow-scrolling:touch}.stcadm-mono{font-family:var(--pps-font-mono)}.stcadm-muted{color:var(--muted);font-size:var(--fs-sm)}.stcadm-sub{color:var(--muted);font-size:var(--fs-sm);margin-left:8px}.stcadm-card{background:var(--card);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px;margin-bottom:12px}.stcadm-error{border-color:#fecaca;background:var(--danger-bg);color:var(--danger)}.stcadm-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stcadm-headLeft,.stcadm-headRight{display:flex;align-items:center;gap:10px}.stcadm-title{display:flex;align-items:center;gap:10px;font-size:var(--fs-xl);font-weight:600;letter-spacing:.2px}.stcadm-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:var(--h-btn);padding:0 var(--pad-x);border-radius:12px;border:1px solid var(--border);background:var(--primary);color:#fff;cursor:pointer;box-shadow:0 1px #00000008;text-decoration:none;-webkit-user-select:none;user-select:none}.stcadm-btn:disabled{opacity:.6;cursor:not-allowed}.stcadm-btnSoft{background:#fff;color:var(--text)}.stcadm-btnIcon{width:var(--h-btn);padding:0}.stcadm-btnSm{height:var(--h-btn-sm);padding:0 10px;border-radius:10px}.stcadm-btnWarn{background:var(--warn-bg);color:var(--warn);border-color:#fde68a}.stcadm-btnOk{background:var(--green-bg);color:var(--green);border-color:#bbf7d0}.stcadm-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}.stcadm-tab{min-width:160px;text-align:left;border:1px solid var(--border);background:#fff;border-radius:14px;padding:10px 12px;cursor:pointer;box-shadow:0 1px #00000008}.stcadm-tab.isActive{border-color:#7dd3fc;background:var(--soft)}.stcadm-tabLabel{font-weight:600}.stcadm-tabHint{font-size:var(--fs-xs);color:var(--muted);margin-top:2px}.stcadm-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.stcadm-search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:0 12px;height:var(--h-field);min-width:280px;flex:1}.stcadm-searchIcon{color:var(--muted)}.stcadm-input{width:100%;height:var(--h-field);border:1px solid var(--border);border-radius:14px;padding:0 12px;outline:none;font:inherit;background:#fff;box-shadow:0 1px #00000005}.stcadm-search .stcadm-input{height:100%;border:none;border-radius:0;padding:0;background:transparent;box-shadow:none}.stcadm-search:focus-within{border-color:#7dd3fc;box-shadow:0 0 0 3px #7dd3fc59}.stcadm-input:focus{border-color:#7dd3fc;box-shadow:0 0 0 3px #7dd3fc59}.stcadm-check{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:var(--fs-sm)}.stcadm-checkRow{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}.stcadm-cardHead{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:10px}.stcadm-cardTitle{font-weight:700;font-size:var(--fs-lg)}.stcadm-tableWrap{width:100%;overflow:auto;border:1px solid var(--border2);border-radius:14px}.stcadm-table{width:100%;border-collapse:separate;border-spacing:0;min-width:720px}.stcadm-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;text-align:left;padding:10px 12px;font-size:var(--fs-xs);color:var(--muted);border-bottom:1px solid var(--border2)}.stcadm-table tbody td{padding:10px 12px;border-bottom:1px solid var(--border2);vertical-align:top}.stcadm-table tbody tr:hover td{background:#fafafa}.stcadm-table tbody tr.isInactive td{opacity:.65}.stcadm-name{font-weight:600}.stcadm-actions{display:flex;gap:8px;justify-content:flex-end}.stcadm-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:var(--fs-xs);border:1px solid var(--border2);background:#fff}.stcadm-pill.ok{border-color:#bbf7d0;background:var(--green-bg);color:var(--green)}.stcadm-pill.off{border-color:#fecaca;background:var(--danger-bg);color:var(--danger)}.stcadm-empty{text-align:center;color:var(--muted);padding:18px}.stcadm-note{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border);color:var(--muted);font-size:var(--fs-sm)}.stcadm-deny{text-align:center;padding:18px}.stcadm-denyTitle{display:flex;align-items:center;justify-content:center;gap:10px;font-weight:700;font-size:var(--fs-lg);margin-bottom:6px;color:var(--danger)}.stcadm-denyActions{display:flex;gap:10px;justify-content:center;margin-top:12px}.stcadm-modalBackdrop{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;padding:14px;z-index:9999}.stcadm-modal{width:min(720px,100%);background:#fff;border-radius:18px;box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden}.stcadm-modalHead{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#f8fafc;border-bottom:1px solid var(--border2)}.stcadm-modalTitle{font-weight:700}.stcadm-modalBody{padding:14px}.stcadm-modalFoot{display:flex;justify-content:flex-end;gap:10px;padding:12px 14px;border-top:1px solid var(--border2);background:#fff}.stcadm-field{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.stcadm-label{font-size:var(--fs-xs);color:var(--muted);font-weight:600}.stcadm-textarea{width:100%;border:1px solid var(--border);border-radius:14px;padding:10px 12px;font:inherit;outline:none;resize:vertical}.stcadm-grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:720px){.stcadm-grid2{grid-template-columns:1fr}.stcadm-table{min-width:680px}}.stcadm-sigTable{min-width:920px}.stcadm-sigBox{display:flex;flex-direction:column;gap:8px}.stcadm-sigThumb{width:280px;height:92px;border:1px dashed var(--border);border-radius:14px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}.stcadm-sigThumb img{width:100%;height:100%;object-fit:contain;background:#fff}.stcadm-sigPlaceholder{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:var(--fs-sm)}.stcadm-file{display:none}.wpadm-page{--primary: #0b6aa2;--primary2: #075985;--soft: #e0f2fe}.wpadm-filterSelect{max-width:320px;flex:0 1 320px}.wpadm-table{min-width:920px}.wpadm-modal{max-height:calc(100dvh - 28px);display:flex;flex-direction:column}.wpadm-modal .stcadm-modalBody{overflow:auto;-webkit-overflow-scrolling:touch}.wpadm-modal .stcadm-modalFoot{position:sticky;bottom:0;z-index:1}@media(max-width:720px){.wpadm-filterSelect{max-width:none;flex-basis:100%}.wpadm-modal{width:100%;max-height:calc(100dvh - 18px)}}.wpsg-page{--bg: #f4f7fb;--card: #ffffff;--border: #dbe4ee;--text: #0f172a;--muted: #64748b;--primary: #0b6aa2;--ok: #047857;--ok-bg: #ecfdf5;--warn: #a16207;--warn-bg: #fffbeb;--bad: #be123c;--bad-bg: #fff1f2;min-height:100%;padding:16px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);overflow:auto}.wpsg-page,.wpsg-page *{box-sizing:border-box}.wpsg-header{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:14px}.wpsg-kicker{margin:0 0 4px;color:var(--primary);font-size:.75rem;font-weight:900}.wpsg-header h1{margin:0;font-size:clamp(1.2rem,1rem + .8vw,1.7rem);line-height:1.2}.wpsg-sub{max-width:860px;margin:6px 0 0;color:var(--muted);font-size:.9rem;line-height:1.55}.wpsg-actions,.wpsg-rowActions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.wpsg-btn{min-height:38px;padding:0 12px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:.82rem;font-weight:900;text-decoration:none;cursor:pointer}.wpsg-btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.wpsg-btn.small{min-height:34px;padding:0 10px}.wpsg-btn:disabled{opacity:.52;cursor:not-allowed}.wpsg-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.wpsg-search{flex:1;min-width:260px;min-height:42px;padding:0 12px;border:1px solid var(--border);border-radius:12px;background:#fff;display:flex;align-items:center;gap:8px}.wpsg-search input,.wpsg-date{min-height:40px;border:1px solid var(--border);border-radius:12px;background:#fff;padding:0 12px;font:inherit}.wpsg-search input{min-width:0;width:100%;border:0;padding:0;outline:0}.wpsg-card{border:1px solid var(--border);border-radius:14px;background:var(--card);box-shadow:0 8px 24px #0f172a0f;padding:14px}.wpsg-cardHead{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}.wpsg-cardHead span{color:var(--muted);font-size:.82rem}.wpsg-tableWrap{overflow:auto;border:1px solid #edf2f7;border-radius:12px}.wpsg-table{width:100%;min-width:980px;border-collapse:collapse}.wpsg-table th,.wpsg-table td{padding:10px 12px;border-bottom:1px solid #edf2f7;text-align:left;vertical-align:top;font-size:.86rem}.wpsg-table th{background:#f8fafc;color:var(--muted);font-size:.75rem}.wpsg-table strong,.wpsg-table small,.wpsg-table span{display:block}.wpsg-table small{margin-top:3px;color:var(--muted);font-size:.76rem}.wpsg-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:.75rem;font-weight:900;white-space:nowrap}.wpsg-pill.ok{background:var(--ok-bg);color:var(--ok)}.wpsg-pill.warn{background:var(--warn-bg);color:var(--warn)}.wpsg-pill.bad{background:var(--bad-bg);color:var(--bad)}.wpsg-empty{text-align:center;color:var(--muted);padding:24px}.wpsg-printBadge{display:none}.wpsg-pass{width:320px;border:2px solid #111827;border-radius:12px;padding:18px;text-align:center;font-family:Arial,sans-serif}.wpsg-pass h2{margin:0 0 10px;font-size:1.1rem}.wpsg-passNo{margin:10px 0;padding:8px;background:#111827;color:#fff;font-weight:900}@media(max-width:720px){.wpsg-page{padding:12px 10px}.wpsg-actions,.wpsg-btn,.wpsg-date{width:100%}}@media print{body *{visibility:hidden!important}.wpsg-printBadge,.wpsg-printBadge *{visibility:visible!important}.wpsg-printBadge{display:block;position:fixed;inset:0;padding:20px;background:#fff}}.wpch-page{min-height:100%;padding:24px;background:linear-gradient(180deg,#f8fbff,#eef4fb);color:#0f172a;font-family:var(--pps-font-main)}.wpch-page *{box-sizing:border-box}.wpch-header,.wpch-cardHead{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}.wpch-header{margin-bottom:18px}.wpch-kicker{margin:0 0 4px;color:#075985;font-weight:900;letter-spacing:.04em;text-transform:uppercase;font-size:.78rem}.wpch-header h1{margin:0;font-size:clamp(1.35rem,1.1rem + 1vw,2rem);line-height:1.12}.wpch-sub{margin:8px 0 0;color:#64748b;font-size:.95rem}.wpch-actions,.wpch-filterActions,.wpch-rowActions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.wpch-btn,.wpch-iconBtn{min-height:40px;border:1px solid #d8e2ee;border-radius:14px;background:#fff;color:#0f172a;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;font-weight:900;font-size:.88rem;text-decoration:none;cursor:pointer;box-shadow:0 1px 2px #0f172a0d}.wpch-btn:hover:not(:disabled),.wpch-iconBtn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px #0f172a14}.wpch-btn:disabled,.wpch-iconBtn:disabled{opacity:.55;cursor:not-allowed}.wpch-btn-primary,.wpch-iconPrimary{background:linear-gradient(180deg,#0b6aa2,#075985);color:#fff;border-color:transparent}.wpch-iconBtn{width:40px;min-width:40px;padding:0}.wpch-filterCard,.wpch-tableCard,.wpch-kpi{border:1px solid #d8e2ee;border-radius:22px;background:#ffffffeb;box-shadow:0 12px 30px #0f172a12}.wpch-filterCard,.wpch-tableCard{padding:16px;margin-bottom:16px}.wpch-cardTitle{display:inline-flex;align-items:center;gap:8px;font-weight:900;color:#0f172a}.wpch-filterGrid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;align-items:end;margin-top:14px}.wpch-field{display:flex;flex-direction:column;gap:6px;min-width:0}.wpch-field span{color:#64748b;font-size:.78rem;font-weight:900}.wpch-field input,.wpch-field select{width:100%;min-height:42px;border:1px solid #cdd9e8;border-radius:14px;padding:10px 12px;background:#fff;color:#0f172a;font-family:inherit;font-size:.92rem;outline:none}.wpch-field input:focus,.wpch-field select:focus{border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf826}.wpch-help{display:inline-flex;align-items:center;gap:8px;margin-top:12px;color:#64748b;font-size:.85rem}.wpch-kpiGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.wpch-kpi{padding:14px}.wpch-kpi span,.wpch-kpi small{color:#64748b;font-size:.82rem}.wpch-kpi b{display:block;margin:4px 0;font-size:1.55rem;line-height:1;color:#075985}.wpch-tableWrap{width:100%;overflow:auto;margin-top:12px}.wpch-table{width:100%;min-width:980px;border-collapse:separate;border-spacing:0;font-size:.88rem}.wpch-table th,.wpch-table td{padding:12px 10px;border-bottom:1px solid #e2e8f0;vertical-align:top;text-align:left}.wpch-table th{position:sticky;top:0;z-index:1;background:#f8fafc;color:#475569;font-size:.78rem;font-weight:900}.wpch-table td b,.wpch-table td span,.wpch-table td small{display:block}.wpch-table td small{margin-top:3px;color:#64748b;line-height:1.35}.wpch-pill{display:inline-flex!important;width:max-content;border-radius:999px;padding:5px 10px;border:1px solid #d8e2ee;font-weight:900;font-size:.78rem;background:#f8fafc;color:#334155}.wpch-pill.is-green{background:#ecfdf5;color:#047857;border-color:#a7f3d0}.wpch-pill.is-red{background:#fff1f2;color:#be123c;border-color:#fecdd3}.wpch-empty{text-align:center!important;padding:28px!important;color:#64748b}@media(max-width:1100px){.wpch-filterGrid,.wpch-kpiGrid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.wpch-page{padding:16px 12px}.wpch-filterGrid,.wpch-kpiGrid{grid-template-columns:1fr}.wpch-actions .wpch-btn{flex:1 1 100%}}.wptn-page{--wptn-bg: #f4f7fb;--wptn-surface: #ffffff;--wptn-border: #d9e4ef;--wptn-border-strong: #c7d6e5;--wptn-text: #0f172a;--wptn-muted: #64748b;--wptn-primary: #0b6aa2;--wptn-primary-strong: #075985;--wptn-primary-soft: #e0f2fe;--wptn-danger: #be123c;--wptn-danger-soft: #fff1f2;--wptn-success: #047857;--wptn-success-soft: #ecfdf5;min-height:100%;padding:22px;background:linear-gradient(180deg,#f8fbff 0%,var(--wptn-bg) 100%);color:var(--wptn-text);font-family:var(--pps-font-main);box-sizing:border-box}.wptn-page *,.wptn-page *:before,.wptn-page *:after{box-sizing:border-box}.wptn-header,.wptn-cardHead{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:16px}.wptn-title{font-size:clamp(1.35rem,1.1rem + 1vw,2rem);line-height:1.15;font-weight:900;letter-spacing:-.02em}.wptn-sub,.wptn-testMeta{color:var(--wptn-muted);margin-top:6px;font-size:.95rem}.wptn-layout{display:grid;grid-template-columns:minmax(240px,300px) minmax(0,1fr);gap:16px;align-items:start}.wptn-main{display:grid;gap:16px;min-width:0}.wptn-card{background:linear-gradient(180deg,var(--wptn-surface) 0%,#fbfdff 100%);border:1px solid var(--wptn-border);border-radius:22px;padding:18px;box-shadow:0 10px 28px #0f172a12}.wptn-cardTitle{display:inline-flex;align-items:center;gap:8px;font-size:1.05rem;font-weight:900;margin-bottom:12px}.wptn-topicList{position:sticky;top:16px}.wptn-list,.wptn-questionList,.wptn-testQuestions{display:grid;gap:10px}.wptn-topicItem,.wptn-questionRow,.wptn-testQuestion{border:1px solid var(--wptn-border);border-radius:16px;background:#fff;padding:12px}.wptn-topicItem{width:100%;text-align:left;cursor:pointer;display:grid;gap:4px}.wptn-topicItem b{color:var(--wptn-text)}.wptn-topicItem span,.wptn-questionBody span{color:var(--wptn-muted);font-size:.86rem}.wptn-topicItem.is-active{background:var(--wptn-primary-soft);border-color:#7dd3fc}.wptn-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:10px}.wptn-btn,.wptn-iconBtn{min-height:42px;border:1px solid var(--wptn-border);border-radius:14px;background:linear-gradient(180deg,#fff,#f8fafc);color:var(--wptn-text);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;font-weight:800;cursor:pointer;text-decoration:none}.wptn-btn:hover:not(:disabled),.wptn-iconBtn:hover:not(:disabled){border-color:var(--wptn-border-strong);transform:translateY(-1px)}.wptn-btn:disabled{opacity:.55;cursor:not-allowed}.wptn-btn-primary{background:linear-gradient(180deg,var(--wptn-primary) 0%,var(--wptn-primary-strong) 100%);color:#fff;border-color:transparent}.wptn-iconBtn{width:42px;padding:0}.wptn-danger{color:var(--wptn-danger);background:var(--wptn-danger-soft);border-color:#fecdd3}.wptn-grid{display:grid;gap:14px;grid-template-columns:1fr}.wptn-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.wptn-field{display:grid;gap:6px;min-width:0}.wptn-field-full{grid-column:1 / -1}.wptn-field span{color:var(--wptn-muted);font-size:.82rem;font-weight:900}.wptn-field input,.wptn-field select,.wptn-field textarea{width:100%;min-height:44px;padding:11px 13px;border:1px solid var(--wptn-border);border-radius:14px;background:#fff;font:inherit;outline:none}.wptn-field textarea{min-height:94px;resize:vertical}.wptn-field input:focus,.wptn-field select:focus,.wptn-field textarea:focus{border-color:#0b6aa273;box-shadow:0 0 0 3px #0b6aa21f}.wptn-check{display:inline-flex;align-items:center;gap:8px;font-weight:800}.wptn-qrPanel{display:grid;grid-template-columns:132px minmax(0,1fr);gap:16px;align-items:center;padding:14px;border-radius:18px;border:1px solid var(--wptn-border);background:#fff}.wptn-qrPanel img{width:132px;height:132px;border:1px solid var(--wptn-border);border-radius:14px;padding:8px;background:#fff}.wptn-qrPanel code{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--wptn-primary-strong)}.wptn-questionRow{display:grid;grid-template-columns:34px minmax(0,1fr) auto;gap:12px;align-items:start}.wptn-questionNo,.wptn-questionPrompt span{width:30px;height:30px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:var(--wptn-primary-soft);color:var(--wptn-primary-strong);font-weight:900}.wptn-questionBody{display:grid;gap:5px;min-width:0}.wptn-tableWrap{overflow:auto}.wptn-table{width:100%;border-collapse:collapse;min-width:680px}.wptn-table th,.wptn-table td{padding:10px 12px;border-bottom:1px solid var(--wptn-border);text-align:left}.wptn-table th{color:var(--wptn-muted);font-size:.78rem;text-transform:uppercase}.wptn-pill{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-weight:900;font-size:.78rem}.wptn-pill.is-pass,.wptn-scoreBox.is-pass{color:var(--wptn-success);background:var(--wptn-success-soft)}.wptn-pill.is-fail,.wptn-scoreBox.is-fail{color:var(--wptn-danger);background:var(--wptn-danger-soft)}.wptn-empty{padding:14px;border:1px dashed var(--wptn-border-strong);border-radius:14px;color:var(--wptn-muted);background:#fff}.wptn-testShell{width:min(980px,100%);margin:0 auto;display:grid;gap:16px}.wptn-testHero{display:flex;justify-content:space-between;align-items:center;gap:16px}.wptn-scoreBox{min-width:132px;min-height:104px;border-radius:18px;display:grid;place-items:center;padding:12px;font-weight:900}.wptn-scoreBox b{font-size:1.8rem}.wptn-questionPrompt{display:flex;gap:10px;align-items:flex-start;margin-bottom:12px}.wptn-answer{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border:1px solid var(--wptn-border);border-radius:14px;margin:8px 0;cursor:pointer}.wptn-answer:has(input:checked){background:var(--wptn-primary-soft);border-color:#7dd3fc}.wptn-submitBar{justify-content:flex-end;margin-top:14px}.print-only{display:none}.wptn-printSheet{background:#fff;color:#000}@media(max-width:900px){.wptn-layout{grid-template-columns:1fr}.wptn-topicList{position:static}.wptn-grid-2{grid-template-columns:1fr}.wptn-testHero{align-items:stretch;flex-direction:column}}@media(max-width:560px){.wptn-page{padding:14px}.wptn-qrPanel,.wptn-questionRow{grid-template-columns:1fr}.wptn-actions{width:100%}.wptn-btn{flex:1 1 100%}}@page{size:A4;margin:12mm}@media print{body{background:#fff!important}.no-print,.wptn-header,.wptn-topicList{display:none!important}.print-only{display:block!important}.wptn-page{padding:0!important;background:#fff!important}.wptn-layout,.wptn-main{display:block!important}.wptn-card{box-shadow:none!important;border:0!important;padding:0!important}.wptn-printSheet{width:186mm;min-height:273mm;padding:0;page-break-after:always}.wptn-printHead{display:grid;grid-template-columns:minmax(0,1fr) 34mm;gap:8mm;align-items:start;border-bottom:1px solid #000;padding-bottom:5mm;margin-bottom:5mm}.wptn-printHead h1{font-size:18pt;margin:0 0 3mm}.wptn-printHead h2{font-size:14pt;margin:0 0 3mm}.wptn-printHead p{font-size:10pt;margin:1.5mm 0}.wptn-printQr{text-align:center;font-size:8pt}.wptn-printQr img{width:32mm;height:32mm;border:1px solid #222;padding:1mm}.wptn-printInfo{display:grid;grid-template-columns:1fr 1fr;gap:4mm 8mm;font-size:10pt;margin-bottom:5mm}.wptn-printQuestions{font-size:10.5pt;padding-left:6mm}.wptn-printQuestions li{break-inside:avoid;margin-bottom:4mm}.wptn-printQuestions div{margin-top:1.5mm}}.wptn-workerSearch{position:relative;display:grid;gap:12px;margin-bottom:14px}.wptn-searchInputWrap{width:100%;min-height:48px;display:flex;align-items:center;gap:10px;padding:0 12px;border:1px solid var(--wptn-border);border-radius:16px;background:#fff}.wptn-searchInputWrap:focus-within{border-color:#0b6aa273;box-shadow:0 0 0 3px #0b6aa21f}.wptn-searchInputWrap svg{color:var(--wptn-muted);flex:0 0 auto}.wptn-searchInputWrap input{min-width:0;flex:1;border:0;outline:0;font:inherit;background:transparent}.wptn-searchInputWrap button{border:0;border-radius:999px;padding:6px 10px;color:var(--wptn-primary-strong);background:var(--wptn-primary-soft);font-weight:900;cursor:pointer}.wptn-workerResults{max-height:220px;overflow:auto;display:grid;gap:8px;padding:8px;border:1px solid var(--wptn-border);border-radius:18px;background:#fff;box-shadow:0 14px 30px #0f172a14;height:fit-content}.wptn-workerOption{width:100%;display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,.8fr);gap:12px;text-align:left;padding:10px 12px;border:1px solid var(--wptn-border);border-radius:16px;background:#fff;cursor:pointer}.wptn-workerOption:hover,.wptn-workerOption.is-selected{border-color:#7dd3fc;background:var(--wptn-primary-soft)}.wptn-workerOption span{display:grid;gap:3px;min-width:0}.wptn-workerOption b,.wptn-workerOption small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wptn-workerOption small{color:var(--wptn-muted);font-size:.82rem}.wptn-profileGrid{margin-top:10px}.wptn-profileGrid input[readonly]{color:var(--wptn-text);background:#f8fafc}.wptn-workerSelected{margin-top:12px;display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:8px 12px;font-weight:900}.wptn-workerSelected.is-ok{color:var(--wptn-success);background:var(--wptn-success-soft)}.wptn-workerSelected.is-warn{color:var(--wptn-danger);background:var(--wptn-danger-soft)}@media(max-width:560px){.wptn-workerOption{grid-template-columns:1fr}}.wptn-resultsPage .wptn-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.wptn-kpiGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:16px 0}.wptn-kpi{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;box-shadow:0 10px 30px #0f172a0f}.wptn-kpi span{display:block;color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.wptn-kpi b{display:block;margin-top:6px;color:#0f172a;font-size:28px;line-height:1.1}.wptn-kpi small{display:block;margin-top:6px;color:#64748b}.wptn-resultsLayout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(360px,.9fr);gap:16px;align-items:start}.wptn-detailGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:12px 0 16px}.wptn-detailGrid>div{border:1px solid #e5e7eb;border-radius:12px;background:#f8fafc;padding:10px 12px}.wptn-detailGrid span{display:block;color:#64748b;font-size:12px;margin-bottom:4px}.wptn-helpText{margin:6px 0 0;color:#64748b;line-height:1.55}.wptn-questionRow.is-correct{border-left:4px solid #059669}.wptn-questionRow.is-wrong{border-left:4px solid #dc2626}@media(max-width:1100px){.wptn-resultsLayout,.wptn-resultsPage .wptn-grid-4,.wptn-kpiGrid,.wptn-detailGrid{grid-template-columns:1fr 1fr}}@media(max-width:720px){.wptn-resultsLayout,.wptn-resultsPage .wptn-grid-4,.wptn-kpiGrid,.wptn-detailGrid{grid-template-columns:1fr}}:root{--bg: #eef1f6;--surface: #ffffff;--surface-soft: #f8fafc;--border: #d9e0e7;--shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 4px 16px rgba(15, 23, 42, .06);--ink-1: #353d39;--ink-2: #4b5652;--ink-3: #6f7673;--ink-4: #8f9494;--ink-5: #c5c8ca;--sf-blue: #315f9e;--sf-blue-soft: #4e8fa8;--sf-blue-pale: #e9f0f8;--sf-blue-border: #c8d7ea;--sf-green: #588467;--sf-green-soft: #eef5f0;--sf-green-border: #b8d3bf;--sf-orange: #c28a2e;--sf-orange-soft: #f4ead8;--sf-orange-border: #e1c998;--sf-red: #b56565;--sf-red-soft: #f5e8e8;--sf-red-border: #dfb7b7;--r: 14px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{font-family:var(--pps-font-main);background:var(--bg);color:var(--ink-1);-webkit-font-smoothing:antialiased}.sfm-page{width:100%;height:100vh;padding:10px;display:grid;grid-template-rows:72px 1fr;gap:10px}.sfm-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);display:flex;align-items:center;justify-content:space-between;padding:0 24px 0 20px;box-shadow:var(--shadow);position:relative;overflow:hidden}.sfm-header:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:3px;background:linear-gradient(180deg,var(--sf-blue) 0%,#8faace 100%);border-radius:0 3px 3px 0}.sfm-header-left{display:flex;align-items:center;gap:16px;position:relative}.sfm-menu-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--surface-soft);color:var(--ink-3);font-size:var(--fs-18);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,border-color .15s}.sfm-menu-btn:hover{background:#e9eef3;border-color:#cbd5df}.sfm-logo-badge{width:40px;height:40px;border-radius:10px;background:#ef4444;display:flex;align-items:center;justify-content:center;font-size:var(--fs-13);font-weight:800;color:#fff;font-style:italic;letter-spacing:-.5px;flex:0 0 auto;box-shadow:0 2px 8px #ef444447}.sfm-brand-divider{width:1px;height:32px;background:var(--border)}.sfm-brand-title{font-size:var(--fs-15);font-weight:700;color:var(--ink-1);letter-spacing:-.02em;white-space:nowrap}.sfm-brand-sub{display:flex;align-items:center;gap:8px;margin-top:3px;font-size:var(--fs-11);color:var(--ink-3);font-weight:400;white-space:nowrap}.sfm-site-pill{padding:2px 20px 2px 9px;background:var(--sf-blue-pale);border:1px solid var(--sf-blue-border);border-radius:999px;font-size:var(--fs-11);font-weight:600;color:var(--sf-blue);position:relative}.sfm-site-pill:after{content:"▾";position:absolute;right:7px;top:50%;transform:translateY(-50%);font-size:var(--fs-9);color:#7f9ec8}.sfm-header-status{display:flex;align-items:center;gap:6px;padding:5px 14px;background:var(--sf-green-soft);border:1px solid var(--sf-green-border);border-radius:999px}.sfm-status-dot{width:7px;height:7px;border-radius:50%;background:var(--sf-green);box-shadow:0 0 6px #5884678c}.sfm-status-text{font-size:var(--fs-11);font-weight:700;color:var(--sf-green);letter-spacing:.06em}.sfm-header-right{text-align:right}.sfm-header-date{font-size:var(--fs-14);font-weight:700;color:var(--ink-1);letter-spacing:-.01em}.sfm-header-update{font-size:var(--fs-11);font-weight:400;color:var(--ink-4);margin-top:3px}.sfm-content{display:grid;grid-template-rows:43% 57%;gap:10px;min-height:0}.sfm-top-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;min-height:0}.sfm-bottom-cards{display:grid;grid-template-columns:1fr 2fr;gap:10px;min-height:0}.sfm-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;min-height:0;box-shadow:var(--shadow)}.pec-card{--pec-color-main: var(--ink-1);--pec-color-sub: var(--ink-4);--pec-color-border: var(--ink-5);--pec-color-avail: var(--sf-green);--pec-color-perf: var(--sf-blue);--pec-color-qual: var(--ink-4);--pec-color-up-bg: var(--sf-green-soft);--pec-color-up-border: var(--sf-green-border);--pec-color-up-text: var(--sf-green);--pec-color-down: var(--sf-red);width:100%;height:100%;display:flex;flex-direction:column;padding:22px 18px 16px 22px;position:relative;overflow:hidden}.pec-top-rule{position:absolute;top:0;left:22px;right:22px;height:2px;background:linear-gradient(90deg,var(--sf-blue) 0%,#8faace 55%,transparent 100%);border-radius:0 0 2px 2px}.pec-header{flex:0 0 auto;margin-bottom:6px}.pec-title{font-size:var(--fs-15);font-weight:700;color:var(--pec-color-main);letter-spacing:-.02em}.pec-title-tag{font-size:var(--fs-11);font-weight:500;color:var(--pec-color-sub);margin-left:6px}.pec-subtitle{font-size:var(--fs-11);font-weight:400;color:var(--pec-color-sub);margin-top:3px}.pec-body{flex:1 1 0;min-height:0;display:grid;grid-template-columns:.5fr 1fr;gap:14px;align-items:center;margin-top:10px}.pec-kpis{display:flex;flex-direction:column;gap:0}.pec-kpi{padding:9px 0;border-bottom:1px solid var(--pec-color-border)}.pec-kpi:last-child{border-bottom:none}.pec-kpi-label{font-size:var(--fs-10);font-weight:700;letter-spacing:.07em;text-transform:uppercase;margin-bottom:3px}.pec-kpi-value{font-size:var(--fs-26);font-weight:800;letter-spacing:-.04em;line-height:1}.pec-kpi-delta{font-size:var(--fs-11);font-weight:600;margin-top:3px}.pec-kpi--avail .pec-kpi-label,.pec-kpi--avail .pec-kpi-value{color:var(--pec-color-avail)}.pec-kpi--perf .pec-kpi-label,.pec-kpi--perf .pec-kpi-value{color:var(--pec-color-perf)}.pec-kpi--qual .pec-kpi-label,.pec-kpi--qual .pec-kpi-value{color:var(--pec-color-qual)}.delta-up{color:var(--pec-color-avail)}.delta-flat{color:var(--pec-color-sub)}.delta-down{color:var(--pec-color-down)}.pec-chart-wrap{display:flex;align-items:center;justify-content:center;min-height:0}.pec-chart{position:relative;width:min(100%,200px);aspect-ratio:1}.pec-chart svg{width:100%;height:100%;display:block}.pec-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;pointer-events:none;white-space:nowrap}.pec-center-oee{font-size:var(--fs-10);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--pec-color-sub)}.pec-center-val{font-size:var(--fs-42);font-weight:800;color:var(--pec-color-main);letter-spacing:-.05em;line-height:1;margin-top:1px}.pec-center-delta{margin-top:6px;font-size:var(--fs-11);font-weight:700;padding:3px 10px;border-radius:999px;background:var(--pec-color-up-bg);border:1px solid var(--pec-color-up-border);color:var(--pec-color-up-text)}.pec-legend{margin-top:10px;display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.pec-leg-item{display:flex;align-items:center;gap:6px;font-size:var(--fs-12);font-weight:600}.pec-chart-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;gap:10px}.pec-chart{position:relative;width:min(100%,200px);aspect-ratio:1;flex:0 0 auto}.pec-legend{display:flex;justify-content:center;align-items:center;gap:18px;flex-wrap:wrap;width:100%}.pec-leg-item{display:flex;align-items:center;gap:6px;font-size:var(--fs-12);font-weight:600;line-height:1.2}.pec-leg-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}.pec-leg-avail{color:var(--pec-color-avail)}.pec-leg-perf{color:var(--pec-color-perf)}.pec-leg-qual{color:var(--pec-color-qual)}.emc-card{--emc-color-main: var(--ink-1);--emc-color-sub: var(--ink-4);--emc-color-border: var(--ink-5);--emc-color-track: #e3e7e9;--emc-color-grid: var(--sf-orange);--emc-color-grid-soft: #d8b06a;--emc-color-solar: var(--sf-blue-soft);--emc-color-solar-soft: #9fc0cd;--emc-color-target: #14b8d4;--emc-color-target-soft: #d9eef4;width:100%;height:100%;display:flex;flex-direction:column;padding:22px 18px 16px 22px;position:relative;overflow:hidden}.emc-top-rule{position:absolute;top:0;left:22px;right:22px;height:2px;background:linear-gradient(90deg,var(--emc-color-grid) 0%,var(--emc-color-grid-soft) 55%,transparent 100%);border-radius:0 0 2px 2px}.emc-header{flex:0 0 auto;margin-bottom:6px}.emc-title{font-size:var(--fs-15);font-weight:700;color:var(--emc-color-main);letter-spacing:-.02em}.emc-subtitle{font-size:var(--fs-11);font-weight:400;color:var(--emc-color-sub);margin-top:3px}.emc-body{flex:1 1 0;min-height:0;display:grid;gap:18px;align-items:center;margin-top:10px}.emc-body--donut-only{grid-template-columns:.7fr 1fr}.emc-stats{display:flex;flex-direction:column;gap:0}.emc-stat{padding:9px 0;border-bottom:1px solid var(--emc-color-border)}.emc-stat:last-child{border-bottom:none}.emc-stat-label{font-size:var(--fs-10);font-weight:700;letter-spacing:.07em;text-transform:uppercase;margin-bottom:3px}.emc-stat-row{display:flex;align-items:baseline;gap:6px}.emc-stat-val{font-size:var(--fs-26);font-weight:800;letter-spacing:-.04em;line-height:1}.emc-stat-unit{font-size:var(--fs-11);font-weight:700}.emc-grid{color:var(--emc-color-grid)}.emc-solar{color:var(--emc-color-solar)}.emc-total{color:var(--emc-color-main)}.emc-total .emc-stat-label{color:var(--emc-color-sub)}.emc-chart-side{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;height:100%}.emc-donut-wrap{position:relative;width:min(100%,230px);aspect-ratio:1;flex:0 0 auto}.emc-donut-wrap--double{width:min(100%,240px)}.emc-donut-wrap svg{width:100%;height:100%;display:block}.emc-donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;white-space:nowrap}.emc-dc-label{font-size:var(--fs-10);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--emc-color-sub)}.emc-dc-val{font-size:var(--fs-42);font-weight:800;color:var(--emc-color-main);letter-spacing:-.04em;line-height:1;margin-top:1px}.emc-dc-unit{font-size:var(--fs-11);font-weight:600;color:var(--emc-color-sub)}.emc-legend{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}.emc-legend--stack{width:100%;justify-content:center;gap:14px 22px}.emc-legend-group{display:flex;flex-direction:column;gap:8px;min-width:165px}.emc-legend-title{font-size:var(--fs-10);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--emc-color-sub)}.emc-leg-item{display:flex;align-items:center;gap:6px;font-size:var(--fs-12);font-weight:600}.emc-leg-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}.emc-leg-dot-ring{width:10px;height:10px;border:2px solid;border-radius:50%}.emc-leg-grid{color:var(--emc-color-grid)}.emc-leg-solar{color:var(--emc-color-solar)}.emc-leg-target{color:var(--emc-color-target)}.emc-stat-delta{display:flex;align-items:center;gap:4px;margin-top:4px;font-size:var(--fs-11);font-weight:600;line-height:1}.emc-stat-delta-symbol{font-size:var(--fs-12);line-height:1}.emc-stat-delta.delta-up{color:var(--sf-green)}.emc-stat-delta.delta-down{color:var(--sf-red)}.emc-stat-delta.delta-flat{color:var(--emc-color-sub)}.mmc-card{--mmc-color-main: var(--ink-1);--mmc-color-sub: var(--ink-4);--mmc-color-border: var(--ink-5);--mmc-color-grid: var(--border);--mmc-color-total: #e3e7e9;--mmc-color-available: var(--sf-green);--mmc-color-shutdown: var(--sf-orange);--mmc-color-breakdown: var(--sf-red);--mmc-top-start: var(--sf-green);--mmc-top-mid: #9bb7a3;width:100%;height:100%;display:flex;flex-direction:column;padding:22px 18px 16px 22px;position:relative;overflow:hidden}.mmc-top-rule{position:absolute;top:0;left:22px;right:22px;height:2px;background:linear-gradient(90deg,var(--mmc-top-start) 0%,var(--mmc-top-mid) 55%,transparent 100%);border-radius:0 0 2px 2px}.mmc-header{flex:0 0 auto;margin-bottom:6px}.mmc-title{font-size:var(--fs-15);font-weight:700;color:var(--mmc-color-main);letter-spacing:-.02em}.mmc-subtitle{font-size:var(--fs-11);font-weight:400;color:var(--mmc-color-sub);margin-top:3px}.mmc-body{flex:1 1 0;min-height:0;display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:center;margin-top:10px}.mmc-chart-left{height:100%;display:flex;align-items:center}.mmc-bar-area{display:grid;grid-template-columns:30px 1fr 96px;gap:10px;align-items:center;width:100%}.mmc-yaxis{height:150px;position:relative;font-size:var(--fs-10);font-weight:600;color:var(--mmc-color-sub)}.mmc-yaxis span{position:absolute;right:0}.mmc-yaxis span:nth-child(1){top:-2px;transform:translateY(-50%)}.mmc-yaxis span:nth-child(2){top:47px;transform:translateY(-50%)}.mmc-yaxis span:nth-child(3){top:103px;transform:translateY(-50%)}.mmc-yaxis span:nth-child(4){bottom:-2px;transform:translateY(50%)}.mmc-plot{position:relative;height:178px}.mmc-gridline{position:absolute;left:0;right:0;border-top:1px dashed var(--mmc-color-grid)}.mmc-gl-1{top:14px}.mmc-gl-2{top:76px}.mmc-gl-3{top:138px}.mmc-gl-base{top:164px;border-top-style:solid;border-top-color:var(--mmc-color-border)}.mmc-plot:before{content:"";position:absolute;left:0;top:14px;bottom:14px;border-left:1px solid var(--mmc-color-border)}.mmc-bar-col{position:absolute;left:26px;bottom:15px;width:68px}.mmc-bar-total{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:var(--fs-11);font-weight:700;color:var(--ink-3);white-space:nowrap}.mmc-stack{width:68px;height:150px;display:flex;flex-direction:column-reverse;border-radius:5px 5px 0 0;overflow:hidden}.mmc-seg{display:flex;align-items:center;justify-content:center}.mmc-seg span{font-size:var(--fs-11);font-weight:700;color:#ffffffeb}.mmc-seg-avail{background:var(--mmc-color-available)}.mmc-seg-shutdown{background:var(--mmc-color-shutdown)}.mmc-seg-breakdown{background:var(--mmc-color-breakdown)}.mmc-xlabel{position:absolute;left:26px;bottom:-2px;width:68px;text-align:center;font-size:var(--fs-10);font-weight:600;color:var(--mmc-color-sub)}.mmc-legend{display:flex;flex-direction:column;gap:8px}.mmc-leg-row{display:flex;align-items:center;gap:7px;font-size:var(--fs-11);font-weight:600;color:var(--mmc-color-sub)}.mmc-leg-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}.mmc-d-total{background:var(--mmc-color-total);border:1px solid var(--mmc-color-border)}.mmc-d-avail{background:var(--mmc-color-available)}.mmc-d-shutdown{background:var(--mmc-color-shutdown)}.mmc-d-breakdown{background:var(--mmc-color-breakdown)}.mmc-chart-right{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.mmc-donut-wrap{position:relative;width:min(100%,200px);aspect-ratio:1;flex:0 0 auto}.mmc-donut-wrap svg{width:100%;height:100%;display:block}.mmc-donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;white-space:nowrap}.mmc-dc-label{font-size:var(--fs-10);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mmc-color-sub)}.mmc-dc-val{font-size:var(--fs-42);font-weight:800;color:var(--mmc-color-main);letter-spacing:-.05em;line-height:1;margin-top:1px}.mmc-chips{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}.mmc-chip{display:flex;align-items:center;gap:6px;font-size:var(--fs-12);font-weight:600}.mmc-chip-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}.mmc-chip-h{color:var(--mmc-color-available)}.mmc-chip-w{color:var(--mmc-color-shutdown)}.mmc-chip-c{color:var(--mmc-color-breakdown)}.psc-card{--psc-color-main: var(--ink-1);--psc-color-sub: var(--ink-4);--psc-color-muted: var(--ink-3);--psc-color-border: var(--ink-5);--psc-color-track: #e3e7e9;--psc-color-fg: var(--sf-blue);--psc-color-fg-soft: #8faace;--psc-color-fg-bg: var(--sf-blue-pale);--psc-color-fg-border: var(--sf-blue-border);--psc-color-semi: var(--sf-blue-soft);--psc-color-semi-soft: #9fc0cd;--psc-color-semi-bg: #e8f1f4;--psc-color-semi-border: #c7dbe4;--psc-color-low: var(--sf-orange);width:100%;height:100%;display:flex;flex-direction:column;padding:22px 18px 16px 22px;position:relative;overflow:hidden}.psc-top-rule{position:absolute;top:0;left:22px;right:22px;height:2px;background:linear-gradient(90deg,var(--psc-color-fg) 0%,var(--psc-color-fg-soft) 55%,transparent 100%);border-radius:0 0 2px 2px}.psc-header{flex:0 0 auto;margin-bottom:6px}.psc-title{font-size:var(--fs-15);font-weight:700;color:var(--psc-color-main);letter-spacing:-.02em}.psc-subtitle{font-size:var(--fs-11);font-weight:400;color:var(--psc-color-sub);margin-top:3px}.psc-body{flex:1 1 0;min-height:0;display:flex;flex-direction:column;justify-content:center;gap:16px;margin-top:10px}.psc-part{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start}.psc-part-type{display:flex;align-items:center;gap:8px;margin-bottom:8px}.psc-type-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:var(--fs-10);font-weight:700;letter-spacing:.06em;text-transform:uppercase}.psc-badge-fg{background:var(--psc-color-fg-bg);color:var(--psc-color-fg);border:1px solid var(--psc-color-fg-border)}.psc-badge-semi{background:var(--psc-color-semi-bg);color:var(--psc-color-semi);border:1px solid var(--psc-color-semi-border)}.psc-part-name{font-size:var(--fs-12);font-weight:600;color:var(--psc-color-muted)}.psc-bar-wrap{position:relative;height:8px;border-radius:999px;background:var(--psc-color-track);overflow:hidden}.psc-bar-fill-fg{background:linear-gradient(90deg,var(--psc-color-fg),var(--psc-color-fg-soft))}.psc-bar-fill-semi{background:linear-gradient(90deg,var(--psc-color-semi),var(--psc-color-semi-soft))}.psc-bar-meta{margin-top:6px;display:flex;justify-content:space-between;font-size:var(--fs-11);font-weight:600;color:var(--psc-color-sub)}.psc-bar-pct-good{color:var(--psc-color-fg)}.psc-bar-pct-low{color:var(--psc-color-low)}.psc-part-right{text-align:right;flex:0 0 auto}.psc-kpi-val{font-size:var(--fs-32);font-weight:800;letter-spacing:-.04em;line-height:1}.psc-kpi-val-fg{color:var(--psc-color-fg)}.psc-kpi-val-semi{color:var(--psc-color-semi)}.psc-kpi-unit{font-size:var(--fs-10);font-weight:700;color:var(--psc-color-sub);letter-spacing:.04em;text-transform:uppercase;margin-top:2px}.psc-kpi-target{font-size:var(--fs-11);font-weight:600;color:var(--psc-color-sub);margin-top:2px}.psc-divider{height:1px;background:var(--psc-color-border)}.psc-footer{display:flex;align-items:center;justify-content:space-between;padding-top:2px}.psc-footer-label{font-size:var(--fs-10);font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--psc-color-sub)}.psc-footer-val{font-size:var(--fs-12);font-weight:700;color:var(--psc-color-muted)}.psc-footer-pct{font-size:var(--fs-11);font-weight:700;padding:3px 10px;border-radius:999px;background:var(--psc-color-fg-bg);border:1px solid var(--psc-color-fg-border);color:var(--psc-color-fg)}.psc-card{position:relative;display:flex;flex-direction:column;width:100%;height:100%;padding:18px 22px;background:linear-gradient(180deg,#fff,#fbfcfd);border:1px solid #d9e1e7;border-radius:20px;box-shadow:0 10px 30px #0f172a0d;overflow:hidden}.psc-top-rule{position:absolute;top:0;left:18px;right:18px;height:3px;border-radius:0 0 999px 999px;background:linear-gradient(90deg,#315f9e 0%,#7fa0cc 55%,transparent 100%)}.psc-header{margin-bottom:14px}.psc-title{font-size:var(--fs-15);font-weight:700;color:#2d3640;letter-spacing:-.02em}.psc-subtitle{margin-top:4px;font-size:var(--fs-11);color:#8b97a3}.psc-body{display:flex;flex-direction:column;gap:14px;min-height:0;flex:1 1 auto}.psc-divider{height:1px;background:linear-gradient(90deg,#cbd5e100,#cbd5e1 15% 85%,#cbd5e100)}.psc-trend-card{padding:12px 14px 10px;border-radius:16px;background:linear-gradient(180deg,#f8fafc,#f3f6f9);border:1px solid #e1e8ef}.psc-trend-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.psc-trend-title{font-size:var(--fs-12);font-weight:700;color:#2d3640;letter-spacing:.02em}.psc-trend-subtitle{margin-top:2px;font-size:var(--fs-10);color:#8b97a3}.psc-trend-legend{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.psc-legend-item{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-10);font-weight:600;color:#6b7785}.psc-legend-dot{width:10px;height:10px;border-radius:50%}.psc-legend-dot-actual{background:#315f9e}.psc-legend-dot-target{background:#8fb2c9}.psc-trend-svg{width:100%;height:148px;display:block}.psc-grid-line{stroke:#d9e2ea;stroke-width:1;stroke-dasharray:4 4}.psc-grid-line-vertical{stroke:#edf2f6;stroke-width:1}.psc-line-actual{fill:none;stroke:#315f9e;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.psc-line-target{fill:none;stroke:#8fb2c9;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:6 6}.psc-point-actual{fill:#315f9e;stroke:#fff;stroke-width:2}.psc-point-target{fill:#8fb2c9;stroke:#fff;stroke-width:2}.psc-trend-xlabels{margin-top:6px;display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.psc-trend-xlabels span{text-align:center;font-size:var(--fs-10);font-weight:600;color:#7a8694}.psc-part{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:center}.psc-part-left{min-width:0}.psc-part-type{display:flex;align-items:center;gap:8px;margin-bottom:10px}.psc-type-badge{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:22px;padding:0 10px;border-radius:999px;font-size:var(--fs-10);font-weight:700;letter-spacing:.05em;text-transform:uppercase}.psc-badge-fg{color:#315f9e;background:#e9f0fb;border:1px solid #c7d7ee}.psc-badge-semi{color:#5f94aa;background:#eaf3f7;border:1px solid #cfe0e7}.psc-part-name{font-size:var(--fs-12);font-weight:600;color:#5f6b77}.psc-bar-wrap{position:relative;height:10px;border-radius:999px;background:#e9eef3;overflow:hidden}.psc-bar-fill{height:100%;border-radius:999px}.psc-bar-fill-fg{background:linear-gradient(90deg,#315f9e,#6f93c1)}.psc-bar-fill-semi{background:linear-gradient(90deg,#5f94aa,#9ec0d0)}.psc-bar-target{position:absolute;top:-3px;width:2px;height:16px;border-radius:999px;background:#46556673}.psc-bar-meta{margin-top:8px;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:var(--fs-11);color:#7c8794}.psc-bar-pct-good{font-weight:700;color:#588467}.psc-bar-pct-low{font-weight:700;color:#c28a2e}.psc-part-right{min-width:90px;text-align:right}.psc-kpi-val{font-size:var(--fs-30);line-height:1;font-weight:800;letter-spacing:-.04em}.psc-kpi-val-fg{color:#315f9e}.psc-kpi-val-semi{color:#5f94aa}.psc-kpi-unit{margin-top:4px;font-size:var(--fs-10);font-weight:700;color:#8b97a3;text-transform:uppercase;letter-spacing:.08em}.psc-kpi-target{margin-top:3px;font-size:var(--fs-11);color:#8b97a3}.psc-footer{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:16px}.psc-footer-label{font-size:var(--fs-10);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#8b97a3}.psc-footer-val{font-size:var(--fs-13);font-weight:700;color:#2d3640}.psc-footer-pct{display:inline-flex;align-items:center;justify-content:center;min-width:56px;height:24px;padding:0 10px;border-radius:999px;background:#e9f0fb;border:1px solid #c7d7ee;color:#315f9e;font-size:var(--fs-11);font-weight:800}@media(max-width:760px){.psc-part{grid-template-columns:1fr}.psc-part-right{text-align:left;min-width:0}.psc-footer{grid-template-columns:1fr;align-items:flex-start}.psc-trend-head{flex-direction:column;align-items:flex-start}}.sfls-card{--sfls-color-main: var(--ink-1);--sfls-color-sub: var(--ink-4);--sfls-color-panel: #e2e8f0;--sfls-color-blue: var(--sf-blue);--sfls-color-blue-soft: rgba(49, 95, 158, .12);--sfls-color-blue-line: rgba(49, 95, 158, .55);--sfls-color-green: var(--sf-green);--sfls-color-green-soft: rgba(88, 132, 103, .14);--sfls-color-green-line: rgba(88, 132, 103, .68);--sfls-color-orange: var(--sf-orange);--sfls-color-orange-soft: rgba(194, 138, 46, .15);--sfls-color-orange-line: rgba(194, 138, 46, .74);--sfls-color-red: var(--sf-red);--sfls-color-red-soft: rgba(181, 101, 101, .16);--sfls-color-red-line: rgba(181, 101, 101, .82);position:relative;width:100%;height:100%;display:flex;flex-direction:column;min-height:0;background:#f7f8fa;border:1px solid #d7dde5;border-radius:18px;overflow:hidden}.sfls-body{position:relative;flex:1 1 0;min-height:0;width:100%;padding:12px}.sfls-image-wrap{position:relative;width:100%;height:100%;min-height:520px;border-radius:12px;overflow:hidden;background:#eef1f4}.sfls-scada-stage{position:absolute;inset:0;width:100%;height:100%}.sfls-image{display:block;width:100%;height:100%;object-fit:cover;-webkit-user-select:none;user-select:none;pointer-events:none}.sfls-toolbar{position:absolute;top:12px;left:12px;right:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:20}.sfls-toolbar-left,.sfls-toolbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sfls-toolbar-chip{padding:5px 10px;border-radius:999px;background:#ffffffe6;border:1px solid rgba(201,208,216,.9);font-size:var(--fs-10);font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--sfls-color-main);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.sfls-toolbar-btn{height:32px;padding:0 12px;border:1px solid rgba(201,208,216,.95);border-radius:10px;background:#ffffffeb;color:var(--sfls-color-main);font-size:var(--fs-12);font-weight:700;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:all .18s ease}.sfls-toolbar-btn:hover{border-color:#315f9e59;background:#fffffffa}.sfls-zones{position:absolute;inset:0;z-index:5}.sfls-zone{position:absolute;border-radius:12px;border:2px dashed var(--sfls-color-blue-line);background:var(--sfls-color-blue-soft);pointer-events:none;transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.sfls-zone.is-running{border-color:var(--sfls-color-green-line);background:var(--sfls-color-green-soft)}.sfls-zone.is-warning{border-color:var(--sfls-color-orange-line);background:var(--sfls-color-orange-soft)}.sfls-zone.is-alarm{border-color:var(--sfls-color-red-line);background:var(--sfls-color-red-soft)}.sfls-zone.is-blink{box-shadow:0 0 0 2px #e553532e,0 0 18px #e5535347}.sfls-zone-label{position:absolute;left:10px;top:10px;display:inline-flex;align-items:center;min-height:24px;padding:3px 10px;border-radius:999px;background:#ffffffeb;border:1px solid rgba(201,208,216,.9);color:var(--sfls-color-main);font-size:var(--fs-11);font-weight:800;letter-spacing:.04em;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.sfls-callout-line-layer{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:6}.sfls-callout-line{fill:none;stroke:#4da534;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.sfls-zone-info{position:absolute;z-index:7;background:#ffffffb8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid #4da534;border-radius:10px;padding:8px 10px;box-shadow:0 6px 14px #0f172a0f,0 1px 4px #0f172a0a;transform:scale(.9);transform-origin:top left}.sfls-zone-info:after{content:"";position:absolute;left:0;top:0;right:0;height:3px;border-radius:10px 10px 0 0;background:linear-gradient(90deg,#4da534,#7cc35f)}.sfls-zone-info-title{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:var(--fs-12);font-weight:800;color:#1f2937}.sfls-zone-info-title:before{content:"";width:6px;height:6px;border-radius:50%;background:#4da534;box-shadow:0 0 0 3px #4da53426}.sfls-zone-info-divider{border-top:1px dashed rgba(0,0,0,.25);margin:5px 0 6px}.sfls-zone-info-row{display:flex;justify-content:space-between;align-items:baseline;font-size:var(--fs-11);line-height:1.3}.sfls-zone-info-row+.sfls-zone-info-row{margin-top:2px}.sfls-zone-info-label{color:#64748b;font-weight:600}.sfls-zone-info-value{color:#111827;font-weight:800}.sfls-legend{position:absolute;right:12px;bottom:12px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;z-index:21;padding:8px 10px;border-radius:12px;background:#ffffffeb;border:1px solid rgba(201,208,216,.9);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 16px #0f172a14}.sfls-legend-item{display:flex;align-items:center;gap:6px;font-size:var(--fs-11);font-weight:700}.sfls-legend-dot{width:10px;height:10px;border-radius:50%}.sfls-legend-item.is-running{color:var(--sfls-color-green)}.sfls-legend-item.is-running .sfls-legend-dot{background:var(--sfls-color-green)}.sfls-legend-item.is-warning{color:var(--sfls-color-orange)}.sfls-legend-item.is-warning .sfls-legend-dot{background:var(--sfls-color-orange)}.sfls-legend-item.is-alarm{color:var(--sfls-color-red)}.sfls-legend-item.is-alarm .sfls-legend-dot{background:var(--sfls-color-red)}@media(max-width:1400px){.sfls-zone-info{transform:scale(.92);transform-origin:top left}}@media(max-width:1280px){.sfls-legend{right:12px;bottom:12px}}@media(max-width:980px){.sfls-toolbar{flex-direction:column;align-items:stretch}.sfls-toolbar-right{justify-content:flex-end}.sfls-legend{left:12px;right:12px;justify-content:flex-start}}@media(max-width:992px){.sfls-callout-line-layer,.sfls-zone-info{display:none}.sfls-image-wrap{min-height:auto}}.pir-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary-hover: #0284c7;--primary-soft: #e0f2fe;--primary-soft-2: #bae6fd;--ok-bg: #ecfdf5;--ok-border: #86efac;--ok-text: #166534;--warn-bg: #fff7ed;--warn-border: #fdba74;--warn-text: #9a3412;--danger-bg: #fef2f2;--danger-border: #fca5a5;--danger-text: #b91c1c;--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius: 16px;--radius-sm: 12px;--tap: 48px;min-height:100dvh;background:var(--bg);color:var(--text);padding:14px;padding-bottom:calc(96px + env(safe-area-inset-bottom));overflow-x:hidden}.pir-page *{box-sizing:border-box}.pir-header{display:grid;gap:10px;margin-bottom:14px}.pir-back{min-height:var(--tap);border:1px solid var(--border);background:#fff;border-radius:999px;padding:10px 14px;display:inline-flex;align-items:center;gap:8px;font-weight:800;color:var(--text);cursor:pointer;width:fit-content}.pir-headings{display:grid;gap:4px}.pir-title{font-size:var(--fs-24);line-height:1.1;font-weight:1000}.pir-subtitle{color:var(--muted);font-size:var(--fs-13)}.pir-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;margin-bottom:14px}.pir-card-title{font-size:var(--fs-15);font-weight:1000;display:flex;align-items:center;gap:8px;margin-bottom:12px}.pir-grid{display:grid;gap:12px}.pir-grid-2{grid-template-columns:1fr}.pir-field{display:grid;gap:6px}.pir-field-full{grid-column:1 / -1}.pir-field label{font-size:var(--fs-12);font-weight:900;color:#334155}.pir-value{min-height:44px;border:1px solid #e2e8f0;background:#f8fafc;border-radius:12px;padding:11px 12px;display:flex;align-items:center;color:var(--text);line-height:1.35;word-break:break-word}.pir-value.mono,.mono{font-family:var(--pps-font-mono)}.pir-field input,.pir-field select,.pir-field textarea{width:100%;min-height:48px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:11px 12px;font:inherit;color:var(--text);outline:none}.pir-field textarea{min-height:104px;resize:vertical}.pir-field input:focus,.pir-field select:focus,.pir-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.pir-order-search{display:grid;gap:10px}.pir-grow{min-width:0}.pir-divider{height:1px;background:#e2e8f0;margin:12px 0}.pir-muted{color:var(--muted);font-size:var(--fs-13)}.pir-alert,.pir-alert-inline{border:1px solid var(--danger-border);background:var(--danger-bg);color:var(--danger-text);border-radius:14px;padding:12px}.pir-alert-title{display:flex;align-items:center;gap:8px;font-weight:1000;margin-bottom:6px}.pir-alert-text{font-size:var(--fs-13);line-height:1.5}.pir-ok-inline{border:1px solid var(--ok-border);background:var(--ok-bg);color:var(--ok-text);border-radius:14px;padding:12px;font-size:var(--fs-13);line-height:1.5}.pir-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.pir-btn{min-height:var(--tap);border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);padding:10px 14px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none}.pir-btn:disabled{opacity:.6;cursor:not-allowed}.pir-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.pir-btn-primary:not(:disabled):hover{background:var(--primary-hover);border-color:var(--primary-hover)}.pir-success{border-color:var(--ok-border);background:linear-gradient(180deg,#fff,#f0fdf4)}.pir-success-icon{color:var(--ok-text);font-size:var(--fs-32);line-height:1;margin-bottom:8px}.pir-success-title{font-size:var(--fs-18);font-weight:1000;color:#14532d}.pir-success-no{margin-top:6px;font-size:var(--fs-18);font-weight:1000;color:#166534}.pir-success-desc{margin-top:8px;color:#166534;font-size:var(--fs-13);line-height:1.5}.pir-mt{margin-top:12px}.pir-sticky-actions{position:fixed;left:0;right:0;bottom:0;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:#f8fafcf5;border-top:1px solid #dbe4ee;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;grid-template-columns:1fr 1fr;gap:10px;z-index:50}@media(min-width:768px){.pir-page{padding:20px 20px 110px}.pir-header{grid-template-columns:auto 1fr;align-items:center}.pir-grid-2{grid-template-columns:1fr 1fr}.pir-order-search{grid-template-columns:1fr auto;align-items:end}.pir-sticky-actions{left:auto;right:20px;bottom:20px;width:min(520px,calc(100vw - 40px));border:1px solid #dbe4ee;border-radius:18px;box-shadow:0 12px 30px #0f172a1f}}.pirs-page{--bg: #f8fafc;--card: #ffffff;--border: #e5e7eb;--text: #0f172a;--muted: #64748b;--primary: #0369a1;--primary-hover: #0284c7;--ok-bg: #ecfdf5;--ok-border: #86efac;--ok-text: #166534;--danger-bg: #fef2f2;--danger-border: #fca5a5;--danger-text: #b91c1c;--note-bg: #eff6ff;--note-border: #93c5fd;--note-text: #1d4ed8;--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius: 16px;--tap: 48px;min-height:100dvh;background:var(--bg);color:var(--text);padding:14px;padding-bottom:calc(110px + env(safe-area-inset-bottom));overflow-x:hidden}.pirs-page *{box-sizing:border-box}.pirs-header{display:grid;gap:10px;margin-bottom:14px}.pirs-back{min-height:var(--tap);border:1px solid var(--border);background:#fff;color:var(--text);border-radius:999px;padding:10px 14px;display:inline-flex;align-items:center;gap:8px;font-weight:800;cursor:pointer;width:fit-content}.pirs-headings{display:grid;gap:4px}.pirs-title{font-size:var(--fs-24);line-height:1.1;font-weight:1000}.pirs-subtitle{color:var(--muted);font-size:var(--fs-13)}.pirs-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;margin-bottom:14px}.pirs-card-title{font-size:var(--fs-15);font-weight:1000;display:flex;align-items:center;gap:8px;margin-bottom:12px}.pirs-success-card{border-color:var(--ok-border);background:linear-gradient(180deg,#fff,#f0fdf4)}.pirs-success-top{display:grid;grid-template-columns:1fr;gap:12px;align-items:start}.pirs-success-icon{font-size:var(--fs-40);color:var(--ok-text);line-height:1}.pirs-success-main{display:grid;gap:6px}.pirs-success-title{font-size:var(--fs-20);font-weight:1000;color:#14532d}.pirs-success-no{font-size:var(--fs-18);font-weight:1000;color:#166534}.pirs-success-desc{font-size:var(--fs-13);line-height:1.5;color:#166534}.pirs-status-chip{width:fit-content;min-height:36px;border-radius:999px;background:#dcfce7;color:#166534;border:1px solid #86efac;padding:8px 12px;display:inline-flex;align-items:center;font-size:var(--fs-12);font-weight:900}.pirs-loading-card,.pirs-error-card{text-align:center}.pirs-spinner{width:42px;height:42px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);margin:0 auto 12px;animation:pirs-spin 1s linear infinite}@keyframes pirs-spin{to{transform:rotate(360deg)}}.pirs-loading-title,.pirs-error-title{font-size:var(--fs-18);font-weight:1000}.pirs-loading-desc,.pirs-error-desc{margin-top:6px;color:var(--muted);font-size:var(--fs-13)}.pirs-error-card{border-color:var(--danger-border);background:var(--danger-bg);color:var(--danger-text)}.pirs-error-icon{font-size:var(--fs-32);line-height:1;margin-bottom:8px}.pirs-grid{display:grid;gap:12px}.pirs-grid-2{grid-template-columns:1fr}.pirs-field{display:grid;gap:6px}.pirs-field-full{grid-column:1 / -1}.pirs-field label{font-size:var(--fs-12);font-weight:900;color:#334155}.pirs-value{min-height:44px;border:1px solid #e2e8f0;background:#f8fafc;border-radius:12px;padding:11px 12px;display:flex;align-items:center;color:var(--text);line-height:1.4;word-break:break-word}.pirs-value-multiline{align-items:flex-start;white-space:pre-wrap}.pirs-note-card{border-color:var(--note-border);background:linear-gradient(180deg,#fff,#eff6ff)}.pirs-note-list{display:grid;gap:8px}.pirs-note-item{border:1px solid #bfdbfe;background:#fff;color:var(--note-text);border-radius:12px;padding:10px 12px;font-size:var(--fs-13);line-height:1.5}.pirs-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:14px}.pirs-btn{min-height:var(--tap);border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);padding:10px 14px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none}.pirs-btn:disabled{opacity:.6;cursor:not-allowed}.pirs-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.pirs-btn-primary:not(:disabled):hover{background:var(--primary-hover);border-color:var(--primary-hover)}.pirs-sticky-actions{position:fixed;left:0;right:0;bottom:0;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:#f8fafcf5;border-top:1px solid #dbe4ee;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;grid-template-columns:1fr;gap:10px;z-index:50}@media(min-width:768px){.pirs-page{padding:20px 20px 110px}.pirs-header{grid-template-columns:auto 1fr;align-items:center}.pirs-grid-2{grid-template-columns:1fr 1fr}.pirs-success-top{grid-template-columns:auto 1fr auto;align-items:center}.pirs-sticky-actions{left:auto;right:20px;bottom:20px;width:min(620px,calc(100vw - 40px));grid-template-columns:1fr 1fr 1fr;border:1px solid #dbe4ee;border-radius:18px;box-shadow:0 12px 30px #0f172a1f}}.csd-page{--bg: #f8fafc;--card: #ffffff;--card-2: #f9fafb;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-strong: #075985;--primary-soft: #e0f2fe;--success: #166534;--success-soft: #ecfdf5;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--info: #1d4ed8;--info-soft: #eff6ff;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius-sm: 12px;--radius-md: 16px;--radius-lg: 18px;--radius-xl: 22px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--fs-11: .6875rem;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;--fs-32: 2rem;--fs-36: 2.25rem;min-height:100%;padding:16px;background:var(--bg);color:var(--text);font-family:var(--pps-font-main);font-size:var(--fs-14);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.csd-page *,.csd-page *:before,.csd-page *:after{box-sizing:border-box}.csd-page button,.csd-page input,.csd-page select,.csd-page textarea{font:inherit;color:inherit}.csd-page img,.csd-page svg{display:block;max-width:100%}.csd-page a{color:inherit}.csd-page :focus-visible{outline:2px solid rgba(3,105,161,.25);outline-offset:2px}.csd-page ::selection{background:#0369a124}.csd-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-4)}.csd-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csd-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.5}.csd-topbar-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.csd-btn{min-height:42px;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;cursor:pointer;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease,color .18s ease;-webkit-tap-highlight-color:transparent}.csd-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csd-btn:active:not(:disabled){transform:translateY(1px)}.csd-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.csd-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csd-btn-primary:hover:not(:disabled){background:var(--primary-strong);border-color:var(--primary-strong);color:#fff}.csd-btn-soft{background:var(--primary-soft);border-color:#bae6fd;color:var(--primary-strong)}.csd-spin{animation:csd-spin 1s linear infinite}@keyframes csd-spin{to{transform:rotate(360deg)}}.csd-summary-card,.csd-scope-card,.csd-panel,.csd-loading-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg)}.csd-summary-row{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;margin-bottom:14px}.csd-summary-card{padding:14px}.csd-summary-label{display:flex;align-items:center;gap:8px;color:var(--text-soft);font-size:var(--fs-13);font-weight:700;line-height:1.4}.csd-summary-value{margin-top:8px;font-size:clamp(1rem,1rem + 1vw,1rem);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:var(--text)}.csd-scope-card{padding:14px;margin-bottom:14px}.csd-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csd-scope-grid{margin-top:12px;display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.csd-scope-label{color:var(--text-soft);font-size:var(--fs-12);font-weight:700;line-height:1.4;margin-bottom:4px;text-transform:uppercase;letter-spacing:.02em}.csd-scope-values{color:var(--text);font-size:var(--fs-14);line-height:1.55;word-break:break-word}.csd-loading-card{text-align:center;padding:32px 16px}.csd-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csd-spin 1s linear infinite}.csd-loading-title{font-size:var(--fs-18);font-weight:800;line-height:1.3;color:var(--text)}.csd-loading-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.5}.csd-card-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;margin-bottom:16px}.csd-kpi-card{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow);padding:14px;min-width:0}.csd-card-primary{background:linear-gradient(180deg,#fff,#f0f9ff);border-color:#bae6fd}.csd-card-success{background:linear-gradient(180deg,#fff,#f0fdf4);border-color:#bbf7d0}.csd-card-warning{background:linear-gradient(180deg,#fff,#fff7ed);border-color:#fed7aa}.csd-card-danger{background:linear-gradient(180deg,#fff,#fef2f2);border-color:#fecaca}.csd-card-info{background:linear-gradient(180deg,#fff,#eff6ff);border-color:#bfdbfe}.csd-card-neutral{background:linear-gradient(180deg,#fff,#f8fafc);border-color:#e2e8f0}.csd-kpi-title{font-size:var(--fs-13);font-weight:700;line-height:1.4;color:var(--text-soft)}.csd-kpi-value{margin-top:10px;font-size:clamp(1.75rem,1.3rem + 1.6vw,2.4rem);line-height:1.05;font-weight:800;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csd-kpi-hint{margin-top:10px;font-size:var(--fs-12);color:var(--text-muted);line-height:1.55}.csd-main-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:14px;margin-bottom:16px}.csd-panel{padding:14px;min-width:0}.csd-panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.csd-link{color:var(--primary);text-decoration:none;font-weight:700;font-size:var(--fs-13);line-height:1.4;transition:color .18s ease}.csd-link:hover{color:var(--primary-strong);text-decoration:underline}.csd-empty{border:1px dashed var(--border-strong);background:var(--surface);border-radius:14px;padding:16px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.6}.csd-list{display:grid;gap:10px}.csd-list-item{border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px;display:grid;grid-template-columns:minmax(0,1fr);gap:10px;min-width:0;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.csd-list-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow-xs)}.csd-list-main{min-width:0}.csd-list-title-row{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap}.csd-list-title{font-size:var(--fs-14);font-weight:800;line-height:1.45;color:var(--text);word-break:break-word}.csd-list-sub{margin-top:5px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.55;word-break:break-word}.csd-list-side{display:grid;gap:4px;color:var(--text-muted);font-size:var(--fs-12);line-height:1.5;justify-content:start;min-width:0}.csd-status-badge{display:inline-flex;align-items:center;justify-content:center;max-width:100%;border-radius:999px;background:var(--surface);border:1px solid var(--border);padding:6px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2;color:var(--text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.csd-quick-links{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.csd-quick-link{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;min-height:64px;padding:14px;text-decoration:none;color:var(--text);display:flex;align-items:center;gap:12px;font-size:var(--fs-14);font-weight:700;line-height:1.45;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease,background-color .18s ease}.csd-quick-link:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm);background:#fcfdff}.csd-quick-link:active{transform:translateY(1px)}.csd-count-badge{display:inline-flex;align-items:center;justify-content:center;margin-left:8px;min-width:28px;padding:4px 10px;border-radius:999px;background:#e2e8f0;color:#334155;font-size:var(--fs-12);font-weight:800;line-height:1}@media(max-width:479px){.csd-page{padding:12px}.csd-topbar{margin-bottom:14px}.csd-topbar-actions{width:100%}.csd-topbar-actions .csd-btn{flex:1 1 auto;min-width:0}.csd-summary-card,.csd-scope-card,.csd-panel,.csd-kpi-card,.csd-quick-link{border-radius:14px}.csd-list-item{padding:12px}.csd-status-badge{white-space:normal}}@media(min-width:768px){.csd-page{padding:20px;font-size:var(--fs-15)}.csd-summary-row{grid-template-columns:repeat(3,minmax(0,1fr))}.csd-scope-grid,.csd-card-grid,.csd-main-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csd-list-item{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px}.csd-list-side{justify-content:end;text-align:right}.csd-quick-links{grid-template-columns:repeat(2,minmax(0,1fr))}.csd-summary-card,.csd-scope-card,.csd-panel,.csd-loading-card,.csd-kpi-card{padding:16px}}@media(min-width:1024px){.csd-page{padding:24px}.csd-card-grid,.csd-quick-links{grid-template-columns:repeat(3,minmax(0,1fr))}.csd-panel,.csd-scope-card,.csd-summary-card,.csd-kpi-card{padding:18px}}@media(min-width:1280px){.csd-summary-row{grid-template-columns:repeat(5,minmax(0,1fr))}.csd-card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.csd-main-grid{grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr)}.csd-quick-links{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1536px){.csd-page{padding:28px}.csd-main-grid{gap:18px}.csd-card-grid,.csd-summary-row,.csd-quick-links{gap:14px}}@media(hover:none){.csd-btn:hover,.csd-list-item:hover,.csd-quick-link:hover,.csd-link:hover{transform:none;box-shadow:inherit;text-decoration:none}}@media(prefers-reduced-motion:reduce){.csd-page *,.csd-page *:before,.csd-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.csr-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-strong: #075985;--primary-soft: #e0f2fe;--info: #1d4ed8;--info-soft: #eff6ff;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius-sm: 12px;--radius-md: 14px;--radius-lg: 18px;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;--fs-32: 2rem;min-height:100%;background:var(--bg);color:var(--text);padding:16px;font-family:var(--pps-font-main);font-size:var(--fs-14);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.csr-page *,.csr-page *:before,.csr-page *:after{box-sizing:border-box}.csr-page button,.csr-page input,.csr-page select,.csr-page textarea{font:inherit;color:inherit}.csr-page img,.csr-page svg{display:block;max-width:100%}.csr-page :focus-visible{outline:2px solid rgba(3,105,161,.2);outline-offset:2px}.csr-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csr-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csr-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.5}.csr-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.csr-btn{min-height:42px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;-webkit-tap-highlight-color:transparent}.csr-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csr-btn:active:not(:disabled){transform:translateY(1px)}.csr-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.csr-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csr-btn-primary:hover:not(:disabled){background:var(--primary-strong);border-color:var(--primary-strong);color:#fff}.csr-btn-warning{background:#fff7ed;border-color:#fdba74;color:#9a3412}.csr-btn-warning:hover:not(:disabled){background:#ffedd5;border-color:#fb923c}.csr-btn-danger{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.csr-btn-danger:hover:not(:disabled){background:#fee2e2;border-color:#f87171}.csr-spin{animation:csr-spin 1s linear infinite}@keyframes csr-spin{to{transform:rotate(360deg)}}.csr-kpi-card,.csr-filter-card,.csr-item-card,.csr-loading-card,.csr-empty-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg)}.csr-kpi-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:14px}.csr-kpi-card{padding:14px;min-width:0}.csr-kpi-title{font-size:var(--fs-13);font-weight:700;line-height:1.4;color:var(--text-soft)}.csr-kpi-value{margin-top:10px;font-size:clamp(1.75rem,1.3rem + 1.5vw,2.4rem);line-height:1.05;font-weight:800;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csr-kpi-neutral{background:linear-gradient(180deg,#fff,#f8fafc)}.csr-kpi-info{background:linear-gradient(180deg,#fff,#eff6ff);border-color:#bfdbfe}.csr-kpi-primary{background:linear-gradient(180deg,#fff,#f0f9ff);border-color:#bae6fd}.csr-kpi-warning{background:linear-gradient(180deg,#fff,#fff7ed);border-color:#fed7aa}.csr-filter-card{padding:14px;margin-bottom:14px}.csr-filter-head{margin-bottom:12px}.csr-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csr-filter-grid{display:grid;grid-template-columns:1fr;gap:12px}.csr-field{display:grid;gap:6px;min-width:0}.csr-field-grow{min-width:0}.csr-field label{font-size:var(--fs-12);font-weight:700;line-height:1.4;color:#334155}.csr-field input,.csr-field select{width:100%;min-height:44px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:10px 12px;font-size:var(--fs-14);line-height:1.4;color:var(--text);outline:none;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.csr-field input::placeholder{color:#94a3b8}.csr-field input:focus,.csr-field select:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.csr-filter-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.csr-loading-card,.csr-empty-card{padding:32px 16px;text-align:center}.csr-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csr-spin 1s linear infinite}.csr-loading-title{font-size:var(--fs-18);font-weight:800;line-height:1.3;color:var(--text)}.csr-loading-subtitle,.csr-empty-text{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.5}.csr-list{display:grid;gap:14px}.csr-item-card{padding:14px;min-width:0}.csr-item-head{display:grid;gap:8px;margin-bottom:12px}.csr-item-title-wrap{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:flex-start}.csr-item-title{font-size:var(--fs-16);font-weight:800;line-height:1.4;color:var(--text);word-break:break-word}.csr-item-time{font-size:var(--fs-12);line-height:1.45;color:var(--text-muted);white-space:nowrap}.csr-item-grid{display:grid;grid-template-columns:1fr;gap:12px}.csr-meta-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;min-width:0}.csr-meta-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;line-height:1.4;margin-bottom:8px;color:var(--text)}.csr-meta-line{color:var(--text-soft);font-size:var(--fs-13);line-height:1.6;margin-top:4px}.csr-wrap{word-break:break-word;overflow-wrap:anywhere;white-space:pre-wrap}.csr-item-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.csr-status-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid var(--border);white-space:nowrap}.csr-badge-neutral{background:var(--surface);color:var(--text-soft)}.csr-badge-info{background:var(--info-soft);border-color:#bfdbfe;color:var(--info)}.csr-badge-primary{background:var(--primary-soft);border-color:#bae6fd;color:var(--primary)}.csr-badge-warning{background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csr-badge-danger{background:var(--danger-soft);border-color:#fca5a5;color:var(--danger)}@media(max-width:479px){.csr-page{padding:12px}.csr-topbar-actions{width:100%}.csr-topbar-actions .csr-btn,.csr-filter-actions .csr-btn,.csr-item-actions .csr-btn{flex:1 1 auto;min-width:0}.csr-item-time{white-space:normal}}@media(min-width:768px){.csr-page{padding:20px;font-size:var(--fs-15)}.csr-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csr-filter-grid{grid-template-columns:220px minmax(0,1fr) auto;align-items:end}.csr-item-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csr-item-head{grid-template-columns:minmax(0,1fr) auto;align-items:start}}@media(min-width:1024px){.csr-page{padding:24px}.csr-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.csr-item-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.csr-kpi-card,.csr-filter-card,.csr-item-card{padding:16px}}@media(min-width:1280px){.csr-page{padding:28px}.csr-kpi-grid,.csr-filter-grid,.csr-item-grid,.csr-list{gap:14px}}@media(hover:none){.csr-btn:hover:not(:disabled){background:inherit;border-color:inherit;box-shadow:var(--shadow-xs)}.csr-btn-primary:hover:not(:disabled){background:var(--primary);border-color:var(--primary)}.csr-btn-warning:hover:not(:disabled){background:#fff7ed;border-color:#fdba74}.csr-btn-danger:hover:not(:disabled){background:#fef2f2;border-color:#fca5a5}}@media(prefers-reduced-motion:reduce){.csr-page *,.csr-page *:before,.csr-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.csr-btn-skip{background:#fff;border:1.5px solid #f6c48f;color:#6b7280}.csr-btn-skip:hover:not(:disabled){background:#fffaf5;border-color:#f0b978;color:#4b5563}.csr-item-head-badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.csdoc-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-strong: #075985;--primary-soft: #e0f2fe;--info: #1d4ed8;--info-soft: #eff6ff;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--success: #166534;--success-soft: #ecfdf5;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius-sm: 12px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 22px;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;--fs-32: 2rem;--fs-36: 2.25rem;min-height:100%;background:var(--bg);color:var(--text);padding:16px;font-family:var(--pps-font-main);font-size:var(--fs-14);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.csdoc-page *,.csdoc-page *:before,.csdoc-page *:after{box-sizing:border-box}.csdoc-page button,.csdoc-page input,.csdoc-page select,.csdoc-page textarea{font:inherit;color:inherit}.csdoc-page img,.csdoc-page svg{display:block;max-width:100%}.csdoc-page a{color:inherit}.csdoc-page :focus-visible{outline:2px solid rgba(3,105,161,.2);outline-offset:2px}.csdoc-page ::selection{background:#0369a124}.csdoc-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csdoc-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csdoc-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.55}.csdoc-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.csdoc-btn{min-height:42px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;white-space:nowrap;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;-webkit-tap-highlight-color:transparent}.csdoc-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csdoc-btn:active:not(:disabled){transform:translateY(1px)}.csdoc-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.csdoc-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csdoc-btn-primary:hover:not(:disabled){background:var(--primary-strong);border-color:var(--primary-strong);color:#fff}.csdoc-spin{animation:csdoc-spin 1s linear infinite}@keyframes csdoc-spin{to{transform:rotate(360deg)}}.csdoc-kpi-card,.csdoc-filter-card,.csdoc-item-card,.csdoc-loading-card,.csdoc-empty-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg)}.csdoc-kpi-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:14px}.csdoc-kpi-card{padding:14px;min-width:0}.csdoc-kpi-title{font-size:var(--fs-13);font-weight:700;line-height:1.4;color:var(--text-soft)}.csdoc-kpi-value{margin-top:10px;font-size:clamp(1.75rem,1.3rem + 1.5vw,2.35rem);line-height:1.05;font-weight:800;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csdoc-kpi-neutral{background:linear-gradient(180deg,#fff,#f8fafc)}.csdoc-kpi-primary{background:linear-gradient(180deg,#fff,#f0f9ff);border-color:#bae6fd}.csdoc-kpi-warning{background:linear-gradient(180deg,#fff,#fff7ed);border-color:#fed7aa}.csdoc-kpi-info{background:linear-gradient(180deg,#fff,#eff6ff);border-color:#bfdbfe}.csdoc-kpi-success{background:linear-gradient(180deg,#fff,#f0fdf4);border-color:#bbf7d0}.csdoc-filter-card{padding:14px;margin-bottom:14px}.csdoc-filter-head{margin-bottom:12px}.csdoc-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csdoc-filter-grid{display:grid;grid-template-columns:1fr;gap:12px}.csdoc-field{display:grid;gap:6px;min-width:0}.csdoc-field-grow{min-width:0}.csdoc-field label{font-size:var(--fs-12);font-weight:700;line-height:1.4;color:#334155}.csdoc-field input,.csdoc-field select{width:100%;min-height:44px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:10px 12px;font-size:var(--fs-14);line-height:1.4;color:var(--text);outline:none;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.csdoc-field input::placeholder{color:#94a3b8}.csdoc-field input:focus,.csdoc-field select:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.csdoc-filter-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.csdoc-loading-card,.csdoc-empty-card{padding:32px 16px;text-align:center}.csdoc-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csdoc-spin 1s linear infinite}.csdoc-loading-title{font-size:var(--fs-18);font-weight:800;line-height:1.3;color:var(--text)}.csdoc-loading-subtitle,.csdoc-empty-text{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.55}.csdoc-list{display:grid;gap:14px}.csdoc-item-card{padding:14px;min-width:0}.csdoc-item-head{display:grid;gap:8px;margin-bottom:12px}.csdoc-item-title-wrap{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:flex-start}.csdoc-item-title{font-size:var(--fs-16);font-weight:800;line-height:1.4;color:var(--text);word-break:break-word}.csdoc-item-time{font-size:var(--fs-12);color:var(--text-muted);line-height:1.45;white-space:nowrap}.csdoc-item-grid{display:grid;grid-template-columns:1fr;gap:12px}.csdoc-meta-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;min-width:0}.csdoc-meta-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;line-height:1.4;margin-bottom:8px;color:var(--text)}.csdoc-meta-line{color:var(--text-soft);font-size:var(--fs-13);line-height:1.6;margin-top:4px}.csdoc-wrap{word-break:break-word;overflow-wrap:anywhere;white-space:pre-wrap}.csdoc-item-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.csdoc-status-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid var(--border);white-space:nowrap;max-width:100%}.csdoc-badge-neutral{background:var(--surface);color:var(--text-soft)}.csdoc-badge-primary{background:var(--primary-soft);border-color:#bae6fd;color:var(--primary)}.csdoc-badge-info{background:var(--info-soft);border-color:#bfdbfe;color:var(--info)}.csdoc-badge-warning{background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csdoc-badge-danger{background:var(--danger-soft);border-color:#fca5a5;color:var(--danger)}.csdoc-badge-success{background:var(--success-soft);border-color:#86efac;color:var(--success)}@media(max-width:479px){.csdoc-page{padding:12px}.csdoc-topbar-actions{width:100%}.csdoc-topbar-actions .csdoc-btn,.csdoc-filter-actions .csdoc-btn,.csdoc-item-actions .csdoc-btn{flex:1 1 auto;min-width:0}.csdoc-item-time,.csdoc-status-badge{white-space:normal}}@media(min-width:768px){.csdoc-page{padding:20px;font-size:var(--fs-15)}.csdoc-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.csdoc-filter-grid{grid-template-columns:180px 220px minmax(140px,160px) minmax(0,1fr) auto;align-items:end}.csdoc-item-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csdoc-item-head{grid-template-columns:minmax(0,1fr) auto;align-items:start}.csdoc-kpi-card,.csdoc-filter-card,.csdoc-item-card{padding:16px}}@media(min-width:1024px){.csdoc-page{padding:24px}.csdoc-item-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1200px){.csdoc-kpi-grid{grid-template-columns:repeat(6,minmax(0,1fr))}}@media(min-width:1440px){.csdoc-page{padding:28px}.csdoc-kpi-grid,.csdoc-filter-grid,.csdoc-item-grid,.csdoc-list{gap:14px}}@media(hover:none){.csdoc-btn:hover:not(:disabled){background:inherit;border-color:inherit;box-shadow:var(--shadow-xs)}.csdoc-btn-primary:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}}@media(prefers-reduced-motion:reduce){.csdoc-page *,.csdoc-page *:before,.csdoc-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.csdoc-btn-disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.csdoc-warning-box{margin-top:12px;padding:10px 12px;border:1px solid #fdba74;background:#fff7ed;border-radius:12px;display:grid;gap:6px}.csdoc-warning-line{display:flex;align-items:center;gap:8px;color:#9a3412;font-size:var(--fs-14);font-weight:600;line-height:1.5}.csdt-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-strong: #075985;--primary-soft: #e0f2fe;--info: #1d4ed8;--info-soft: #eff6ff;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--success: #166534;--success-soft: #ecfdf5;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius-sm: 12px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 22px;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;--fs-32: 2rem;min-height:100%;background:var(--bg);color:var(--text);padding:16px;font-family:var(--pps-font-main);font-size:var(--fs-14);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.csdt-page *,.csdt-page *:before,.csdt-page *:after{box-sizing:border-box}.csdt-page button,.csdt-page input,.csdt-page select,.csdt-page textarea{font:inherit;color:inherit}.csdt-page img,.csdt-page svg{display:block;max-width:100%}.csdt-page a{color:inherit}.csdt-page :focus-visible{outline:2px solid rgba(3,105,161,.22);outline-offset:2px}.csdt-page ::selection{background:#0369a124}.csdt-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csdt-topbar-left{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap;min-width:0}.csdt-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.csdt-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csdt-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.55}.csdt-btn{min-height:42px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;white-space:nowrap;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;-webkit-tap-highlight-color:transparent}.csdt-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csdt-btn:active:not(:disabled){transform:translateY(1px)}.csdt-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.csdt-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csdt-btn-primary:hover:not(:disabled){background:var(--primary-strong);border-color:var(--primary-strong);color:#fff}.csdt-spin{animation:csdt-spin 1s linear infinite}@keyframes csdt-spin{to{transform:rotate(360deg)}}.csdt-loading-card,.csdt-hero-card,.csdt-summary-card,.csdt-panel{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg)}.csdt-loading-card{text-align:center;padding:32px 16px}.csdt-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csdt-spin 1s linear infinite}.csdt-loading-title{font-size:var(--fs-18);font-weight:800;line-height:1.3;color:var(--text)}.csdt-loading-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.55}.csdt-hero-card{padding:16px;margin-bottom:14px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:flex-start}.csdt-doc-no{font-size:clamp(1.25rem,1rem + .9vw,1.75rem);font-weight:800;line-height:1.2;color:var(--text);word-break:break-word}.csdt-hero-sub{margin-top:6px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.5}.csdt-hero-desc{margin-top:8px;color:var(--text);font-size:var(--fs-14);line-height:1.55;word-break:break-word}.csdt-status-chip,.csdt-status-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid var(--border);white-space:nowrap;max-width:100%}.csdt-badge-neutral{background:var(--surface);color:var(--text-soft)}.csdt-badge-primary{background:var(--primary-soft);border-color:#bae6fd;color:var(--primary)}.csdt-badge-info{background:var(--info-soft);border-color:#bfdbfe;color:var(--info)}.csdt-badge-warning{background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csdt-badge-danger{background:var(--danger-soft);border-color:#fca5a5;color:var(--danger)}.csdt-badge-success{background:var(--success-soft);border-color:#86efac;color:var(--success)}.csdt-summary-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:14px}.csdt-summary-card{padding:14px}.csdt-summary-label{color:var(--text-soft);font-size:var(--fs-13);font-weight:700;line-height:1.4}.csdt-summary-value{margin-top:8px;font-size:clamp(1rem,1rem + 1vw,1rem);font-weight:800;line-height:1.25;color:var(--text);word-break:break-word}.csdt-main-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}.csdt-panel{padding:14px;min-width:0}.csdt-panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.csdt-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csdt-section-count{color:var(--text-muted);font-size:var(--fs-12);font-weight:700;line-height:1.4}.csdt-field-grid{display:grid;grid-template-columns:1fr;gap:12px}.csdt-field{display:grid;gap:6px;min-width:0}.csdt-field-full{grid-column:1 / -1}.csdt-field label{font-size:var(--fs-12);font-weight:700;line-height:1.4;color:#334155}.csdt-value{min-height:44px;border:1px solid #e2e8f0;background:#f8fafc;border-radius:12px;padding:11px 12px;display:flex;align-items:center;color:var(--text);font-size:var(--fs-14);line-height:1.5;word-break:break-word;overflow-wrap:anywhere}.csdt-value-multiline{align-items:flex-start;white-space:pre-wrap}.csdt-highlight-card{border:1px solid #dbeafe;background:linear-gradient(180deg,#fff,#eff6ff);border-radius:14px;padding:12px;margin-bottom:12px}.csdt-highlight-title{font-size:var(--fs-14);font-weight:800;line-height:1.4;margin-bottom:6px;color:var(--text)}.csdt-highlight-sub{color:var(--text-soft);font-size:var(--fs-13);line-height:1.55;margin-top:4px}.csdt-subsection-title{font-size:var(--fs-13);font-weight:800;line-height:1.4;margin-bottom:8px;color:var(--text)}.csdt-empty{border:1px dashed var(--border-strong);background:var(--surface);border-radius:14px;padding:16px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.6}.csdt-mini-list{display:grid;gap:10px}.csdt-mini-row{border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px;display:grid;grid-template-columns:1fr;gap:10px;min-width:0}.csdt-mini-title{font-size:var(--fs-14);font-weight:800;line-height:1.4;color:var(--text);word-break:break-word}.csdt-mini-sub{margin-top:5px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.55;word-break:break-word}.csdt-mini-side{color:var(--text-muted);font-size:var(--fs-12);line-height:1.5}.csdt-wrap{word-break:break-word;overflow-wrap:anywhere;white-space:pre-wrap}.csdt-timeline{display:grid;gap:10px}.csdt-timeline-item{display:grid;grid-template-columns:18px minmax(0,1fr);gap:10px;align-items:start}.csdt-timeline-dot{width:12px;height:12px;border-radius:999px;background:var(--primary);margin-top:6px;box-shadow:0 0 0 4px #0369a11f}.csdt-timeline-body{border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px;min-width:0}.csdt-timeline-title{font-size:var(--fs-14);font-weight:800;line-height:1.4;color:var(--text);word-break:break-word}.csdt-timeline-sub{margin-top:4px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.55;word-break:break-word}.csdt-timeline-time{margin-top:6px;color:var(--text-muted);font-size:var(--fs-12);line-height:1.45}@media(max-width:479px){.csdt-page{padding:12px}.csdt-topbar-actions{width:100%}.csdt-topbar-actions .csdt-btn{flex:1 1 auto;min-width:0}.csdt-status-chip,.csdt-status-badge{white-space:normal}}@media(min-width:768px){.csdt-page{padding:20px;font-size:var(--fs-15)}.csdt-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csdt-main-grid,.csdt-field-grid{grid-template-columns:1fr 1fr}.csdt-mini-row{grid-template-columns:minmax(0,1fr) auto;align-items:center}.csdt-panel,.csdt-summary-card,.csdt-hero-card{padding:16px}}@media(min-width:1024px){.csdt-page{padding:24px}.csdt-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1440px){.csdt-page{padding:28px}.csdt-summary-grid,.csdt-main-grid,.csdt-field-grid,.csdt-mini-list,.csdt-timeline{gap:14px}}@media(hover:none){.csdt-btn:hover:not(:disabled){background:inherit;border-color:inherit;box-shadow:var(--shadow-xs)}.csdt-btn-primary:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}}@media(prefers-reduced-motion:reduce){.csdt-page *,.csdt-page *:before,.csdt-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.csdt-btn-disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.csdt-warning-box{margin-bottom:14px;padding:12px 14px;border:1px solid #fdba74;background:#fff7ed;border-radius:14px;display:grid;gap:8px}.csdt-warning-line{display:flex;align-items:flex-start;gap:8px;color:#9a3412;font-size:var(--fs-14);font-weight:700;line-height:1.55}.csop-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-strong: #075985;--primary-soft: #e0f2fe;--danger: #b91c1c;--danger-soft: #fef2f2;--success: #166534;--success-soft: #ecfdf5;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .28);--radius-sm: 12px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 20px;--tap: 46px;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;min-height:100%;background:var(--bg);color:var(--text);padding:16px 16px 110px;font-family:var(--pps-font-main);font-size:var(--fs-14);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.csop-page *,.csop-page *:before,.csop-page *:after{box-sizing:border-box}.csop-page button,.csop-page input,.csop-page select,.csop-page textarea{font:inherit;color:inherit}.csop-page img,.csop-page svg{display:block;max-width:100%}.csop-page a{color:inherit}.csop-page :focus-visible{outline:2px solid rgba(3,105,161,.22);outline-offset:2px}.csop-page ::selection{background:#0369a124}.csop-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csop-topbar-left{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap;min-width:0}.csop-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.csop-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csop-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.55}.csop-btn{min-height:var(--tap);border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;white-space:nowrap;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;-webkit-tap-highlight-color:transparent}.csop-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csop-btn:active:not(:disabled){transform:translateY(1px)}.csop-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.csop-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csop-btn-primary:hover:not(:disabled){background:var(--primary-strong);border-color:var(--primary-strong);color:#fff}.csop-btn-danger{background:var(--danger-soft);border-color:#fca5a5;color:var(--danger)}.csop-btn-danger:hover:not(:disabled){background:#fee2e2;border-color:#f87171;color:var(--danger)}.csop-spin{animation:csop-spin 1s linear infinite}@keyframes csop-spin{to{transform:rotate(360deg)}}.csop-loading-card,.csop-hero-card,.csop-summary-card,.csop-panel{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg)}.csop-loading-card{text-align:center;padding:32px 16px}.csop-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csop-spin 1s linear infinite}.csop-loading-title{font-size:var(--fs-18);font-weight:800;line-height:1.3;color:var(--text)}.csop-loading-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.55}.csop-hero-card{padding:16px;margin-bottom:14px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:flex-start}.csop-doc-no{font-size:clamp(1.25rem,1rem + .9vw,1.75rem);font-weight:800;line-height:1.2;color:var(--text);word-break:break-word}.csop-hero-sub{margin-top:6px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.5}.csop-hero-desc{margin-top:8px;color:var(--text);font-size:var(--fs-14);line-height:1.55;word-break:break-word}.csop-status-wrap{display:grid;gap:8px}.csop-status-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:8px 12px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid #bae6fd;background:var(--primary);color:#fff;white-space:nowrap;max-width:100%}.csop-status-chip-soft{background:var(--primary-soft);color:var(--primary)}.csop-summary-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:14px}.csop-summary-card{padding:14px}.csop-summary-label{color:var(--text-soft);font-size:var(--fs-13);font-weight:700;line-height:1.4}.csop-summary-value{margin-top:8px;font-size:clamp(1rem,1rem + 1vw,1rem);font-weight:800;line-height:1.3;color:var(--text);word-break:break-word}.csop-panel{padding:14px;margin-bottom:14px;min-width:0}.csop-panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.csop-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csop-session-meta{display:flex;gap:8px;flex-wrap:wrap}.csop-chip,.csop-count-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid var(--border);background:var(--surface);color:var(--text-soft)}.csop-empty{border:1px dashed var(--border-strong);background:var(--surface);border-radius:14px;padding:16px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.6}.csop-grid-head{display:none}.csop-rows{display:grid;gap:10px}.csop-row{display:grid;grid-template-columns:1fr;gap:10px;border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px;min-width:0}.csop-item-meta,.csop-item-spec,.csop-item-input,.csop-item-remark{min-width:0}.csop-item-title{font-size:var(--fs-14);font-weight:800;line-height:1.45;color:var(--text);word-break:break-word}.csop-item-code{margin-top:4px;color:var(--text-soft);font-size:var(--fs-12);line-height:1.45;word-break:break-word}.csop-item-ref{margin-top:6px;display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:var(--fs-12);line-height:1.45;word-break:break-word;flex-wrap:wrap}.csop-spec-main{color:var(--text);font-size:var(--fs-13);line-height:1.55;word-break:break-word}.csop-spec-sub{margin-top:4px;color:var(--text-muted);font-size:var(--fs-12);line-height:1.5;word-break:break-word}.csop-item-input{display:grid;gap:8px}.csop-item-remark{display:grid}.csop-row input,.csop-row select{width:100%;min-height:44px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:10px 12px;font-size:var(--fs-14);line-height:1.4;color:var(--text);outline:none;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.csop-row input::placeholder{color:#94a3b8}.csop-row input:focus,.csop-row select:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.csop-auto-result{min-height:44px;border:1px solid #cbd5e1;background:#f8fafc;border-radius:12px;padding:10px 12px;display:flex;align-items:center;font-size:var(--fs-14);font-weight:700;line-height:1.4;color:#475569}.csop-auto-result.is-pass,.csop-status-chip.is-pass{background:#ecfdf5;border-color:#86efac;color:#166534}.csop-auto-result.is-fail,.csop-status-chip.is-fail{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.csop-row input.is-fail,.csop-row select.is-fail{border-color:#fca5a5;box-shadow:0 0 0 4px #ef444414}.csop-sticky-actions{position:fixed;left:0;right:0;bottom:0;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:#f8fafcf5;border-top:1px solid #dbe4ee;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:grid;grid-template-columns:1fr;gap:10px;z-index:50}.csop-ref-card{margin-top:10px;display:grid;gap:8px;max-width:220px}.csop-ref-image{width:100%;height:140px;object-fit:contain;border:1px solid var(--border);border-radius:12px;background:#fff;display:block;cursor:zoom-in;box-shadow:var(--shadow-xs)}.csop-image-placeholder{width:100%;height:140px;border:1px dashed var(--border-strong);border-radius:12px;background:var(--surface);color:var(--text-muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:10px;text-align:center;font-size:var(--fs-12);line-height:1.45}.csop-ref-zoom{min-height:40px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;cursor:pointer;width:fit-content;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,box-shadow .18s ease}.csop-ref-zoom:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csop-ref-zoom:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.csop-lightbox{position:fixed;inset:0;background:#0f172ab8;z-index:1300;display:flex;align-items:center;justify-content:center;padding:20px}.csop-lightbox-dialog{width:min(1100px,100%);max-height:calc(100vh - 40px);background:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.csop-lightbox-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.csop-lightbox-title{font-size:var(--fs-16);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csop-lightbox-body{padding:16px;overflow:auto;display:flex;align-items:center;justify-content:center;background:#f8fafc}.csop-lightbox-image{width:100%;max-width:100%;max-height:calc(100vh - 180px);object-fit:contain;border-radius:14px;background:#fff}@media(max-width:479px){.csop-page{padding:12px 12px 116px}.csop-topbar-actions{width:100%}.csop-topbar-actions .csop-btn,.csop-sticky-actions .csop-btn{flex:1 1 auto;min-width:0}.csop-status-chip{white-space:normal}.csop-ref-card{max-width:100%}.csop-ref-image,.csop-image-placeholder{height:180px}.csop-lightbox,.csop-lightbox-head,.csop-lightbox-body{padding:12px}}@media(min-width:768px){.csop-page{padding:20px 20px 120px;font-size:var(--fs-15)}.csop-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csop-grid-head{display:grid;grid-template-columns:1.2fr 1.2fr 1fr 1fr;gap:10px;padding:0 2px 8px;color:var(--text-soft);font-size:var(--fs-12);font-weight:700;line-height:1.4}.csop-row{grid-template-columns:1.2fr 1.2fr 1fr 1fr;align-items:start}.csop-sticky-actions{left:auto;right:20px;bottom:20px;width:min(520px,calc(100vw - 40px));grid-template-columns:1fr 1fr 1fr;border:1px solid #dbe4ee;border-radius:18px;box-shadow:0 12px 30px #0f172a1f}.csop-panel,.csop-summary-card,.csop-hero-card{padding:16px}}@media(min-width:1024px){.csop-page{padding:24px 24px 128px}.csop-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1440px){.csop-page{padding:28px 28px 136px}.csop-summary-grid,.csop-rows{gap:14px}}@media(hover:none){.csop-btn:hover:not(:disabled),.csop-ref-zoom:hover:not(:disabled){background:inherit;border-color:inherit;box-shadow:var(--shadow-xs)}.csop-btn-primary:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}.csop-btn-danger:hover:not(:disabled){background:var(--danger-soft);border-color:#fca5a5;color:var(--danger)}}@media(prefers-reduced-motion:reduce){.csop-page *,.csop-page *:before,.csop-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.csp-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-strong: #075985;--primary-soft: #e0f2fe;--danger: #b91c1c;--danger-soft: #fef2f2;--warning: #9a3412;--warning-soft: #fff7ed;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .28);--radius-sm: 12px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 20px;--tap: 46px;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;min-height:100%;background:var(--bg);color:var(--text);padding:16px 16px 130px;font-family:var(--pps-font-main);font-size:var(--fs-14);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.csp-page *,.csp-page *:before,.csp-page *:after{box-sizing:border-box}.csp-page button,.csp-page input,.csp-page select,.csp-page textarea{font:inherit;color:inherit}.csp-page img,.csp-page svg{display:block;max-width:100%}.csp-page a{color:inherit}.csp-page :focus-visible{outline:2px solid rgba(3,105,161,.22);outline-offset:2px}.csp-page ::selection{background:#0369a124}.csp-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csp-topbar-left{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap;min-width:0}.csp-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.csp-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csp-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.55}.csp-btn{min-height:var(--tap);border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;white-space:nowrap;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;-webkit-tap-highlight-color:transparent}.csp-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csp-btn:active:not(:disabled){transform:translateY(1px)}.csp-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.csp-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csp-btn-primary:hover:not(:disabled){background:var(--primary-strong);border-color:var(--primary-strong);color:#fff}.csp-btn-danger{background:var(--danger-soft);border-color:#fca5a5;color:var(--danger)}.csp-btn-danger:hover:not(:disabled){background:#fee2e2;border-color:#f87171}.csp-btn-skip{background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csp-btn-skip:hover:not(:disabled){background:#ffedd5;border-color:#fb923c}.csp-spin{animation:csp-spin 1s linear infinite}@keyframes csp-spin{to{transform:rotate(360deg)}}.csp-loading-card,.csp-hero-card,.csp-summary-card,.csp-panel{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg)}.csp-loading-card{text-align:center;padding:32px 16px}.csp-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csp-spin 1s linear infinite}.csp-loading-title{font-size:var(--fs-18);font-weight:800;line-height:1.3;color:var(--text)}.csp-loading-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.55}.csp-hero-card{padding:16px;margin-bottom:14px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:flex-start}.csp-doc-no{font-size:clamp(1.25rem,1rem + .9vw,1.75rem);font-weight:800;line-height:1.2;color:var(--text);word-break:break-word}.csp-hero-sub{margin-top:6px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.5}.csp-hero-desc{margin-top:8px;color:var(--text);font-size:var(--fs-14);line-height:1.55;word-break:break-word}.csp-status-wrap{display:grid;gap:8px}.csp-status-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:8px 12px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid #bae6fd;background:var(--primary);color:#fff;white-space:nowrap;max-width:100%}.csp-status-chip-soft{background:var(--primary-soft);color:var(--primary)}.csp-summary-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:14px}.csp-summary-card{padding:14px}.csp-summary-label{color:var(--text-soft);font-size:var(--fs-13);font-weight:700;line-height:1.4}.csp-summary-value{margin-top:8px;font-size:clamp(1rem,1rem + 1vw,1rem);font-weight:800;line-height:1.3;color:var(--text);word-break:break-word}.csp-main-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}.csp-panel{padding:14px;margin-bottom:14px;min-width:0}.csp-panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.csp-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csp-session-meta{display:flex;gap:8px;flex-wrap:wrap}.csp-chip,.csp-count-chip,.csp-round-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid var(--border);background:var(--surface);color:var(--text-soft)}.csp-empty{border:1px dashed var(--border-strong);background:var(--surface);border-radius:14px;padding:16px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.6}.csp-round-list{display:grid;gap:10px}.csp-round-card{width:100%;border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px;cursor:pointer;text-align:left;box-shadow:var(--shadow-xs);transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease,transform .18s ease}.csp-round-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csp-round-card:active{transform:translateY(1px)}.csp-round-card.active{border-color:#7dd3fc;background:linear-gradient(180deg,#fff,#f0f9ff)}.csp-round-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.csp-round-title{font-size:var(--fs-14);font-weight:800;line-height:1.4;color:var(--text);word-break:break-word}.csp-round-sub{margin-top:6px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.55;word-break:break-word}.csp-control-actions{display:flex;gap:10px;flex-wrap:wrap}.csp-grid-head{display:none}.csp-rows{display:grid;gap:10px}.csp-row{display:grid;grid-template-columns:1fr;gap:10px;border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px;min-width:0}.csp-row.is-fail-row{border-color:#fca5a5;background:#fff5f5}.csp-item-meta,.csp-item-spec,.csp-item-input,.csp-item-remark{min-width:0}.csp-item-title{font-size:var(--fs-14);font-weight:800;line-height:1.45;color:var(--text);word-break:break-word}.csp-item-code{margin-top:4px;color:var(--text-soft);font-size:var(--fs-12);line-height:1.45;word-break:break-word}.csp-item-ref{margin-top:6px;display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:var(--fs-12);line-height:1.45;word-break:break-word;flex-wrap:wrap}.csp-item-spec{min-width:0}.csp-spec-main{color:var(--text);font-size:var(--fs-13);line-height:1.55;word-break:break-word}.csp-spec-sub{margin-top:4px;color:var(--text-muted);font-size:var(--fs-12);line-height:1.5;word-break:break-word}.csp-item-input{display:grid;gap:8px}.csp-item-remark{display:grid}.csp-row input,.csp-row select{width:100%;min-height:44px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:10px 12px;font-size:var(--fs-14);line-height:1.4;color:var(--text);outline:none;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.csp-row input::placeholder{color:#94a3b8}.csp-row input:focus,.csp-row select:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.csp-row input.is-fail,.csp-row select.is-fail{border-color:#fca5a5;box-shadow:0 0 0 4px #ef444414}.csp-row input:disabled,.csp-row select:disabled{background:#f1f5f9;color:#64748b;cursor:not-allowed}.csp-auto-result{min-height:44px;border:1px solid #cbd5e1;background:#f8fafc;border-radius:12px;padding:10px 12px;display:flex;align-items:center;justify-content:center;font-size:var(--fs-14);font-weight:800;line-height:1.4;color:#475569}.csp-auto-result.is-pass,.csp-status-chip.is-pass{background:#ecfdf5;border-color:#86efac;color:#166534}.csp-auto-result.is-fail,.csp-status-chip.is-fail{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.csp-sticky-actions{position:fixed;left:0;right:0;bottom:0;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:#f8fafcf5;border-top:1px solid #dbe4ee;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:grid;grid-template-columns:1fr;gap:10px;z-index:50}.csp-ref-card{margin-top:10px;display:grid;gap:8px;max-width:220px}.csp-ref-image{width:100%;height:140px;object-fit:contain;border:1px solid var(--border);border-radius:12px;background:#fff;display:block;cursor:zoom-in;box-shadow:var(--shadow-xs)}.csp-image-placeholder{width:100%;height:140px;border:1px dashed var(--border-strong);border-radius:12px;background:var(--surface);color:var(--text-muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:10px;text-align:center;font-size:var(--fs-12);line-height:1.45}.csp-ref-zoom{min-height:40px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;cursor:pointer;width:fit-content;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,box-shadow .18s ease}.csp-ref-zoom:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csp-ref-zoom:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.csp-lightbox{position:fixed;inset:0;background:#0f172ab8;z-index:1300;display:flex;align-items:center;justify-content:center;padding:20px}.csp-lightbox-dialog{width:min(1100px,100%);max-height:calc(100vh - 40px);background:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.csp-lightbox-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.csp-lightbox-title{font-size:var(--fs-16);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csp-lightbox-body{padding:16px;overflow:auto;display:flex;align-items:center;justify-content:center;background:#f8fafc}.csp-lightbox-image{width:100%;max-width:100%;max-height:calc(100vh - 180px);object-fit:contain;border-radius:14px;background:#fff}@media(max-width:479px){.csp-page{padding:12px 12px 136px}.csp-topbar-actions{width:100%}.csp-topbar-actions .csp-btn,.csp-control-actions .csp-btn,.csp-sticky-actions .csp-btn{flex:1 1 auto;min-width:0}.csp-status-chip{white-space:normal}.csp-ref-card{max-width:100%}.csp-ref-image,.csp-image-placeholder{height:180px}.csp-lightbox,.csp-lightbox-head,.csp-lightbox-body{padding:12px}}@media(min-width:768px){.csp-page{padding:20px 20px 140px;font-size:var(--fs-15)}.csp-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csp-main-grid{grid-template-columns:320px minmax(0,1fr);align-items:start}.csp-grid-head{display:grid;grid-template-columns:1.2fr 1.2fr 1fr 1fr;gap:10px;padding:0 2px 8px;color:var(--text-soft);font-size:var(--fs-12);font-weight:700;line-height:1.4}.csp-row{grid-template-columns:1.2fr 1.2fr 1fr 1fr;align-items:start}.csp-sticky-actions{left:auto;right:20px;bottom:20px;width:min(680px,calc(100vw - 40px));grid-template-columns:1fr 1fr 1fr 1fr;border:1px solid #dbe4ee;border-radius:18px;box-shadow:0 12px 30px #0f172a1f}.csp-panel,.csp-summary-card,.csp-hero-card{padding:16px}}@media(min-width:1024px){.csp-page{padding:24px 24px 148px}.csp-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1440px){.csp-page{padding:28px 28px 156px}.csp-summary-grid,.csp-main-grid,.csp-round-list,.csp-rows{gap:14px}}@media(hover:none){.csp-btn:hover:not(:disabled),.csp-ref-zoom:hover:not(:disabled),.csp-round-card:hover{background:inherit;border-color:inherit;box-shadow:var(--shadow-xs)}.csp-btn-primary:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}.csp-btn-danger:hover:not(:disabled){background:var(--danger-soft);border-color:#fca5a5;color:var(--danger)}.csp-btn-skip:hover:not(:disabled){background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csp-round-card.active:hover{border-color:#7dd3fc;background:linear-gradient(180deg,#fff,#f0f9ff)}}@media(prefers-reduced-motion:reduce){.csp-page *,.csp-page *:before,.csp-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.csai-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-soft: #e0f2fe;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--success: #166534;--success-soft: #ecfdf5;--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius: 18px;min-height:100%;background:var(--bg);color:var(--text);padding:16px}.csai-page *{box-sizing:border-box}.csai-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csai-title{font-size:var(--fs-28);font-weight:800;line-height:1.1;letter-spacing:-.02em}.csai-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14)}.csai-topbar-actions{display:flex;gap:10px}.csai-btn{min-height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none}.csai-btn:disabled{opacity:.6;cursor:not-allowed}.csai-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csai-btn-warning{background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csai-btn-danger{background:var(--danger-soft);border-color:#fca5a5;color:var(--danger)}.csai-spin{animation:csai-spin 1s linear infinite}@keyframes csai-spin{to{transform:rotate(360deg)}}.csai-kpi-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:14px}.csai-kpi-card,.csai-filter-card,.csai-item-card,.csai-loading-card,.csai-empty-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius)}.csai-kpi-card{padding:14px}.csai-kpi-title{font-size:var(--fs-13);font-weight:700;color:var(--text-soft)}.csai-kpi-value{margin-top:10px;font-size:var(--fs-34);line-height:1;font-weight:800}.csai-kpi-neutral{background:linear-gradient(180deg,#fff,#f8fafc)}.csai-kpi-primary{background:linear-gradient(180deg,#fff,#f0f9ff);border-color:#bae6fd}.csai-kpi-warning{background:linear-gradient(180deg,#fff,#fff7ed);border-color:#fed7aa}.csai-kpi-success{background:linear-gradient(180deg,#fff,#f0fdf4);border-color:#bbf7d0}.csai-kpi-danger{background:linear-gradient(180deg,#fff,#fef2f2);border-color:#fecaca}.csai-filter-card{padding:14px;margin-bottom:14px}.csai-filter-head{margin-bottom:12px}.csai-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800}.csai-filter-grid{display:grid;grid-template-columns:1fr;gap:12px}.csai-field{display:grid;gap:6px}.csai-field-grow{min-width:0}.csai-field label{font-size:var(--fs-12);font-weight:700;color:#334155}.csai-field input,.csai-field select{width:100%;min-height:44px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:10px 12px;font:inherit;color:var(--text);outline:none}.csai-field input:focus,.csai-field select:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.csai-filter-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.csai-loading-card,.csai-empty-card{padding:32px 16px;text-align:center}.csai-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csai-spin 1s linear infinite}.csai-loading-title{font-size:var(--fs-18);font-weight:800}.csai-loading-subtitle,.csai-empty-text{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13)}.csai-list{display:grid;gap:14px}.csai-item-card{padding:14px}.csai-item-head{display:grid;gap:8px;margin-bottom:12px}.csai-item-title-wrap{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:flex-start}.csai-item-title{font-size:var(--fs-16);font-weight:800}.csai-item-time{font-size:var(--fs-12);color:var(--text-muted)}.csai-item-grid{display:grid;grid-template-columns:1fr;gap:12px}.csai-meta-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:12px}.csai-meta-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;margin-bottom:8px}.csai-meta-line{color:var(--text-soft);font-size:var(--fs-13);line-height:1.5;margin-top:4px}.csai-wrap{word-break:break-word;white-space:pre-wrap}.csai-item-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.csai-status-badge{border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:700;border:1px solid var(--border);white-space:nowrap}.csai-badge-neutral{background:var(--surface);color:var(--text-soft)}.csai-badge-primary{background:var(--primary-soft);border-color:#bae6fd;color:var(--primary)}.csai-badge-warning{background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csai-badge-success{background:var(--success-soft);border-color:#86efac;color:var(--success)}.csai-badge-danger{background:var(--danger-soft);border-color:#fca5a5;color:var(--danger)}@media(min-width:768px){.csai-page{padding:20px}.csai-kpi-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.csai-filter-grid{grid-template-columns:180px 220px 160px 1fr auto;align-items:end}.csai-item-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.csai-item-head{grid-template-columns:1fr auto;align-items:start}}.csrpt-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-strong: #075985;--primary-soft: #e0f2fe;--success: #166534;--success-soft: #ecfdf5;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius-sm: 12px;--radius-md: 14px;--radius-lg: 18px;--tap: 44px;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;--fs-32: 2rem;min-height:100%;background:var(--bg);color:var(--text);padding:16px;font-family:var(--pps-font-main);font-size:var(--fs-14);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.csrpt-page *,.csrpt-page *:before,.csrpt-page *:after{box-sizing:border-box}.csrpt-page button,.csrpt-page input,.csrpt-page select,.csrpt-page textarea{font:inherit;color:inherit}.csrpt-page img,.csrpt-page svg{display:block;max-width:100%}.csrpt-page a{color:inherit}.csrpt-page :focus-visible{outline:2px solid rgba(3,105,161,.22);outline-offset:2px}.csrpt-page ::selection{background:#0369a124}.csrpt-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csrpt-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csrpt-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.55}.csrpt-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.csrpt-btn{min-height:var(--tap);border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;white-space:nowrap;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;-webkit-tap-highlight-color:transparent}.csrpt-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csrpt-btn:active:not(:disabled){transform:translateY(1px)}.csrpt-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.csrpt-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csrpt-btn-primary:hover:not(:disabled){background:var(--primary-strong);border-color:var(--primary-strong);color:#fff}.csrpt-spin{animation:csrpt-spin 1s linear infinite}@keyframes csrpt-spin{to{transform:rotate(360deg)}}.csrpt-filter-card,.csrpt-kpi-card,.csrpt-panel,.csrpt-loading-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg)}.csrpt-filter-card{padding:14px;margin-bottom:14px}.csrpt-filter-head{margin-bottom:12px}.csrpt-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csrpt-filter-grid{display:grid;grid-template-columns:1fr;gap:12px}.csrpt-field{display:grid;gap:6px;min-width:0}.csrpt-field label{font-size:var(--fs-12);font-weight:700;line-height:1.4;color:#334155}.csrpt-field input{width:100%;min-height:44px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:10px 12px;font-size:var(--fs-14);line-height:1.4;color:var(--text);outline:none;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.csrpt-field input::placeholder{color:#94a3b8}.csrpt-field input[type=date]{min-width:0;appearance:none;-webkit-appearance:none}.csrpt-field input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.csrpt-filter-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.csrpt-loading-card{text-align:center;padding:32px 16px}.csrpt-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csrpt-spin 1s linear infinite}.csrpt-loading-title{font-size:var(--fs-18);font-weight:800;line-height:1.3;color:var(--text)}.csrpt-loading-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.55}.csrpt-card-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:16px}.csrpt-kpi-card{padding:14px;min-width:0}.csrpt-card-neutral{background:linear-gradient(180deg,#fff,#f8fafc)}.csrpt-card-primary{background:linear-gradient(180deg,#fff,#f0f9ff);border-color:#bae6fd}.csrpt-card-success{background:linear-gradient(180deg,#fff,#f0fdf4);border-color:#bbf7d0}.csrpt-card-warning{background:linear-gradient(180deg,#fff,#fff7ed);border-color:#fed7aa}.csrpt-card-danger{background:linear-gradient(180deg,#fff,#fef2f2);border-color:#fecaca}.csrpt-kpi-title{font-size:var(--fs-13);font-weight:700;line-height:1.4;color:var(--text-soft)}.csrpt-kpi-value{margin-top:10px;font-size:clamp(1.75rem,1.3rem + 1.5vw,2.35rem);line-height:1.05;font-weight:800;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csrpt-kpi-hint{margin-top:10px;font-size:var(--fs-12);color:var(--text-muted);line-height:1.55}.csrpt-main-grid,.csrpt-main-grid-balanced{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}.csrpt-panel{padding:14px;margin-bottom:14px;min-width:0}.csrpt-panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.csrpt-empty{border:1px dashed var(--border-strong);background:var(--surface);border-radius:14px;padding:16px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.6}.csrpt-stat-list{display:grid;gap:10px}.csrpt-stat-row{display:flex;justify-content:space-between;gap:10px;align-items:center;border:1px solid var(--border);border-radius:14px;background:#fff;padding:12px}.csrpt-stat-label{color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.45;word-break:break-word}.csrpt-stat-value{color:var(--text);font-size:var(--fs-16);font-weight:800;line-height:1.3;text-align:right}.csrpt-panel-table{overflow:hidden}.csrpt-table-wrap{width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:14px;background:#fff}.csrpt-table{width:100%;border-collapse:separate;border-spacing:0;min-width:560px}.csrpt-table th,.csrpt-table td{padding:12px;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:top;font-size:var(--fs-13);line-height:1.5;white-space:nowrap}.csrpt-table th{position:sticky;top:0;z-index:1;background:#f8fafc;color:#334155;font-weight:800}.csrpt-table tbody tr:last-child td{border-bottom:none}.csrpt-table-compact{min-width:420px}.csrpt-table-compact th:last-child,.csrpt-table-compact td:last-child{width:96px;text-align:right}.csrpt-table-trend{min-width:620px}.csrpt-table-trend th:nth-child(1),.csrpt-table-trend td:nth-child(1){width:150px}.csrpt-table-trend th:nth-child(2),.csrpt-table-trend td:nth-child(2),.csrpt-table-trend th:nth-child(3),.csrpt-table-trend td:nth-child(3),.csrpt-table-trend th:nth-child(4),.csrpt-table-trend td:nth-child(4){width:110px;text-align:right}.csrpt-list{display:grid;gap:10px}.csrpt-list-item{border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px;display:grid;grid-template-columns:1fr;gap:10px;min-width:0}.csrpt-list-main{min-width:0}.csrpt-list-title-row{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap}.csrpt-list-title{font-size:var(--fs-14);font-weight:800;line-height:1.45;color:var(--text);word-break:break-word}.csrpt-list-sub{margin-top:5px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.55;word-break:break-word}.csrpt-list-side{display:grid;gap:8px;color:var(--text-muted);font-size:var(--fs-12);line-height:1.45;justify-content:start}.csrpt-status-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--surface);border:1px solid var(--border);padding:6px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2;color:var(--text-soft);white-space:nowrap;max-width:100%}@media(min-width:768px){.csrpt-page{padding:20px;font-size:var(--fs-15)}.csrpt-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:end}.csrpt-filter-actions{grid-column:1 / -1}.csrpt-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csrpt-main-grid,.csrpt-main-grid-balanced{grid-template-columns:1fr}.csrpt-list-item{grid-template-columns:1fr;align-items:start}.csrpt-list-side{justify-content:start;text-align:left}.csrpt-filter-card,.csrpt-kpi-card,.csrpt-panel{padding:16px}}@media(min-width:1024px){.csrpt-filter-grid,.csrpt-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.csrpt-main-grid{grid-template-columns:1fr 1fr}.csrpt-main-grid-balanced{grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr)}.csrpt-list-item{grid-template-columns:1fr auto;align-items:center}.csrpt-list-side{justify-content:end;text-align:right}}@media(min-width:1440px){.csrpt-filter-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.csrpt-filter-actions{grid-column:1 / -1}.csrpt-card-grid{grid-template-columns:repeat(7,minmax(0,1fr))}}@media(max-width:479px){.csrpt-page{padding:12px}.csrpt-topbar-actions{width:100%}.csrpt-topbar-actions .csrpt-btn,.csrpt-filter-actions .csrpt-btn{flex:1 1 auto;min-width:0}.csrpt-status-badge{white-space:normal}}@media(hover:none){.csrpt-btn:hover:not(:disabled){background:inherit;border-color:inherit;box-shadow:var(--shadow-xs)}.csrpt-btn-primary:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}}@media(prefers-reduced-motion:reduce){.csrpt-page *,.csrpt-page *:before,.csrpt-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.csat-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-strong: #075985;--primary-soft: #e0f2fe;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--success: #166534;--success-soft: #ecfdf5;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .28);--radius-sm: 12px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 20px;--tap: 44px;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;--fs-32: 2rem;min-height:100%;background:var(--bg);color:var(--text);padding:16px;font-family:var(--pps-font-main);font-size:var(--fs-14);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.csat-page *,.csat-page *:before,.csat-page *:after{box-sizing:border-box}.csat-page button,.csat-page input,.csat-page select,.csat-page textarea{font:inherit;color:inherit}.csat-page img,.csat-page svg{display:block;max-width:100%}.csat-page a{color:inherit}.csat-page :focus-visible{outline:2px solid rgba(3,105,161,.22);outline-offset:2px}.csat-page ::selection{background:#0369a124}.csat-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csat-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csat-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.55}.csat-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.csat-btn{min-height:var(--tap);border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;white-space:nowrap;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;-webkit-tap-highlight-color:transparent}.csat-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csat-btn:active:not(:disabled){transform:translateY(1px)}.csat-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.csat-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csat-btn-primary:hover:not(:disabled){background:var(--primary-strong);border-color:var(--primary-strong);color:#fff}.csat-btn-warning{background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csat-btn-warning:hover:not(:disabled){background:#ffedd5;border-color:#fb923c}.csat-btn-success{background:var(--success-soft);border-color:#86efac;color:var(--success)}.csat-btn-success:hover:not(:disabled){background:#dcfce7;border-color:#4ade80}.csat-icon-btn{min-width:42px;min-height:42px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-xs);transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease}.csat-icon-btn:hover{background:var(--surface);border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csat-icon-btn:active{transform:translateY(1px)}.csat-spin{animation:csat-spin 1s linear infinite}@keyframes csat-spin{to{transform:rotate(360deg)}}.csat-kpi-card,.csat-filter-card,.csat-item-card,.csat-loading-card,.csat-empty-card,.csat-panel,.csat-modal,.csat-resultbar,.csat-pagination-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg)}.csat-kpi-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:14px}.csat-kpi-card{padding:14px;min-width:0}.csat-kpi-title{font-size:var(--fs-13);font-weight:700;line-height:1.4;color:var(--text-soft)}.csat-kpi-value{margin-top:10px;font-size:clamp(1.75rem,1.3rem + 1.5vw,2.35rem);line-height:1.05;font-weight:800;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csat-kpi-neutral{background:linear-gradient(180deg,#fff,#f8fafc)}.csat-kpi-primary{background:linear-gradient(180deg,#fff,#f0f9ff);border-color:#bae6fd}.csat-kpi-warning{background:linear-gradient(180deg,#fff,#fff7ed);border-color:#fed7aa}.csat-kpi-success{background:linear-gradient(180deg,#fff,#f0fdf4);border-color:#bbf7d0}.csat-filter-card{padding:14px;margin-bottom:14px}.csat-filter-head{margin-bottom:12px}.csat-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csat-filter-grid,.csat-form-grid{display:grid;grid-template-columns:1fr;gap:12px}.csat-field{display:grid;gap:6px;min-width:0}.csat-field-inline{display:inline-grid;gap:6px}.csat-field-grow{min-width:0}.csat-field-full{grid-column:1 / -1}.csat-field label{font-size:var(--fs-12);font-weight:700;line-height:1.4;color:#334155}.csat-field input,.csat-field select,.csat-material-search input{width:100%;min-height:44px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:10px 12px;font-size:var(--fs-14);line-height:1.4;color:var(--text);outline:none;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.csat-field input::placeholder,.csat-material-search input::placeholder{color:#94a3b8}.csat-field input:focus,.csat-field select:focus,.csat-material-search input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.csat-readonly{background:#f8fafc!important;color:#334155!important;font-weight:700}.csat-filter-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.csat-resultbar{padding:12px 14px;margin-bottom:14px;display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}.csat-result-info{color:var(--text-soft);font-size:var(--fs-14);line-height:1.5}.csat-result-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.csat-loading-card,.csat-empty-card{padding:32px 16px;text-align:center}.csat-list{display:grid;gap:14px}.csat-item-card{padding:14px;min-width:0}.csat-item-head{display:grid;gap:8px;margin-bottom:12px}.csat-item-title-wrap{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:flex-start}.csat-item-title{font-size:var(--fs-16);font-weight:800;line-height:1.4;color:var(--text);word-break:break-word}.csat-item-subtitle{margin-top:4px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.5;word-break:break-word}.csat-item-time{font-size:var(--fs-12);line-height:1.45;color:var(--text-muted);white-space:nowrap}.csat-item-badges{display:flex;gap:8px;flex-wrap:wrap}.csat-item-grid{display:grid;grid-template-columns:1fr;gap:12px}.csat-meta-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:12px;min-width:0}.csat-meta-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;line-height:1.4;margin-bottom:8px;color:var(--text)}.csat-meta-line{color:var(--text-soft);font-size:var(--fs-13);line-height:1.6;margin-top:4px}.csat-wrap{word-break:break-word;overflow-wrap:anywhere;white-space:pre-wrap}.csat-item-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.csat-status-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid var(--border);white-space:nowrap;max-width:100%}.csat-badge-neutral{background:var(--surface);color:var(--text-soft)}.csat-badge-primary{background:var(--primary-soft);border-color:#bae6fd;color:var(--primary)}.csat-badge-success{background:var(--success-soft);border-color:#86efac;color:var(--success)}.csat-pagination-card{padding:12px 14px;margin-top:14px;display:flex;gap:12px;justify-content:space-between;align-items:center;flex-wrap:wrap}.csat-pagination-info{font-size:var(--fs-14);color:var(--text-soft)}.csat-pagination{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.csat-page-list{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.csat-page-btn{min-width:40px;min-height:40px;padding:0 10px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;cursor:pointer;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease}.csat-page-btn:hover:not(:disabled){background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.csat-page-btn.is-active{background:var(--primary);border-color:var(--primary);color:#fff}.csat-page-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.csat-image-placeholder{width:100%;min-height:220px;border:1px dashed var(--border-strong);border-radius:14px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);color:var(--text-muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:16px;font-size:var(--fs-13);line-height:1.5}.csat-image-placeholder svg{width:28px;height:28px;opacity:.8}.csat-ref-card{display:grid;gap:10px}.csat-ref-preview{width:100%;height:240px;object-fit:contain;border-radius:12px;border:1px solid var(--border);background:#fff;display:block;cursor:zoom-in;box-shadow:var(--shadow-xs)}.csat-preview-zoom{min-height:40px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;cursor:pointer;width:fit-content;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,box-shadow .18s ease}.csat-preview-zoom:hover{border-color:#7dd3fc;background:#f0f9ff;box-shadow:var(--shadow-sm)}.csat-lightbox{position:fixed;inset:0;background:#0f172ab8;z-index:1300;display:flex;align-items:center;justify-content:center;padding:20px}.csat-lightbox-dialog{width:min(1100px,100%);max-height:calc(100vh - 40px);background:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}.csat-lightbox-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.csat-lightbox-title{font-size:var(--fs-16);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csat-lightbox-body{padding:16px;overflow:auto;display:flex;align-items:center;justify-content:center;background:#f8fafc}.csat-lightbox-image{width:100%;max-width:100%;max-height:calc(100vh - 180px);object-fit:contain;border-radius:14px;background:#fff}@media(max-width:479px){.csat-page{padding:12px}.csat-topbar-actions{width:100%}.csat-topbar-actions .csat-btn,.csat-filter-actions .csat-btn,.csat-item-actions .csat-btn,.csat-pagination .csat-btn{flex:1 1 auto;min-width:0}.csat-page-list{width:100%}.csat-page-btn{flex:1 1 40px}.csat-item-time,.csat-status-badge{white-space:normal}.csat-lightbox,.csat-lightbox-head,.csat-lightbox-body{padding:12px}}@media(min-width:768px){.csat-page{padding:20px;font-size:var(--fs-15)}.csat-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.csat-filter-grid{grid-template-columns:160px 140px 160px 180px minmax(0,1fr) auto;align-items:end}.csat-item-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csat-item-head{grid-template-columns:minmax(0,1fr) auto;align-items:start}.csat-kpi-card,.csat-filter-card,.csat-item-card{padding:16px}}@media(min-width:1024px){.csat-page{padding:24px}.csat-kpi-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.csat-item-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:767px){.csat-ref-preview{height:220px}.csat-pagination-card{align-items:stretch}.csat-pagination{width:100%;justify-content:space-between}}@media(hover:none){.csat-btn:hover:not(:disabled),.csat-icon-btn:hover,.csat-preview-zoom:hover{background:inherit;border-color:inherit;box-shadow:var(--shadow-xs)}.csat-btn-primary:hover:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}.csat-btn-warning:hover:not(:disabled){background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csat-btn-success:hover:not(:disabled){background:var(--success-soft);border-color:#86efac;color:var(--success)}}@media(prefers-reduced-motion:reduce){.csat-page *,.csat-page *:before,.csat-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.csaic-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-soft: #e0f2fe;--warning: #9a3412;--warning-soft: #fff7ed;--success: #166534;--success-soft: #ecfdf5;--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius: 18px;min-height:100%;background:var(--bg);color:var(--text);padding:16px}.csaic-page *{box-sizing:border-box}.csaic-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csaic-title{font-size:var(--fs-28);font-weight:800;line-height:1.1;letter-spacing:-.02em}.csaic-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14)}.csaic-topbar-actions{display:flex;gap:10px;flex-wrap:wrap}.csaic-btn{min-height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none}.csaic-btn:disabled{opacity:.6;cursor:not-allowed}.csaic-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csaic-btn-warning{background:var(--warning-soft);border-color:#fdba74;color:var(--warning)}.csaic-btn-success{background:var(--success-soft);border-color:#86efac;color:var(--success)}.csaic-spin{animation:csaic-spin 1s linear infinite}@keyframes csaic-spin{to{transform:rotate(360deg)}}.csaic-kpi-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:14px}.csaic-kpi-card,.csaic-filter-card,.csaic-item-card,.csaic-loading-card,.csaic-empty-card,.csaic-meta-card,.csaic-modal{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius)}.csaic-kpi-card{padding:14px}.csaic-kpi-title{font-size:var(--fs-13);font-weight:700;color:var(--text-soft)}.csaic-kpi-value{margin-top:10px;font-size:var(--fs-34);line-height:1;font-weight:800}.csaic-kpi-neutral{background:linear-gradient(180deg,#fff,#f8fafc)}.csaic-kpi-primary{background:linear-gradient(180deg,#fff,#f0f9ff);border-color:#bae6fd}.csaic-kpi-warning{background:linear-gradient(180deg,#fff,#fff7ed);border-color:#fed7aa}.csaic-kpi-success{background:linear-gradient(180deg,#fff,#f0fdf4);border-color:#bbf7d0}.csaic-filter-card{padding:14px;margin-bottom:14px}.csaic-filter-head{margin-bottom:12px}.csaic-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800}.csaic-filter-grid,.csaic-form-grid{display:grid;grid-template-columns:1fr;gap:12px}.csaic-field{display:grid;gap:6px}.csaic-field-grow{min-width:0}.csaic-field label{font-size:var(--fs-12);font-weight:700;color:#334155}.csaic-field input,.csaic-field select{width:100%;min-height:44px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:10px 12px;font:inherit;color:var(--text);outline:none}.csaic-field input:focus,.csaic-field select:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.csaic-filter-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.csaic-loading-card,.csaic-empty-card{padding:32px 16px;text-align:center}.csaic-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csaic-spin 1s linear infinite}.csaic-loading-title{font-size:var(--fs-18);font-weight:800}.csaic-loading-subtitle,.csaic-empty-text{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13)}.csaic-list{display:grid;gap:14px}.csaic-item-card{padding:14px}.csaic-item-head{display:grid;gap:8px;margin-bottom:12px}.csaic-item-title-wrap{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:flex-start}.csaic-item-title{font-size:var(--fs-16);font-weight:800}.csaic-item-subtitle{margin-top:4px;color:var(--text-soft);font-size:var(--fs-13)}.csaic-item-time{font-size:var(--fs-12);color:var(--text-muted)}.csaic-item-badges{display:flex;gap:8px;flex-wrap:wrap}.csaic-item-grid{display:grid;grid-template-columns:1fr;gap:12px}.csaic-meta-card{padding:12px}.csaic-meta-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;margin-bottom:8px}.csaic-meta-line{color:var(--text-soft);font-size:var(--fs-13);line-height:1.5;margin-top:4px}.csaic-item-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.csaic-status-badge{border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:700;border:1px solid var(--border);white-space:nowrap}.csaic-badge-neutral{background:var(--surface);color:var(--text-soft)}.csaic-badge-primary{background:var(--primary-soft);border-color:#bae6fd;color:var(--primary)}.csaic-badge-success{background:var(--success-soft);border-color:#86efac;color:var(--success)}.csaic-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:16px;z-index:1100}.csaic-modal{width:min(760px,100%);max-height:calc(100vh - 32px);overflow:auto}.csaic-modal-head,.csaic-modal-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--border)}.csaic-modal-actions{border-bottom:0;border-top:1px solid var(--border);justify-content:flex-end}.csaic-modal-title{font-size:var(--fs-20);font-weight:800}.csaic-modal-body{padding:16px}.csaic-check-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}.csaic-check-row-full{grid-column:1 / -1}.csaic-check-row label{display:inline-flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:700;color:var(--text-soft)}@media(min-width:768px){.csaic-page{padding:20px}.csaic-kpi-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.csaic-filter-grid{grid-template-columns:180px 1fr auto;align-items:end}.csaic-item-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csaic-item-head{grid-template-columns:1fr auto;align-items:start}.csaic-form-grid{grid-template-columns:1fr 1fr}}.csti-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--surface-2: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0b6fa4;--primary-hover: #095d8a;--primary-soft: #e0f2fe;--danger: #b91c1c;--danger-soft: #fef2f2;--warning: #9a3412;--warning-soft: #fff7ed;--success: #166534;--success-soft: #ecfdf5;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .18);--radius: 18px;--radius-md: 14px;--radius-sm: 12px;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-20: 1.25rem;--fs-24: 1.5rem;--fs-28: 1.75rem;--fs-32: 2rem;min-height:100%;background:var(--bg);color:var(--text);padding:16px;font-family:var(--pps-font-main);font-size:var(--fs-14);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.csti-page *,.csti-page *:before,.csti-page *:after{box-sizing:border-box}.csti-page button,.csti-page input,.csti-page select,.csti-page textarea{font:inherit;color:inherit}.csti-page img,.csti-page svg{display:block;max-width:100%}.csti-page a{color:inherit}.csti-page :focus-visible{outline:2px solid rgba(11,111,164,.22);outline-offset:2px}.csti-page ::selection{background:#0b6fa424}.csti-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.csti-topbar-left{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap;min-width:0}.csti-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.csti-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csti-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.55}.csti-btn{min-height:42px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease;box-shadow:var(--shadow-xs);-webkit-tap-highlight-color:transparent}.csti-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #0f172a14;border-color:var(--border-strong)}.csti-btn:active:not(:disabled){transform:translateY(1px)}.csti-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.csti-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.csti-btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.csti-btn-danger{background:var(--danger-soft);border-color:#fecaca;color:var(--danger)}.csti-file-btn{position:relative;overflow:hidden}.csti-spin{animation:csti-spin 1s linear infinite}@keyframes csti-spin{to{transform:rotate(360deg)}}.csti-hero-card,.csti-filter-card,.csti-panel,.csti-loading-card,.csti-item-card,.csti-modal,.csti-image-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius)}.csti-hero-card{padding:16px;margin-bottom:14px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:flex-start}.csti-doc-no{font-size:clamp(1.25rem,1rem + .8vw,1.75rem);font-weight:800;line-height:1.2;color:var(--text);word-break:break-word}.csti-hero-name{margin-top:6px;font-size:clamp(1rem,.95rem + .5vw,1.25rem);font-weight:800;line-height:1.4;color:var(--text);word-break:break-word}.csti-hero-sub{margin-top:6px;color:var(--text-soft);font-size:var(--fs-13);line-height:1.5;word-break:break-word}.csti-hero-stats{display:grid;gap:8px}.csti-stat-chip{border-radius:999px;padding:8px 12px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid #bae6fd;background:var(--primary-soft);color:var(--primary);white-space:nowrap;max-width:100%}.csti-filter-card{padding:14px;margin-bottom:14px}.csti-filter-head{margin-bottom:12px}.csti-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-15);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csti-filter-grid{display:grid;grid-template-columns:1fr;gap:12px}.csti-field{display:grid;gap:6px;min-width:0}.csti-field-grow,.csti-field-grow2{min-width:0}.csti-field-full{grid-column:1 / -1}.csti-field label{font-size:var(--fs-12);font-weight:700;line-height:1.4;color:#334155}.csti-field input,.csti-field select,.csti-field textarea{width:100%;min-height:46px;border:1px solid #cbd5e1;background:#fff;border-radius:var(--radius-sm);padding:10px 12px;font-size:var(--fs-14);line-height:1.4;color:var(--text);outline:none;transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.csti-field textarea{min-height:96px;resize:vertical;padding-top:12px}.csti-field input::placeholder,.csti-field textarea::placeholder{color:#94a3b8}.csti-field input:focus,.csti-field select:focus,.csti-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0369a11f}.csti-search-wrap{position:relative}.csti-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.csti-search-wrap input{padding-left:38px}.csti-filter-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.csti-loading-card{text-align:center;padding:32px 16px}.csti-loading-spinner{width:42px;height:42px;margin:0 auto 12px;border-radius:999px;border:4px solid #dbeafe;border-top-color:var(--primary);animation:csti-spin 1s linear infinite}.csti-loading-title{font-size:var(--fs-18);font-weight:800;line-height:1.3;color:var(--text)}.csti-loading-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.55}.csti-panel{padding:14px;margin-bottom:14px}.csti-panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.csti-panel-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.csti-count-chip,.csti-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-size:var(--fs-12);font-weight:700;line-height:1.2;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);max-width:100%}.csti-badge-soft{background:var(--primary-soft);border-color:#bae6fd;color:var(--primary)}.csti-empty,.csti-empty-lite{border:1px dashed var(--border-strong);background:var(--surface);border-radius:var(--radius-md);padding:16px;color:var(--text-muted);font-size:var(--fs-13);line-height:1.6}.csti-empty-lite{text-align:center}.csti-item-list{display:grid;gap:14px}.csti-item-card{padding:14px;min-width:0}.csti-item-head{display:grid;gap:8px;margin-bottom:12px}.csti-item-title-wrap{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:flex-start}.csti-item-title{font-size:var(--fs-16);font-weight:800;line-height:1.4;color:var(--text);word-break:break-word}.csti-badges{display:flex;gap:8px;flex-wrap:wrap}.csti-item-seq{font-size:var(--fs-12);line-height:1.45;color:var(--text-muted)}.csti-item-grid{display:grid;grid-template-columns:1fr;gap:12px}.csti-meta-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;min-width:0}.csti-meta-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-13);font-weight:800;line-height:1.4;margin-bottom:8px;color:var(--text)}.csti-meta-line{color:var(--text-soft);font-size:var(--fs-13);line-height:1.6;margin-top:4px}.csti-wrap{word-break:break-word;overflow-wrap:anywhere;white-space:pre-wrap}.csti-item-footer{margin-top:14px;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:center}.csti-item-time{color:var(--text-muted);font-size:var(--fs-12);line-height:1.45}.csti-item-actions{display:flex;gap:10px;flex-wrap:wrap}.csti-ref-card{display:grid;gap:10px}.csti-image-placeholder{width:100%;min-height:220px;border:1px dashed var(--border-strong);border-radius:14px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);color:var(--text-muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:16px;font-size:var(--fs-13);line-height:1.5}.csti-image-placeholder svg{width:28px;height:28px;opacity:.8}.csti-ref-preview{width:100%;height:240px;object-fit:contain;border-radius:12px;border:1px solid var(--border);background:#fff;display:block;cursor:zoom-in}.csti-image-preview-inner{width:100%;display:grid;gap:10px}.csti-preview-zoom{min-height:40px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;cursor:pointer;width:fit-content;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,box-shadow .18s ease}.csti-preview-zoom:hover:not(:disabled){border-color:#7dd3fc;background:#f0f9ff;box-shadow:0 6px 16px #0f172a14}.csti-preview-zoom-modal{justify-self:start}.csti-modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1200}.csti-modal{width:min(1160px,100%);max-height:calc(100vh - 40px);overflow:auto;border-radius:22px;box-shadow:var(--shadow-lg)}.csti-modal-head{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.csti-modal-title{font-size:clamp(1.25rem,1.05rem + .8vw,1.5rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);word-break:break-word}.csti-modal-subtitle{margin-top:8px;color:var(--text-muted);font-size:var(--fs-14);line-height:1.55}.csti-icon-btn{min-width:42px;min-height:42px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease;box-shadow:var(--shadow-xs)}.csti-icon-btn:hover{background:var(--surface);border-color:var(--border-strong);box-shadow:0 6px 16px #0f172a14}.csti-icon-btn:active{transform:translateY(1px)}.csti-modal-body{padding:20px;display:grid;gap:18px}.csti-form-grid{display:grid;grid-template-columns:1fr;gap:14px;align-items:start}.csti-check-field{display:flex;align-items:end}.csti-check-field label{min-height:46px;width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);padding:10px 12px;display:inline-flex;align-items:center;gap:10px;font-size:var(--fs-14);font-weight:700;line-height:1.45;color:var(--text);cursor:pointer}.csti-check-field input[type=checkbox]{width:18px;height:18px;margin:0;accent-color:var(--primary);flex:0 0 auto}.csti-image-card{padding:16px;background:var(--surface-2)}.csti-image-card-head{margin-bottom:12px}.csti-image-grid{display:grid;grid-template-columns:1fr;gap:12px;align-items:stretch}.csti-image-actions{display:grid;gap:10px;align-content:start}.csti-file-name{color:var(--text-soft);font-size:var(--fs-13);line-height:1.5;word-break:break-word}.csti-image-preview-box{min-height:320px;border:1px solid var(--border);border-radius:16px;background:#fff;padding:14px;display:flex;align-items:center;justify-content:center}.csti-modal-preview{width:100%;max-height:360px;min-height:260px;object-fit:contain;border-radius:12px;background:#fff;display:block;cursor:zoom-in}.csti-modal-footer{padding:16px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;position:sticky;bottom:0;background:#fffffff5;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.csti-lightbox{position:fixed;inset:0;background:#0f172ab8;z-index:1300;display:flex;align-items:center;justify-content:center;padding:20px}.csti-lightbox-dialog{width:min(1100px,100%);max-height:calc(100vh - 40px);background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 24px 60px #0f172a47;display:flex;flex-direction:column}.csti-lightbox-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.csti-lightbox-title{font-size:var(--fs-16);font-weight:800;line-height:1.35;color:var(--text);word-break:break-word}.csti-lightbox-body{padding:16px;overflow:auto;display:flex;align-items:center;justify-content:center;background:#f8fafc}.csti-lightbox-image{width:100%;max-width:100%;max-height:calc(100vh - 180px);object-fit:contain;border-radius:14px;background:#fff}@media(min-width:768px){.csti-page{padding:20px;font-size:var(--fs-15)}.csti-filter-grid{grid-template-columns:200px 200px minmax(0,1fr) auto;align-items:end}.csti-item-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.csti-item-head{grid-template-columns:minmax(0,1fr) auto;align-items:start}.csti-form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.csti-field-grow2{grid-column:span 2}.csti-field-full{grid-column:1 / -1}.csti-image-grid{grid-template-columns:360px minmax(0,1fr);align-items:stretch}}@media(min-width:1100px){.csti-modal{width:min(1240px,100%)}.csti-form-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:14px}.csti-form-grid .csti-field:nth-child(1){grid-column:span 3}.csti-form-grid .csti-field:nth-child(2){grid-column:span 3}.csti-form-grid .csti-field:nth-child(3){grid-column:span 3}.csti-form-grid .csti-field:nth-child(4){grid-column:span 3}.csti-form-grid .csti-field:nth-child(5){grid-column:span 4}.csti-form-grid .csti-field:nth-child(6){grid-column:span 4}.csti-form-grid .csti-field:nth-child(7){grid-column:span 4}.csti-form-grid .csti-field:nth-child(8){grid-column:1 / -1}.csti-form-grid .csti-field:nth-child(9){grid-column:span 3}.csti-form-grid .csti-field:nth-child(10){grid-column:span 3}.csti-form-grid .csti-field:nth-child(11){grid-column:span 3}.csti-form-grid .csti-field:nth-child(12){grid-column:span 3}.csti-form-grid .csti-check-field:nth-child(13){grid-column:span 6}.csti-form-grid .csti-check-field:nth-child(14){grid-column:span 6}}@media(min-width:1024px){.csti-item-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:767px){.csti-page{padding:12px}.csti-modal-backdrop{padding:10px}.csti-modal{max-height:calc(100vh - 20px);border-radius:18px}.csti-modal-head,.csti-modal-body,.csti-modal-footer{padding-left:14px;padding-right:14px}.csti-item-actions,.csti-topbar-actions,.csti-filter-actions,.csti-panel-actions{width:100%}.csti-item-actions>*,.csti-topbar-actions>*,.csti-filter-actions>*,.csti-panel-actions>*{flex:1 1 auto;min-width:0}.csti-ref-preview{height:220px}.csti-modal-preview{min-height:220px}.csti-lightbox,.csti-lightbox-head,.csti-lightbox-body{padding:12px}}@media(hover:none){.csti-btn:hover:not(:disabled),.csti-icon-btn:hover,.csti-material-item:hover,.csti-preview-zoom:hover:not(:disabled){transform:none;box-shadow:var(--shadow-xs)}.csti-btn-primary:hover:not(:disabled){background:var(--primary);border-color:var(--primary)}.csti-material-item:hover{background:#fff;border-color:var(--border)}.csti-preview-zoom:hover:not(:disabled){border-color:var(--border);background:#fff}}@media(prefers-reduced-motion:reduce){.csti-page *,.csti-page *:before,.csti-page *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.cspd-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-strong: #075985;--primary-soft: #e0f2fe;--info: #1d4ed8;--info-soft: #eff6ff;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--success: #166534;--success-soft: #ecfdf5;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);--radius-sm: 12px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 22px;min-height:100%;background:var(--bg);color:var(--text);padding:16px;font-family:var(--pps-font-main)}.cspd-page *,.cspd-page *:before,.cspd-page *:after{box-sizing:border-box}.cspd-page button,.cspd-page input,.cspd-page select,.cspd-page textarea{font:inherit;color:inherit}.cspd-page a{color:inherit;text-decoration:none}.cspd-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.cspd-title{margin:0;font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em}.cspd-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-15);line-height:1.55}.cspd-topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.cspd-btn,.cspd-mini-btn{min-height:42px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease}.cspd-btn:hover,.cspd-mini-btn:hover{background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.cspd-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.cspd-mini-btn{min-height:36px;padding:8px 12px}.cspd-spin{animation:cspd-spin 1s linear infinite}@keyframes cspd-spin{to{transform:rotate(360deg)}}.cspd-summary-row,.cspd-card-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:14px}.cspd-summary-card,.cspd-kpi-card,.cspd-panel,.cspd-loading-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius-lg)}.cspd-summary-card,.cspd-kpi-card{padding:14px}.cspd-summary-label{display:flex;align-items:center;gap:8px;color:var(--text-soft);font-size:var(--fs-14);font-weight:700}.cspd-summary-value{margin-top:8px;font-size:clamp(1.375rem,1.05rem + 1vw,1.85rem);font-weight:800;line-height:1.1}.cspd-kpi-title{color:var(--text-soft);font-size:var(--fs-14);font-weight:700}.cspd-kpi-value{margin-top:8px;font-size:clamp(1.5rem,1.15rem + 1vw,2rem);font-weight:800;line-height:1.1}.cspd-kpi-hint{margin-top:8px;color:var(--text-muted);font-size:var(--fs-13)}.cspd-card-primary{background:linear-gradient(180deg,#f8fdff 0%,var(--card) 100%);border-color:#bae6fd}.cspd-card-success{background:linear-gradient(180deg,#f7fff9 0%,var(--card) 100%);border-color:#bbf7d0}.cspd-card-warning{background:linear-gradient(180deg,#fffaf5 0%,var(--card) 100%);border-color:#fed7aa}.cspd-card-danger{background:linear-gradient(180deg,#fff8f8 0%,var(--card) 100%);border-color:#fecaca}.cspd-card-info{background:linear-gradient(180deg,#f8fbff 0%,var(--card) 100%);border-color:#bfdbfe}.cspd-card-neutral{background:linear-gradient(180deg,#ffffff 0%,var(--card) 100%)}.cspd-loading-card{min-height:260px;display:grid;place-items:center;text-align:center;padding:24px}.cspd-loading-spinner{width:38px;height:38px;border-radius:999px;border:3px solid #dbeafe;border-top-color:var(--primary);animation:cspd-spin .9s linear infinite;margin:0 auto 12px}.cspd-loading-title{font-size:var(--fs-16);font-weight:800}.cspd-loading-subtitle{margin-top:4px;color:var(--text-muted);font-size:var(--fs-14)}.cspd-main-grid{display:grid;grid-template-columns:1fr;gap:14px}.cspd-panel{padding:14px}.cspd-panel-full{grid-column:1 / -1}.cspd-panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.cspd-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-16);font-weight:800}.cspd-link{color:var(--primary);font-size:var(--fs-14);font-weight:700}.cspd-list{display:grid;gap:10px}.cspd-list-item{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;border:1px solid var(--border);border-radius:14px;padding:12px;background:#fff}.cspd-list-main{min-width:0;flex:1}.cspd-list-title-row{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:8px}.cspd-list-title{font-size:var(--fs-15);font-weight:800}.cspd-list-sub{color:var(--text-soft);font-size:var(--fs-14);line-height:1.55}.cspd-list-actions{display:flex;flex-shrink:0;align-items:center}.cspd-status-badge{display:inline-flex;align-items:center;min-height:28px;padding:4px 10px;border-radius:999px;background:var(--info-soft);color:var(--info);font-size:var(--fs-13);font-weight:800}.cspd-status-danger{background:var(--danger-soft);color:var(--danger)}.cspd-empty{border:1px dashed var(--border-strong);background:var(--surface);color:var(--text-muted);border-radius:14px;padding:18px;text-align:center;font-size:var(--fs-15)}.cspd-table-wrap{width:100%;overflow:auto;border:1px solid var(--border);border-radius:14px}.cspd-table{width:100%;border-collapse:collapse;min-width:760px;background:#fff}.cspd-table th,.cspd-table td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;font-size:var(--fs-14)}.cspd-table th{background:#f8fafc;color:var(--text-soft);font-weight:800}@media(min-width:700px){.cspd-summary-row,.cspd-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.cspd-summary-row{grid-template-columns:repeat(5,minmax(0,1fr))}.cspd-card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.cspd-main-grid{grid-template-columns:1.1fr .9fr}}.cspl-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-hover: #075985;--primary-soft: #e0f2fe;--info: #1d4ed8;--info-soft: #eff6ff;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--success: #166534;--success-soft: #ecfdf5;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);min-height:100%;background:var(--bg);color:var(--text);padding:16px;font-family:var(--pps-font-main)}.cspl-page *,.cspl-page *:before,.cspl-page *:after{box-sizing:border-box}.cspl-page button,.cspl-page input,.cspl-page select,.cspl-page textarea{font:inherit;color:inherit}.cspl-page a{color:inherit;text-decoration:none}.cspl-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.cspl-title{font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em}.cspl-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-15);line-height:1.55}.cspl-topbar-actions,.cspl-filter-actions,.cspl-pagination{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.cspl-btn,.cspl-mini-btn{min-height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;line-height:1.2;padding:10px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;box-shadow:var(--shadow-xs);transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .18s ease}.cspl-btn:hover,.cspl-mini-btn:hover{background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.cspl-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.cspl-btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.cspl-btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.cspl-mini-btn{min-height:36px;padding:8px 12px}.cspl-spin{animation:cspl-spin 1s linear infinite}@keyframes cspl-spin{to{transform:rotate(360deg)}}.cspl-summary-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:14px}.cspl-summary-card,.cspl-filter-card,.cspl-list-card{background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}.cspl-summary-card{padding:14px}.cspl-summary-label{display:flex;align-items:center;gap:8px;color:var(--text-soft);font-size:var(--fs-14);font-weight:700}.cspl-summary-value{margin-top:8px;font-size:clamp(1.375rem,1.05rem + 1vw,1.85rem);font-weight:800;line-height:1.1}.cspl-filter-card,.cspl-list-card{padding:14px;margin-bottom:14px}.cspl-filter-head,.cspl-list-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.cspl-section-title{display:flex;align-items:center;gap:8px;font-size:var(--fs-16);font-weight:800}.cspl-page-info,.cspl-pagination-text{color:var(--text-muted);font-size:var(--fs-14);font-weight:600}.cspl-filter-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px}.cspl-field{display:grid;gap:6px}.cspl-field>span{font-size:var(--fs-14);font-weight:700;color:var(--text-soft)}.cspl-field input,.cspl-field select{min-height:42px;width:100%;border-radius:12px;border:1px solid var(--border);background:#fff;padding:10px 12px;outline:none}.cspl-field input:focus,.cspl-field select:focus{border-color:#7dd3fc;box-shadow:0 0 0 3px #0ea5e91f}.cspl-filter-actions{margin-top:12px}.cspl-loading,.cspl-empty{min-height:180px;display:grid;place-items:center;text-align:center;color:var(--text-muted)}.cspl-loading-spinner{width:38px;height:38px;border-radius:999px;border:3px solid #dbeafe;border-top-color:var(--primary);animation:cspl-spin .9s linear infinite;margin:0 auto 12px}.cspl-table-wrap{width:100%;overflow:auto;border:1px solid var(--border);border-radius:14px}.cspl-table{width:100%;min-width:1100px;border-collapse:collapse;background:#fff}.cspl-table th,.cspl-table td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;font-size:var(--fs-14)}.cspl-table th{background:#f8fafc;color:var(--text-soft);font-weight:800}.cspl-badge{display:inline-flex;align-items:center;min-height:28px;padding:4px 10px;border-radius:999px;font-size:var(--fs-13);font-weight:800}.cspl-badge-primary{background:var(--primary-soft);color:var(--primary)}.cspl-badge-info{background:var(--info-soft);color:var(--info)}.cspl-badge-warning{background:var(--warning-soft);color:var(--warning)}.cspl-badge-success{background:var(--success-soft);color:var(--success)}.cspl-badge-danger{background:var(--danger-soft);color:var(--danger)}.cspl-badge-neutral{background:#f1f5f9;color:#475569}@media(min-width:700px){.cspl-summary-grid,.cspl-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1100px){.cspl-summary-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.cspl-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.cspd2-page{--bg: #f8fafc;--card: #ffffff;--surface: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-hover: #075985;--primary-soft: #e0f2fe;--info: #1d4ed8;--info-soft: #eff6ff;--warning: #9a3412;--warning-soft: #fff7ed;--danger: #b91c1c;--danger-soft: #fef2f2;--success: #166534;--success-soft: #ecfdf5;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .05);--shadow-sm: 0 6px 16px rgba(15, 23, 42, .05);--shadow: 0 10px 24px rgba(15, 23, 42, .06);min-height:100%;background:var(--bg);color:var(--text);padding:16px;font-family:var(--pps-font-main)}.cspd2-page *,.cspd2-page *:before,.cspd2-page *:after{box-sizing:border-box}.cspd2-page a{color:inherit;text-decoration:none}.cspd2-page button,.cspd2-page input,.cspd2-page select,.cspd2-page textarea{font:inherit;color:inherit}.cspd2-topbar,.cspd2-section-head,.cspd2-topbar-left,.cspd2-topbar-actions,.cspd2-section-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.cspd2-topbar{justify-content:space-between;align-items:flex-start;margin-bottom:16px}.cspd2-title{font-size:clamp(1.5rem,1.15rem + 1.4vw,2rem);font-weight:800;line-height:1.15;letter-spacing:-.02em}.cspd2-subtitle{margin-top:6px;color:var(--text-muted);font-size:var(--fs-15);line-height:1.55}.cspd2-btn{min-height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:var(--fs-14);font-weight:700;padding:10px 14px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;box-shadow:var(--shadow-xs)}.cspd2-btn:hover{background:#f8fafc;border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.cspd2-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.cspd2-btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.cspd2-btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.cspd2-spin{animation:cspd2-spin 1s linear infinite}@keyframes cspd2-spin{to{transform:rotate(360deg)}}.cspd2-loading-card,.cspd2-card{background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}.cspd2-loading-card{min-height:260px;display:grid;place-items:center;text-align:center;padding:24px}.cspd2-loading-spinner{width:38px;height:38px;border-radius:999px;border:3px solid #dbeafe;border-top-color:var(--primary);animation:cspd2-spin .9s linear infinite;margin:0 auto 12px}.cspd2-loading-title{font-size:var(--fs-16);font-weight:800}.cspd2-header-grid,.cspd2-main-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}.cspd2-card{padding:14px}.cspd2-card-title{display:flex;align-items:center;gap:8px;color:var(--text-soft);font-size:var(--fs-15);font-weight:800;margin-bottom:10px}.cspd2-doc-no{font-size:var(--fs-18);font-weight:800;margin-bottom:10px}.cspd2-meta{color:var(--text-soft);font-size:var(--fs-14);line-height:1.6}.cspd2-inline-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.cspd2-badge{display:inline-flex;align-items:center;min-height:28px;padding:4px 10px;border-radius:999px;font-size:var(--fs-13);font-weight:800}.cspd2-badge-primary{background:var(--primary-soft);color:var(--primary)}.cspd2-badge-info{background:var(--info-soft);color:var(--info)}.cspd2-badge-warning{background:var(--warning-soft);color:var(--warning)}.cspd2-badge-success{background:var(--success-soft);color:var(--success)}.cspd2-badge-danger{background:var(--danger-soft);color:var(--danger)}.cspd2-badge-neutral{background:#f1f5f9;color:#475569}.cspd2-empty{border:1px dashed var(--border-strong);background:var(--surface);color:var(--text-muted);border-radius:14px;padding:18px;text-align:center}.cspd2-round-list,.cspd2-item-list{display:grid;gap:12px}.cspd2-round-item,.cspd2-item-card{border:1px solid var(--border);border-radius:14px;padding:12px;background:#fff}.cspd2-round-item{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.cspd2-round-title,.cspd2-item-title{font-size:var(--fs-15);font-weight:800}.cspd2-round-meta,.cspd2-item-sub{color:var(--text-soft);font-size:var(--fs-14);line-height:1.55}.cspd2-item-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:10px}.cspd2-field{display:grid;gap:6px}.cspd2-field span{font-size:var(--fs-14);font-weight:700;color:var(--text-soft)}.cspd2-field input,.cspd2-field select,.cspd2-field textarea{width:100%;min-height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;padding:10px 12px;outline:none}.cspd2-field textarea{min-height:90px;resize:vertical}.cspd2-field input:focus,.cspd2-field select:focus,.cspd2-field textarea:focus{border-color:#7dd3fc;box-shadow:0 0 0 3px #0ea5e91f}.cspd2-field-full{grid-column:1 / -1}.mono{font-family:var(--pps-font-mono)}@media(min-width:700px){.cspd2-header-grid,.cspd2-item-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1100px){.cspd2-header-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.cspd2-main-grid{grid-template-columns:.9fr 1.1fr}}.cspc-page{--bg: #f8fafc;--card: #ffffff;--card-2: #f9fafb;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-soft: #475569;--text-muted: #64748b;--primary: #0369a1;--primary-hover: #0284c7;--good: #166534;--warn: #b45309;--danger: #b91c1c;--shadow: 0 10px 30px rgba(15, 23, 42, .08);min-height:100%;padding:16px;background:var(--bg);color:var(--text)}.cspc-topbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap;margin-bottom:16px}.cspc-topbar h1{margin:0;font-size:clamp(24px,3vw,32px);font-weight:800}.cspc-topbar p{margin:6px 0 0;color:var(--text-soft);line-height:1.5}.cspc-topbar-actions{display:flex;gap:10px;flex-wrap:wrap}.cspc-card{background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:16px;margin-bottom:16px}.cspc-filter-card{position:relative}.cspc-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.cspc-section-head h3{margin:0;font-size:var(--fs-18);font-weight:800}.cspc-section-head p{margin:4px 0 0;color:var(--text-soft);font-size:var(--fs-14)}.cspc-filter-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.cspc-field{display:flex;flex-direction:column;gap:6px}.cspc-field-wide{grid-column:span 2}.cspc-field span{font-size:var(--fs-13);font-weight:700;color:var(--text-soft)}.cspc-field input,.cspc-field select{width:100%;min-height:42px;border:1px solid var(--border-strong);border-radius:12px;background:#fff;color:var(--text);padding:10px 12px;font-size:var(--fs-14);outline:none}.cspc-field input:focus,.cspc-field select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0369a124}.cspc-filter-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.cspc-btn{display:inline-flex;align-items:center;gap:8px;min-height:42px;border-radius:12px;border:1px solid transparent;padding:0 14px;font-size:var(--fs-14);font-weight:700;cursor:pointer}.cspc-btn.primary{background:var(--primary);color:#fff}.cspc-btn.primary:hover{background:var(--primary-hover)}.cspc-btn.ghost{background:#fff;color:var(--text);border-color:var(--border-strong)}.cspc-btn:disabled{opacity:.6;cursor:not-allowed}.cspc-title-strip{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}.cspc-chip{display:inline-flex;flex-direction:column;gap:3px;min-width:180px;padding:10px 12px;border:1px solid var(--border);border-radius:14px;background:var(--card);box-shadow:var(--shadow)}.cspc-chip .label{font-size:var(--fs-12);font-weight:700;color:var(--text-muted)}.cspc-chip strong{font-size:var(--fs-15)}.cspc-metric-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-bottom:16px}.cspc-metric-card{display:flex;gap:12px;align-items:flex-start;border-radius:18px;border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow);padding:14px}.cspc-metric-card.good{border-color:#16653440;background:#16a34a0d}.cspc-metric-card.warn{border-color:#b4530940;background:#f59e0b14}.cspc-metric-card.danger{border-color:#b91c1c38;background:#ef444414}.cspc-metric-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:#0284c71f;color:var(--primary);font-size:var(--fs-18);flex:0 0 auto}.cspc-metric-body{min-width:0}.cspc-metric-title{font-size:var(--fs-13);font-weight:700;color:var(--text-soft)}.cspc-metric-value{font-size:var(--fs-24);line-height:1.2;font-weight:800;margin-top:4px;word-break:break-word}.cspc-metric-helper{font-size:var(--fs-12);color:var(--text-muted);margin-top:4px;line-height:1.4}.cspc-chart-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:16px}.cspc-chart-card{overflow:hidden}.cspc-chart-wrap{width:100%;height:340px}.cspc-table-wrap{width:100%;overflow:auto}.cspc-table{width:100%;min-width:1100px;border-collapse:separate;border-spacing:0}.cspc-table thead th{position:sticky;top:0;z-index:1;background:#f8fafc;color:var(--text-soft);font-size:var(--fs-13);font-weight:800;text-align:left;padding:12px 10px;border-bottom:1px solid var(--border)}.cspc-table tbody td{font-size:var(--fs-13);padding:10px;border-bottom:1px solid var(--border);vertical-align:top}.cspc-table tbody tr:hover{background:#f8fbff}.cspc-empty{text-align:center;color:var(--text-muted);padding:24px 12px!important}@media(max-width:1400px){.cspc-metric-grid,.cspc-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.cspc-field-wide{grid-column:span 3}}@media(max-width:900px){.cspc-page{padding:12px}.cspc-metric-grid,.cspc-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cspc-field-wide{grid-column:span 2}.cspc-chip{min-width:140px}}@media(max-width:640px){.cspc-metric-grid,.cspc-filter-grid{grid-template-columns:1fr}.cspc-field-wide{grid-column:span 1}.cspc-metric-value{font-size:var(--fs-20)}.cspc-chart-wrap{height:300px}}.ro-page{padding:16px;background:#f8fafc;min-height:100%;color:#0f172a}.ro-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:16px}.ro-header h2{margin:0;font-size:var(--fs-28);font-weight:800}.ro-header p{margin:4px 0 0;color:#475569}.ro-btn-refresh{border:1px solid #cbd5e1;background:#fff;color:#0f172a;padding:10px 14px;border-radius:12px;font-weight:700;cursor:pointer}.ro-btn-refresh:hover{background:#f1f5f9}.ro-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.ro-summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:14px 16px;box-shadow:0 8px 24px #0f172a0f}.ro-summary-card.highlight{border-color:#38bdf8;background:linear-gradient(180deg,#f0f9ff,#fff)}.ro-summary-label{font-size:var(--fs-13);font-weight:700;color:#64748b;margin-bottom:6px}.ro-summary-value{font-size:var(--fs-24);font-weight:800;color:#0f172a}.ro-panel{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:16px;box-shadow:0 10px 30px #0f172a0f}.ro-filters{display:grid;grid-template-columns:1.5fr 180px 180px;gap:12px;margin-bottom:16px}.ro-search{position:relative}.ro-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#64748b}.ro-search input,.ro-filters select{width:100%;border:1px solid #cbd5e1;background:#fff;border-radius:12px;min-height:44px;padding:10px 12px;font-size:var(--fs-14);color:#0f172a;outline:none}.ro-search input{padding-left:36px}.ro-search input:focus,.ro-filters select:focus{border-color:#0284c7;box-shadow:0 0 0 3px #0284c71f}.ro-error{margin-bottom:12px;padding:10px 12px;border-radius:12px;background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;font-weight:600}.ro-table-wrap{position:relative;overflow:auto;border:1px solid #e2e8f0;border-radius:14px}.ro-table{width:100%;min-width:1200px;border-collapse:collapse;background:#fff}.ro-table thead th{position:sticky;top:0;z-index:1;background:#eaf3fb;color:#0f172a;text-align:left;font-size:var(--fs-13);font-weight:800;padding:12px 10px;border-bottom:1px solid #cbd5e1;white-space:nowrap}.ro-table tbody td{padding:10px;font-size:var(--fs-14);border-bottom:1px solid #e2e8f0;vertical-align:top}.ro-table tbody tr:hover{background:#f8fafc}.ro-mono{font-family:var(--pps-font-mono)}.ro-num{text-align:right;font-variant-numeric:tabular-nums}.ro-balance{font-weight:800;color:#0369a1}.ro-info{padding:16px;text-align:center;color:#64748b;font-weight:700}@media(max-width:1024px){.ro-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.ro-filters{grid-template-columns:1fr 1fr}.ro-search{grid-column:1 / -1}}@media(max-width:640px){.ro-page{padding:12px}.ro-summary,.ro-filters{grid-template-columns:1fr}.ro-header h2{font-size:var(--fs-22)}.ro-summary-value{font-size:var(--fs-20)}}
