*{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden;font-family:Segoe UI,system-ui,sans-serif;background:#1a1b26;color:#c0caf5}#app{height:100vh;display:flex;flex-direction:column}.header{display:flex;align-items:center;justify-content:space-between;gap:.7rem;padding:.65rem 1rem;background:#16161e;border-bottom:1px solid #363b54}.map-picker{display:flex;align-items:center;gap:.4rem}.map-picker label{font-size:.8rem;color:#a9b1d6}.map-picker select{padding:.28rem .52rem;font-size:.82rem;background:#24283b;color:#c0caf5;border:1px solid #363b54;border-radius:6px}.header-actions{display:flex;align-items:center;gap:.35rem}.panel-toggle-btn{background:#24283b;color:#a9b1d6;border:1px solid #363b54;border-radius:6px;min-width:34px;min-height:30px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.panel-toggle-btn.active{color:#7aa2f7;border-color:#7aa2f7}.fs-icon{width:16px;height:16px;display:block;stroke:currentColor;stroke-width:1.8;fill:none}.content{flex:1;min-height:0;padding:.55rem}.panel-card-3d{position:relative;height:100%;border:1px solid #363b54;border-radius:10px;background:#16161e;overflow:hidden}#canvas-container{width:100%;height:100%}#canvas-container canvas{width:100%;height:100%;display:block;touch-action:none}.dice-overlay-btn{position:absolute;top:10px;left:10px;z-index:7;width:44px;height:44px;border-radius:10px;border:1px solid #5a6393;background:#24283be6;color:#c0caf5;font-size:24px;line-height:1;cursor:pointer}.fullscreen-overlay-btn{position:absolute;top:10px;right:10px;z-index:7;width:40px;height:40px;border-radius:10px;border:1px solid #5a6393;background:#24283be6;color:#c0caf5;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.panel-3d-overlay{position:absolute;right:8px;width:min(520px,calc(100% - 16px));top:56px;z-index:6;background:#16161edb;border:1px solid #363b54;border-radius:8px;padding:.45rem .55rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.panel-3d-overlay.collapsed{display:none}.overlay-row{margin-top:.3rem}.overlay-row:first-child{margin-top:0}.overlay-row-grid-clean{display:grid;grid-template-columns:56px minmax(0,1fr);align-items:center;column-gap:.55rem}.overlay-row label,.debug-title{font-size:.74rem;color:#a9b1d6}.overlay-row input[type=color]{width:30px;height:26px;border:1px solid #363b54;border-radius:5px;padding:1px;background:#24283b}.overlay-row input[type=range]{width:100%}.overlay-controls{display:flex;align-items:center;gap:.35rem;min-width:0}#shape-opacity{width:170px}.overlay-inline-label{font-size:.72rem;color:#a9b1d6}.overlay-controls select{height:26px;min-width:56px;border:1px solid #363b54;border-radius:5px;background:#24283b;color:#c0caf5;font-size:.74rem;padding:0 .3rem}.overlay-icon-btn{width:28px;height:26px;border:1px solid #363b54;border-radius:5px;background:#24283b;color:#c0caf5;line-height:1;cursor:pointer}.overlay-text-btn{height:26px;border:1px solid #363b54;border-radius:5px;background:#24283b;color:#c0caf5;font-size:.73rem;padding:0 .55rem;cursor:pointer}.overlay-row-debug{display:flex;align-items:center;gap:.6rem}.debug-toggle{display:inline-flex;align-items:center;gap:.35rem}.debug-3d-label,.debug-face-label{color:#ffdd57;font-weight:700;text-shadow:0 0 3px #1a1b26;pointer-events:none}.debug-3d-label{font-size:13px}.debug-face-label{font-size:12px}.face-menu{position:fixed;z-index:20;width:min(94vw,360px);background:#16161e;border:1px solid #3a4262;border-radius:10px;box-shadow:0 14px 30px #0006;padding:.65rem .55rem .55rem}.face-menu.hidden{display:none}.face-menu-title{font-size:.76rem;color:#7aa2f7;margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.04em}.face-menu-close{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:6px;border:1px solid #363b54;background:#24283b;color:#c0caf5;cursor:pointer;line-height:1}.face-menu-group{margin-top:.35rem;padding-top:.25rem;border-top:1px solid #2b3148}.face-menu-group:first-of-type{margin-top:.15rem;border-top:0;padding-top:0}.face-menu-group-title{font-size:.68rem;color:#7aa2f7;margin-bottom:.2rem;text-transform:uppercase;letter-spacing:.04em}.face-menu-inline-label{font-size:.7rem;color:#a9b1d6;min-width:42px}.face-menu-row{display:flex;align-items:center;gap:.35rem;margin-top:.32rem;flex-wrap:wrap}.icon-btn{width:28px;min-width:28px;height:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:14px}.face-menu-row button,.face-menu-row select{background:#24283b;color:#c0caf5;border:1px solid #363b54;border-radius:6px;min-height:28px;padding:.18rem .45rem;font-size:.74rem}.face-menu-row select{min-width:88px}.face-menu-row label{font-size:.72rem;color:#a9b1d6}.face-menu-row input[type=color]{width:30px;height:26px;border:1px solid #363b54;border-radius:5px;padding:1px;background:#24283b}.pseudo-fullscreen{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100vw!important;height:100vh!important;z-index:9999!important}@media(max-width:900px){.header{padding:.5rem .55rem}.map-picker label{font-size:.72rem}.map-picker select{font-size:.74rem;padding:.23rem .42rem}.dice-overlay-btn{width:40px;height:40px;font-size:21px}.fullscreen-overlay-btn{width:36px;height:36px;border-radius:9px}.panel-3d-overlay{left:6px;right:6px;width:auto;top:52px;padding:.35rem .4rem}#shape-opacity{width:100%}.overlay-row-grid-clean{grid-template-columns:48px minmax(0,1fr);column-gap:.35rem}}
