*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#333;background:#f5f5f5;min-height:100vh}#app{max-width:1200px;margin:0 auto;padding:20px;display:flex;flex-direction:column;min-height:100vh}.app-header{text-align:center;margin-bottom:30px;color:#333}.app-header h1{font-size:2.5rem;margin-bottom:10px}.app-header p{font-size:1.1rem}.app-main{display:grid;grid-template-columns:300px 1fr;gap:20px;flex:1}.sidebar{display:flex;flex-direction:column;gap:20px}.toolbar-section{background:#fff;border-radius:8px;padding:20px;border:1px solid #ddd;height:fit-content}.toolbar h3{color:#333;margin-bottom:15px;font-size:1.1rem;border-bottom:1px solid #e0e0e0;padding-bottom:8px}.layout-buttons{display:grid;grid-template-columns:.8fr .8fr .8fr .8fr .8fr;gap:8px;margin:20px 0}.layout-btn{padding:6px 8px;border:1px solid #ddd;background:#f9f9f9;color:#333;border-radius:4px;cursor:pointer;font-size:20px;font-weight:500;text-align:center}.layout-btn:hover{background:#e9e9e9}.layout-btn:active{background:#ddd}.actions{display:flex;flex-direction:row;gap:10px;padding-top:20px}.actions button{padding:4px 0;border:1px solid #ddd;background:#fff;color:#333;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;flex:1}.actions button:hover{background:#f5f5f5}.danger-btn{background:#dc3545!important;color:#fff!important;border-color:#dc3545!important}.danger-btn:hover{background:#c82333!important;border-color:#bd2130!important}.danger-btn:disabled{background:#f5f5f5!important;color:#999!important;border-color:#ddd!important;cursor:not-allowed}.editor-container{border:1px solid #333}.editor-section{background:#fff;border-radius:8px;padding:30px;border:1px solid #ddd;min-height:400px;display:flex;align-items:center;justify-content:center}.layout-node{background:#f9f9f9;position:relative;min-width:120px;min-height:80px;cursor:pointer;display:flex;flex-direction:column;height:100%}.layout-node-header{display:flex;justify-content:space-between;align-items:center;background:#333;color:#fff;border-top:1px solid #666;flex-shrink:0;width:100%;box-sizing:border-box;padding:0 8px;min-height:24px}.layout-label{margin-left:4px;font-size:20px;font-weight:600;color:#fff}.delete-btn{background:transparent;color:#fff;border:none;width:24px;height:24px;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;border-radius:2px}.delete-btn:hover{background:#c82333}.layout-node-content{flex:1;display:grid;gap:0;width:100%;height:100%}.slot .layout-node{width:100%;height:100%;margin:0;min-width:unset;min-height:unset}.slot .layout-node .layout-node-header{width:100%;box-sizing:border-box}.slot .layout-node .layout-node-content{width:100%;height:100%;box-sizing:border-box}.layout-node[data-layout=⿰]>.layout-node-content{grid-template-columns:auto auto;grid-template-rows:auto}.layout-node[data-layout=⿰]>.layout-node-content>:nth-child(2){border-left:1px dashed #999}.layout-node[data-layout=⿱]>.layout-node-content{grid-template-columns:auto;grid-template-rows:auto auto}.layout-node[data-layout=⿱]>.layout-node-content>:nth-child(2){border-top:1px dashed #999}.layout-node[data-layout=⿲]>.layout-node-content{grid-template-columns:auto auto auto;grid-template-rows:auto}.layout-node[data-layout=⿲]>.layout-node-content>:nth-child(2){border-left:1px dashed #999}.layout-node[data-layout=⿲]>.layout-node-content>:nth-child(3){border-left:1px dashed #999}.layout-node[data-layout=⿳]>.layout-node-content{grid-template-columns:auto;grid-template-rows:auto auto auto}.layout-node[data-layout=⿳]>.layout-node-content>:nth-child(2){border-top:1px dashed #999}.layout-node[data-layout=⿳]>.layout-node-content>:nth-child(3){border-top:1px dashed #999}.layout-node[data-layout=⿸]{min-height:120px}.layout-node[data-layout=⿸]>.layout-node-content{grid-template-columns:.3fr 1fr;grid-template-rows:auto auto;gap:0}.layout-node[data-layout=⿸]>.layout-node-content>:nth-child(1){grid-column:1 / 3;grid-row:1;border:none;margin:0;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿸]>.layout-node-content>:nth-child(2){grid-column:2;grid-row:2;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-top:1px dashed #999;border-left:1px dashed #999}.layout-node[data-layout=⿹]{min-height:120px}.layout-node[data-layout=⿹]>.layout-node-content{grid-template-columns:1fr .3fr;grid-template-rows:auto auto;gap:0}.layout-node[data-layout=⿹]>.layout-node-content>:nth-child(1){grid-column:1 / 3;grid-row:1;border:none;margin:0;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿹]>.layout-node-content>:nth-child(2){grid-column:1;grid-row:2;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-top:1px dashed #999;border-right:1px dashed #999}.layout-node[data-layout=⿺]{min-height:120px}.layout-node[data-layout=⿺]>.layout-node-content{grid-template-columns:.3fr 1fr;grid-template-rows:auto auto;gap:0}.layout-node[data-layout=⿺]>.layout-node-content>:nth-child(1){grid-column:1 / 3;grid-row:2;border:none;margin:0;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿺]>.layout-node-content>:nth-child(2){grid-column:2;grid-row:1;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-bottom:1px dashed #999;border-left:1px dashed #999}.layout-node[data-layout=⿽]{min-height:120px}.layout-node[data-layout=⿽]>.layout-node-content{grid-template-columns:1fr .3fr;grid-template-rows:auto auto;gap:0}.layout-node[data-layout=⿽]>.layout-node-content>:nth-child(1){grid-column:1 / 3;grid-row:2;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿽]>.layout-node-content>:nth-child(2){grid-column:1;grid-row:1;border:none;margin:0;display:flex;align-items:center;justify-content:center;border-bottom:1px dashed #999;border-right:1px dashed #999}.layout-node[data-layout=⿵]{min-height:120px}.layout-node[data-layout=⿵]>.layout-node-content{grid-template-columns:2em auto 2em;grid-template-rows:auto auto;gap:0}.layout-node[data-layout=⿵]>.layout-node-content>:nth-child(1){grid-column:1 / 4;grid-row:1;border:none;margin:0;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿵]>.layout-node-content>:nth-child(2){grid-column:2;grid-row:2;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-top:1px dashed #999;border-left:1px dashed #999;border-right:1px dashed #999}.layout-node[data-layout=⿶]{min-height:120px}.layout-node[data-layout=⿶]>.layout-node-content{grid-template-columns:2em auto 2em;grid-template-rows:auto auto;gap:0}.layout-node[data-layout=⿶]>.layout-node-content>:nth-child(1){grid-column:1 / 4;grid-row:2;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿶]>.layout-node-content>:nth-child(2){grid-column:2;grid-row:1;border:none;margin:0;display:flex;align-items:center;justify-content:center;border-right:1px dashed #999;border-bottom:1px dashed #999;border-left:1px dashed #999}.layout-node[data-layout=⿷]{min-height:120px}.layout-node[data-layout=⿷]>.layout-node-content{grid-template-columns:auto auto;grid-template-rows:2em auto 2em;gap:0}.layout-node[data-layout=⿷]>.layout-node-content>:nth-child(1){grid-column:1;grid-row:1 / 4;border:none;margin:0;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿷]>.layout-node-content>:nth-child(2){grid-column:2;grid-row:2;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-top:1px dashed #999;border-bottom:1px dashed #999;border-left:1px dashed #999}.layout-node[data-layout=⿼]{min-height:120px}.layout-node[data-layout=⿼]>.layout-node-content{grid-template-columns:auto auto;grid-template-rows:2em auto 2em;gap:0}.layout-node[data-layout=⿼]>.layout-node-content>:nth-child(1){grid-column:2;grid-row:1 / 4;border:none;margin:0;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿼]>.layout-node-content>:nth-child(2){grid-column:1;grid-row:2;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-bottom:1px dashed #999;border-right:1px dashed #999;border-top:1px dashed #999}.layout-node[data-layout=⿴]{min-height:150px}.layout-node[data-layout=⿴]>.layout-node-content{grid-template-columns:2em auto 2em;grid-template-rows:1fr auto 1fr;gap:0}.layout-node[data-layout=⿴]>.layout-node-content>:nth-child(1){grid-column:2;grid-row:1;border:none;margin:0;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿴]>.layout-node-content>:nth-child(2){grid-column:2;grid-row:2;margin:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-top:1px dashed #999;border-bottom:1px dashed #999;border-left:1px dashed #999;border-right:1px dashed #999}.layout-node[data-layout=⿻]{min-height:150px;min-width:150px}.layout-node[data-layout=⿻]>.layout-node-content{grid-template-columns:auto auto;grid-template-rows:auto auto;gap:0;position:relative}.layout-node[data-layout=⿻]>.layout-node-content>:nth-child(1){grid-column:1;grid-row:1;margin:0;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿻]>.layout-node-content>:nth-child(2){grid-column:2;grid-row:2;margin:0;display:flex;align-items:center;justify-content:center}.layout-node[data-layout=⿾]{min-height:80px;min-width:80px}.layout-node[data-layout=⿾]>.layout-node-content{grid-template-columns:auto;grid-template-rows:auto;gap:0}.layout-node[data-layout=⿾]>.layout-node-content>:nth-child(1){margin:0;display:flex;align-items:center;justify-content:center;transform:scaleX(-1)}.layout-node[data-layout=⿿]{min-height:80px;min-width:80px}.layout-node[data-layout=⿿]>.layout-node-content{grid-template-columns:auto;grid-template-rows:auto;gap:0}.layout-node[data-layout=⿿]>.layout-node-content>:nth-child(1){margin:0;display:flex;align-items:center;justify-content:center;transform:rotate(180deg)}.layout-node[data-layout=㇯]>.layout-node-content{grid-template-columns:auto auto;grid-template-rows:auto}.layout-node[data-layout=㇯]>.layout-node-content>:nth-child(2){border-left:1px dashed #999;background:repeating-linear-gradient(135deg,#f9f9f9,#f9f9f9 8px,#e0e0e0 8px 16px)}.slot{display:flex;align-items:center;justify-content:center;min-width:50px;min-height:50px;position:relative;margin:0;width:100%;height:100%}.slot input{width:2em;height:2em;border:1px solid #ddd;background:#fff;text-align:center;font-size:28px;font-weight:600;color:#333;outline:none;margin:16px}.slot input:focus{border-color:#666;background:#fff}.slot input::placeholder{color:#999;font-weight:400}.empty-slot{color:#999;font-size:16px;font-style:italic;text-align:center;border:1px dashed #ccc;border-radius:4px;padding:16px;width:2em;height:2em;background:#f9f9f9;cursor:pointer;display:flex;align-items:center;justify-content:center}.result-section{background:#fff;border-radius:8px;padding:20px;border:1px solid #ddd;height:fit-content}.ids-input-section{margin-bottom:25px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.ids-input-section h3{color:#333;margin-bottom:15px;font-size:1.2rem;border-bottom:1px solid #e0e0e0;padding-bottom:8px}.ids-input-container{display:flex;gap:8px;margin-bottom:10px;align-items:stretch}.ids-input{flex:1;min-width:0;padding:10px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;font-family:Courier New,Consolas,monospace;transition:border-color .3s ease;background:#fff}.ids-input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 3px #007acc1a}.ids-input::placeholder{color:#999;font-style:italic}.parse-btn{padding:4px 16px;background:#007acc;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .3s ease,transform .1s ease;white-space:nowrap;flex-shrink:0;min-width:60px}.parse-btn:hover{background:#005a9e}.parse-btn:active{transform:translateY(1px)}.result-section h3{color:#333;margin-bottom:15px;font-size:1.2rem;border-bottom:1px solid #e0e0e0;padding-bottom:8px}.result-text{background:#f5f5f5;border:1px solid #ddd;border-radius:4px;padding:15px;font-family:Courier New,Consolas,monospace;font-size:18px;font-weight:600;color:#333;word-break:break-all;min-height:60px;display:flex;align-items:center;margin-bottom:15px}.stats{padding:10px 15px;background:#f0f0f0;border-radius:4px;border-left:3px solid #666}.stats small{color:#666;font-size:12px;line-height:1.4}@media (max-width: 1024px){.app-main{grid-template-columns:280px 1fr;gap:15px}.layout-buttons{grid-template-columns:1fr}}@media (max-width: 768px){#app{padding:10px}.app-main{grid-template-columns:1fr;gap:20px}.sidebar{order:2}.editor-section{order:1}.app-header h1{font-size:2rem}.layout-buttons{grid-template-columns:1fr 1fr}.slot input{font-size:24px}}
