:root{--board-bg: #eef1f4;--ink: #2b2f36;--line: #b9c0c9;--muted: #8a929c}*{box-sizing:border-box}body{margin:0}.mockup-root{min-height:100vh;background:var(--board-bg);color:var(--ink);font-family:system-ui,-apple-system,Segoe UI,Apple SD Gothic Neo,sans-serif}.mockup-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:12px 20px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}.mockup-brand{font-weight:700}.mockup-tag{margin-left:8px;font-weight:400;font-size:12px;color:var(--muted);background:#f1f3f6;border:1px dashed var(--line);padding:2px 8px;border-radius:10px}.mockup-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.screen-jumper{display:flex;gap:6px;flex-wrap:wrap}.mockup-tools{display:flex;align-items:center;gap:6px;padding-left:12px;border-left:1px solid var(--line)}.tool-btn{border:1px solid var(--line);background:#fff;color:#5b636d;border-radius:8px;padding:4px 10px;font-size:12px;cursor:pointer}.tool-btn:hover{background:#f1f3f6}.tool-file{display:none}.jump{border:1px solid var(--line);background:#fff;color:#5b636d;border-radius:8px;padding:4px 10px;font-size:12px;cursor:pointer}.jump:hover{background:#f1f3f6}.jump--active{background:#2b2f36;color:#fff;border-color:#2b2f36}.jump--ext{border-style:dashed;color:#8a5a00}.jump--ext.jump--active{background:#b07a00;border-color:#b07a00;color:#fff}.jump--index{font-weight:700;color:#2b6cf6;border-color:#b9c8ef}.jump--index.jump--active{background:#2b6cf6;border-color:#2b6cf6;color:#fff}.mockup-stage{display:grid;grid-template-columns:minmax(180px,260px) minmax(420px,720px) minmax(180px,260px);gap:20px;justify-content:center;align-items:start;padding:26px 20px 60px}@media (max-width: 1100px){.mockup-stage{grid-template-columns:1fr;max-width:720px;margin:0 auto}}.mockup-stage--present{grid-template-columns:minmax(420px,920px);justify-content:center}.present-toggle{border:1px solid #2b6cf6;background:#2b6cf6;color:#fff;border-radius:8px;padding:4px 12px;font-size:12px;font-weight:600;cursor:pointer}.present-toggle--on{background:#fff;color:#2b6cf6}.present-toggle:hover{opacity:.9}.screen-frame{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 6px 24px #00000014;overflow:hidden}.screen-titlebar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#f7f9fb;border-bottom:1px dashed var(--line);font-size:13px}.screen-id{font-weight:700;background:#2b2f36;color:#fff;border-radius:6px;padding:1px 6px;font-size:11px}.screen-fr{margin-left:auto;color:var(--muted);font-size:11px}.screen-titlebar--ext{background:#fff7e6;border-bottom-color:#f0c873}.ext-badge{background:#f0a500;color:#3a2a00;border-radius:6px;padding:1px 6px;font-size:10px;font-weight:700}.ext-banner{background:#fff7e6;border:1px solid #f0c873;border-left:4px solid #f0a500;border-radius:8px;padding:10px 12px;font-size:12px;color:#5b4500;line-height:1.55}.danger-banner{background:#fdecea;border:1px solid #f0b4ad;border-left:4px solid #c0392b;border-radius:8px;padding:10px 12px;margin-top:10px;font-size:12px;color:#7a1c12;line-height:1.55}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal-box{background:#fff;border-radius:12px;width:100%;max-width:460px;max-height:85vh;overflow:auto;box-shadow:0 12px 40px #00000040}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--line);font-weight:700;font-size:14px}.modal-x{border:none;background:none;font-size:18px;cursor:pointer;color:#8a929c;line-height:1}.modal-x:hover{color:#2b2f36}.modal-body{padding:16px}.screen-content{display:flex;align-items:stretch}.screen-content .screen-body{flex:1;min-width:0}.screen-body{padding:22px}.status-legend{flex:0 0 156px;width:156px;border-left:1px dashed var(--line);background:#fbfcfd;padding:18px 14px}.legend-title{font-size:11px;font-weight:700;color:#6b727b;margin-bottom:12px}.legend-row{display:flex;gap:7px;align-items:flex-start;margin-bottom:11px;font-size:11px}.legend-row b{display:block;color:var(--ink)}.legend-desc{display:block;color:var(--muted);margin-top:1px}@media (max-width: 560px){.screen-content{flex-direction:column}.status-legend{width:auto;flex:none;border-left:none;border-top:1px dashed var(--line)}}.ov{display:flex;flex-direction:column}.exec{border:1px solid #b9c8ef;background:#f5f9ff;border-radius:10px;padding:12px 14px;margin:8px 0 4px}.exec-title{font-weight:700;font-size:14px}.exec-tagline{font-size:12px;color:#3a4753;margin:2px 0 10px}.exec-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.exec-cell{background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 10px}.exec-k{font-size:10px;font-weight:700;color:#1f5be0}.exec-v{font-size:11px;color:#2b2f36;margin-top:2px;line-height:1.5}.exec-diff{font-size:11px;color:#3a4753;margin-top:10px;line-height:1.6}@media (max-width: 560px){.exec-grid{grid-template-columns:1fr}}.sec-summary{border:1px solid #a8e0bd;background:#f3fbf6;border-radius:10px;padding:12px 14px;margin:8px 0 4px}.sec-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.sec-list li{font-size:11px;color:#2b2f36;line-height:1.5}.sec-list li:before{content:"✓ ";color:#1e7e45;font-weight:700}.sec-tech{color:#8a929c;font-size:10px}.ov-section{margin-top:16px}.ov-h{font-size:13px;font-weight:700;color:#2b2f36;border-bottom:2px solid #2b2f36;padding-bottom:4px;margin-bottom:10px}.ov-group-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:#6b727b;margin:8px 0 6px}.ov-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ov-card{display:flex;flex-direction:column;gap:2px;text-align:left;border:1px solid var(--line);border-radius:8px;background:#fff;padding:8px 10px;cursor:pointer}.ov-card:hover{background:#f1f3f6;border-color:#9aa1ab}.ov-card--ext{border-style:dashed;background:#fffdf7}.ov-card-id{align-self:flex-start;font-size:10px;font-weight:700;color:#fff;background:#2b2f36;border-radius:5px;padding:1px 5px}.ov-card--ext .ov-card-id{background:#b07a00}.ov-card-t{font-size:12px;font-weight:700;margin-top:2px}.ov-card-p{font-size:11px;color:#6b727b}.ov-flow{margin:0;padding-left:18px;font-size:12px;color:#2b2f36;line-height:1.7}.ov-flow li{margin-bottom:2px}.ov-link-btn{display:block;width:100%;text-align:left;border:1px solid #b9c8ef;background:#eef4ff;color:#1f5be0;border-radius:8px;padding:10px 12px;font-size:12px;font-weight:600;cursor:pointer}.ov-link-btn:hover{background:#e0ebff}.ov-cta{display:block;width:100%;margin:10px 0 4px;border:none;background:#2b6cf6;color:#fff;border-radius:8px;padding:11px 12px;font-size:13px;font-weight:700;cursor:pointer}.ov-cta:hover{background:#1f5be0}.story{display:flex;flex-direction:column}.story-legend{display:flex;gap:6px;margin:6px 0 12px}.story-tl{display:flex;flex-direction:column;gap:8px}.story-step{display:flex;gap:10px;align-items:flex-start}.story-no{flex:0 0 22px;height:22px;border-radius:50%;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.story-no--vendor{background:#2b6cf6}.story-no--install{background:#b07a00}.story-no--handoff{background:#8a929c}.story-card{flex:1;min-width:0;background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 10px}.story-card-h{display:flex;align-items:center;gap:6px;font-weight:700;font-size:12px}.story-actor{font-size:10px;font-weight:700;border-radius:5px;padding:1px 6px}.story-actor--vendor{background:#e7f0ff;color:#1f5be0}.story-actor--install{background:#fff7e6;color:#8a5a00}.story-actor--handoff{background:#eef0f3;color:#6b727b}.story-desc{font-size:11px;color:#6b727b;margin-top:2px}.story-view{margin-top:4px;border:none;background:transparent;color:#2b6cf6;cursor:pointer;font-size:11px;padding:0}.story-view:hover{text-decoration:underline}.crypto{display:flex;flex-direction:column}.crypto-card{border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:#fff;margin-bottom:12px}.crypto-card-h{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;font-weight:700;margin-bottom:4px}.crypto-badge{font-size:10px;font-weight:700;border-radius:6px;padding:1px 7px}.crypto-badge--asym{background:#e7f0ff;color:#1f5be0}.crypto-badge--sym{background:#eafaf0;color:#1e7e45}.crypto-sub{font-size:11px;color:#6b727b;margin:0 0 10px}.crypto-why{background:#eef4ff;border:1px solid #b9c8ef;border-left:4px solid #2b6cf6;border-radius:8px;padding:10px 12px;margin-bottom:12px;font-size:12px;color:#243b66;line-height:1.6}.flow{display:flex;align-items:stretch;flex-wrap:wrap;gap:6px}.flow-box{display:flex;flex-direction:column;justify-content:center;border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:11px;background:#fbfcfd;text-align:center;line-height:1.35}.flow-box small{display:block;color:#8a929c;font-size:10px}.flow-op{border-color:#b9c8ef;background:#eef4ff;color:#1f5be0;font-weight:600}.flow-key{border-style:dashed;background:#fffdf7}.flow-arrow{align-self:center;color:#9aa1ab;font-size:14px;font-weight:700}.flow-label{font-size:10px;font-weight:400;color:#8a929c}.steps{display:flex;flex-direction:column;gap:8px}.step{display:flex;gap:10px;align-items:flex-start}.step-no{flex:0 0 22px;height:22px;border-radius:50%;background:#2b6cf6;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}.step-body{font-size:12px}.step-body b{display:block}.step-body span{color:#6b727b;font-size:11px}.reenc{margin:8px 0}.reenc-bar{height:8px;background:#e3e7ec;border-radius:999px;overflow:hidden}.reenc-bar span{display:block;height:100%;background:#27ae60;border-radius:999px}.reenc-label{font-size:11px;font-weight:600;color:#1e7e45;margin-top:4px}.reenc-domains{font-size:11px;color:#6b727b;margin-top:2px}.jwt-decode{margin:4px 0 8px}.jwt-parts{display:flex;flex-direction:column;gap:6px}.jwt-part{border-radius:8px;padding:8px 10px}.jwt-part-h{font-size:11px;font-weight:700;margin-bottom:4px}.jwt-part code{font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px;color:#3a4753;word-break:break-all}.jwt-mini{font-size:10px;color:#6b727b;margin-top:4px}.jwt-part--header{background:#fdecea;border:1px solid #f0b4ad}.jwt-part--payload{background:#eef4ff;border:1px solid #b9c8ef}.jwt-part--sig{background:#eafaf0;border:1px solid #a8e0bd}.reveal-btn{border:none;background:none;cursor:pointer;font-size:12px;margin-left:6px;padding:0;opacity:.7}.reveal-btn:hover{opacity:1}.license-card{border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:#fbfcfd}.license-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.state-pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;background:#fff;border:1px solid var(--line);border-radius:999px;padding:3px 10px}.kv{width:100%;border-collapse:collapse;font-size:12px}.kv th{text-align:left;color:#6b727b;font-weight:600;width:84px;padding:3px 0;vertical-align:top;white-space:nowrap}.kv td{padding:3px 0}.scenario-row{display:flex;flex-wrap:wrap;gap:6px}.result-panel{border:1px solid var(--line);border-radius:8px;padding:12px;margin-top:10px}.result-panel--ok{background:#eafaf0;border-color:#a8e0bd}.result-panel--fail{background:#fdecea;border-color:#f0b4ad}.result-head{font-weight:700;font-size:13px;margin-bottom:8px}.result-panel--ok .result-head{color:#1e7e45}.result-panel--fail .result-head{color:#c0392b}.check-list{list-style:none;padding:0;margin:0 0 8px;display:flex;flex-direction:column;gap:3px;font-size:12px}.chk--ok{color:#1e7e45}.chk--fail{color:#c0392b;font-weight:700}.state-line{display:flex;align-items:center;gap:6px;font-size:13px;margin:6px 0 2px}.wf-screen{display:flex;flex-direction:column;gap:12px}.wf-center-col{align-items:center}.wf-card{border:1px solid var(--line);border-radius:10px;padding:18px;background:#fcfcfd;width:100%}.wf-logo{margin:0 0 14px;text-align:center;font-size:16px}.wf-field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#6b727b}.wf-input{border:1px solid var(--line);border-radius:6px;padding:8px;font-size:13px;background:#fff}.wf-row-between{display:flex;align-items:center;justify-content:space-between;gap:10px}.wf-h{font-size:15px;font-weight:700}.wf-btn{display:inline-block;border:1px solid var(--line);background:#fff;border-radius:7px;padding:6px 12px;font-size:12px;cursor:pointer;color:#2b2f36;text-decoration:none}.wf-btn:hover{background:#f1f3f6}.wf-btn:disabled{opacity:.45;cursor:not-allowed}.wf-btn-primary{background:#2b6cf6;border-color:#2b6cf6;color:#fff}.wf-btn-primary:hover{background:#1f5be0}.wf-btn-danger{color:#c0392b;border-color:#e3b4ae}.wf-btn-sm{padding:3px 8px;font-size:11px}.wf-hint{font-size:11px;color:#c0392b;margin:8px 0 0;text-align:center}.wf-note{font-size:11px;color:var(--muted);margin:2px 0}.plan-memo{margin-top:10px;background:#eef4ff;border:1px solid #b9ccf0;border-left:4px solid #3b6fd4;border-radius:8px;padding:10px 12px 10px 14px;font-size:12px;color:#1f3a66;line-height:1.55}.plan-memo-h{font-weight:700;margin-bottom:6px}.plan-memo-list{margin:0;padding-left:18px}.plan-memo-list li{margin:4px 0}.plan-memo-link{color:#2a5bd0;text-decoration:underline}.expiry-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff7e6;border:1px solid #f0c873;border-left:4px solid #f0a500;border-radius:8px;padding:8px 12px;font-size:12px;color:#5b4500}.table-scroll{overflow-x:auto}.row-soon{background:#fff7e6}.row-soon:hover{background:#fdeecb}.contact-link{color:#2b6cf6;text-decoration:none;font-size:11px}.contact-link:hover{text-decoration:underline}.wf-search{display:flex;gap:8px}.wf-search .wf-input{flex:1}.wf-table{width:100%;border-collapse:collapse;font-size:12px}.wf-table th,.wf-table td{border:1px solid #e3e7ec;padding:6px 8px;text-align:left}.wf-table th{background:#f7f9fb;color:#6b727b;font-weight:600}.wf-code{font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px;color:#3a4753}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:middle}.dot--active{background:#27ae60}.dot--warn{background:#f39c12}.dot--expired{background:#bdc3c7}.dot--revoked{background:#c0392b}.wf-pager{display:flex;gap:6px;justify-content:center;margin-top:6px;color:var(--muted);font-size:12px}.wf-keybox{border:1px dashed var(--line);background:#f7f9fb;border-radius:8px;padding:10px;font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px;word-break:break-all;color:#3a4753}.wf-radio{display:flex;gap:14px;font-size:12px;color:#2b2f36}.wf-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.wf-back{background:none;border:none;color:#2b6cf6;cursor:pointer;font-size:12px;padding:0}.note-rail{display:flex;flex-direction:column;gap:14px;padding-top:30px}.rail-label{font-size:11px;color:#9aa1ab;text-align:center}.sticky{position:relative;border-radius:3px;padding:10px 10px 8px;box-shadow:0 4px 10px #00000024}.sticky--0{background:#fff6a8}.sticky--1{background:#ffd6e0}.sticky--2{background:#c8f0d0}.sticky-text{width:100%;border:none;background:transparent;resize:none;overflow:hidden;min-height:48px;font-family:inherit;font-size:12px;line-height:1.5;color:#4a4636;caret-color:#2b6cf6;outline:none}.sticky-text:focus{background:#ffffff8c;border-radius:3px}.sticky-move{display:block;margin-top:4px;border:none;background:transparent;color:#1e7e45;cursor:pointer;font-size:11px;font-weight:600;padding:0}.sticky-move:hover{text-decoration:underline}.sticky-del{position:absolute;top:2px;right:4px;border:none;background:transparent;color:#00000059;cursor:pointer;font-size:15px;line-height:1}.sticky-del:hover{color:#000}.note-add{border:1px dashed #aeb6c0;background:transparent;color:#7b828c;border-radius:6px;padding:6px;font-size:12px;cursor:pointer}.note-add:hover{background:#ffffff80}.reply-area{margin-top:6px;padding-top:6px;border-top:1px dashed rgba(0,0,0,.18)}.reply{display:flex;align-items:flex-start;gap:3px;margin-bottom:4px}.reply-arrow{color:#00000073;font-size:12px;line-height:1.7}.reply-text{flex:1;min-width:0;border:none;background:#ffffff8c;border-radius:3px;resize:vertical;min-height:30px;font-family:inherit;font-size:11px;line-height:1.5;color:#4a4636;caret-color:#2b6cf6;outline:none;padding:3px 5px}.reply-text:focus{background:#ffffffd9}.reply-del{border:none;background:transparent;color:#00000059;cursor:pointer;font-size:12px;line-height:1.4}.reply-del:hover{color:#000}.reply-add{border:none;background:transparent;color:#6b5e00;cursor:pointer;font-size:11px;padding:2px 0;text-decoration:underline}.reply-add:hover{color:#000}.log-tree{position:relative;display:flex;flex-direction:column;gap:10px;padding-left:16px}.log-tree:before{content:"";position:absolute;left:4px;top:6px;bottom:6px;width:2px;background:#d7dce2;border-radius:1px}.log-item{position:relative}.log-item:before{content:"";position:absolute;left:-16px;top:9px;width:9px;height:9px;border-radius:50%;background:#27ae60;border:2px solid #fff;box-shadow:0 0 0 1px #cfd5dc}.log-item:after{content:"";position:absolute;left:-11px;top:13px;width:11px;height:2px;background:#d7dce2}.log-body{background:#fff;border:1px solid #e3e7ec;border-radius:8px;padding:6px 8px}.log-row{display:flex;align-items:flex-start;gap:4px}.log-text{flex:1;min-width:0;border:none;background:transparent;resize:none;overflow:hidden;min-height:22px;font-family:inherit;font-size:12px;font-weight:600;line-height:1.5;color:#2b2f36;caret-color:#2b6cf6;outline:none}.log-del,.log-reply-del{border:none;background:transparent;color:#0000004d;cursor:pointer;font-size:13px;line-height:1.3}.log-del:hover,.log-reply-del:hover{color:#000}.log-replies{margin:5px 0 0 2px;padding-left:10px;border-left:1px dashed #cfd5dc}.log-reply{display:flex;align-items:flex-start;gap:3px}.log-branch{color:#aab0b9;font-size:11px;line-height:1.7}.log-reply-text{flex:1;min-width:0;border:none;background:transparent;resize:none;overflow:hidden;min-height:20px;font-family:inherit;font-size:11px;line-height:1.5;color:#5b636d;caret-color:#2b6cf6;outline:none}.log-reply-add{border:none;background:transparent;color:#2b6cf6;cursor:pointer;font-size:11px;padding:2px 0}.log-reply-add:hover{text-decoration:underline}
