/* Floor Designer — Page-specific Styles (tokens+topbar via shared CSS) */
#app{display:flex;height:100vh;padding-top:48px}
#panel-left{width:280px;flex-shrink:0;background:var(--srf);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}
#canvas-area{flex:1;position:relative;background:var(--bg)}
#konva-container{width:100%;height:calc(100% - 28px)}
#preview-3d{width:380px;flex-shrink:0;background:var(--srf2);border-left:1px solid var(--border);position:relative;display:none}
#preview-canvas{width:100%;height:100%}
.pl-section{padding:14px 16px;border-bottom:1px solid var(--border)}
.pl-title{font-size:11px;font-weight:700;color:var(--ink-lt);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px}
.pl-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}
.pl-label{font-size:11px;color:var(--ink-m);min-width:80px;flex-shrink:0}
.pl-input{flex:1;background:var(--srf2);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--ink);font-family:var(--mono);font-size:12px;outline:none;transition:.15s}
.pl-input:focus{border-color:var(--accent)}
.pl-unit{font-size:10px;color:var(--ink-lt);font-family:var(--mono);min-width:28px}
.pl-btn{width:100%;padding:9px;border-radius:8px;border:1px solid var(--border);background:var(--srf2);color:var(--ink-m);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;transition:.15s;text-align:center}
.pl-btn:hover{color:var(--ink);border-color:var(--ink-lt)}
.pl-btn.primary{background:rgba(34,197,94,.1);color:var(--accent);border-color:rgba(34,197,94,.3)}
.pl-btn.primary:hover{background:rgba(34,197,94,.18);border-color:var(--accent)}
.pl-btn-row{display:flex;gap:8px}
.pl-btn-row .pl-btn{flex:1}
.tool-btn{padding:7px 12px;border-radius:7px;border:1px solid var(--border);background:var(--srf2);color:var(--ink-m);font-family:var(--font);font-size:11px;font-weight:600;cursor:pointer;transition:.15s}
.tool-btn:hover{border-color:var(--accent);color:var(--accent)}
.tool-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(34,197,94,.08)}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--srf);border:1px solid var(--border);border-radius:10px;padding:10px 20px;font-size:13px;color:var(--ink);z-index:999;box-shadow:0 8px 32px rgba(0,0,0,.3);transition:opacity .3s;pointer-events:none}
.toast.success{border-color:var(--accent);color:var(--accent)}
#stats-bar{position:absolute;bottom:0;left:0;right:0;height:28px;background:var(--srf);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:16px;font-family:var(--mono);font-size:10px;color:var(--ink-lt);z-index:10}
/* =====================================================================
   HARDWARE LIBRARY PANEL
   ===================================================================== */
.hw-filter-bar{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}
.hw-cat-btn{padding:4px 8px;border-radius:6px;border:1px solid var(--border);background:var(--srf2);color:var(--ink-lt);font-family:var(--mono);font-size:10px;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap}
.hw-cat-btn:hover{color:var(--ink-m);border-color:var(--border-hi)}
.hw-cat-btn.active{color:var(--accent);border-color:var(--accent);background:rgba(34,197,94,.08)}
.hw-capacity-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.hw-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;max-height:180px;overflow-y:auto;padding-right:2px}
.hw-card{background:var(--srf2);border:1px solid var(--border);border-radius:7px;padding:7px 8px;cursor:pointer;transition:.15s;min-height:60px;display:flex;flex-direction:column;gap:2px}
.hw-card:hover{border-color:var(--accent);background:rgba(34,197,94,.05)}
.hw-card.selected{border-color:var(--accent);background:rgba(34,197,94,.1)}
.hw-card-name{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--ink);line-height:1.3}
.hw-card-brand{font-size:9px;color:var(--ink-lt)}
.hw-card-cap{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--accent);margin-top:auto}
.hw-detail{background:var(--srf2);border:1px solid var(--border);border-radius:8px;margin-top:8px;overflow:hidden}
.hw-detail-inner{padding:10px}
.hw-detail-header{margin-bottom:6px}
.hw-detail-name{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--ink)}
.hw-detail-brand{font-size:10px;color:var(--ink-lt)}
.hw-detail-svg{background:var(--srf);border:1px solid var(--border);border-radius:6px;padding:6px;margin:6px 0;min-height:80px;display:flex;align-items:center;justify-content:center}
.hw-detail-table{width:100%;border-collapse:collapse;font-size:10px;font-family:var(--mono);margin:4px 0}
.hw-detail-table td{padding:2px 4px;color:var(--ink-m);border-bottom:1px solid var(--border)}
.hw-detail-table td:first-child{color:var(--ink-lt);width:50%}
.hw-detail-desc{font-size:10px;color:var(--ink-lt);margin-top:4px;line-height:1.4}

@media(max-width:900px){#preview-3d{display:none!important}#panel-left{width:240px}}
@media(max-width:600px){#panel-left{width:100%;height:auto;max-height:40vh;border-right:none;border-bottom:1px solid var(--border)}#app{flex-direction:column}}
