/* ========================================================================
   柱なし架台モード（Flat Frame Mode） 専用スタイル
   ======================================================================== */

/* メインレイアウト */
#app-flat{position:relative;z-index:1;flex-direction:column;height:calc(100vh - 56px);overflow:hidden}
#app-flat .flat-toolbar{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--s1);border-bottom:1px solid var(--bd);flex-shrink:0}
#app-flat .flat-toolbar h2{font-size:14px;color:var(--ac);letter-spacing:.08em;font-weight:700}
#app-flat .flat-toolbar .flat-tag{background:rgba(230,81,0,.08);color:var(--ac2);border:1px solid rgba(230,81,0,.25);border-radius:10px;padding:2px 8px;font-size:9px;font-weight:700;letter-spacing:.08em}
#app-flat .flat-main{flex:1;display:grid;grid-template-columns:440px 1fr;overflow:hidden}

/* 左パネル */
#app-flat .flat-left{overflow-y:auto;border-right:1px solid var(--bd);background:var(--s1);padding:0}
#app-flat .flat-left::-webkit-scrollbar{width:4px}
#app-flat .flat-left::-webkit-scrollbar-thumb{background:var(--bd);border-radius:2px}

/* 右パネル（キャンバス） */
#app-flat .flat-right{position:relative;background:var(--bg);display:flex;flex-direction:column;overflow:hidden}
#app-flat .flat-canvas-toolbar{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--s1);border-bottom:1px solid var(--bd);flex-wrap:wrap;min-height:38px;flex-shrink:0}
#app-flat .flat-canvas-wrap{flex:1;position:relative;overflow:hidden}
#app-flat #flat-canvas{display:block;width:100%;height:100%;cursor:default}
#app-flat .flat-canvas-info{position:absolute;bottom:6px;left:10px;font-size:11px;color:var(--tx3);font-family:'Share Tech Mono',monospace;pointer-events:none;background:rgba(255,255,255,.8);padding:2px 6px;border-radius:3px}

/* 入力UI補助 */
#app-flat .sec-option-info{font-size:9px;color:var(--tx3);font-family:'Share Tech Mono',monospace;margin-top:2px}

/* 支持条件選択 */
#app-flat .support-opts{display:grid;grid-template-columns:1fr 1fr;gap:4px}
#app-flat .support-opt{padding:6px 8px;border:1px solid var(--bd);border-radius:4px;cursor:pointer;font-size:10px;background:var(--s1);color:var(--tx2);display:flex;align-items:center;gap:6px;transition:all .2s}
#app-flat .support-opt:hover{background:var(--s2)}
#app-flat .support-opt.active{border-color:var(--ac);background:rgba(26,115,232,.08);color:var(--ac);font-weight:700}
#app-flat .support-opt svg{flex-shrink:0}

/* 集中荷重リスト */
#app-flat .pload-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:4px;align-items:center;margin-bottom:4px}
#app-flat .pload-row input{padding:4px 6px;font-size:11px}
#app-flat .pload-row .btn-del{padding:3px 8px;font-size:10px;background:rgba(198,40,40,.08);color:var(--ng);border:1px solid rgba(198,40,40,.2);border-radius:3px;cursor:pointer}

/* B梁配置モード タブ */
#app-flat .bmode-tab{background:var(--s1);border:1px solid var(--bd);color:var(--tx2);font-weight:600}
#app-flat .bmode-tab.active{background:var(--ac);border-color:var(--ac);color:#fff}
#app-flat .bmode-tab:hover:not(.active){background:var(--s2)}

/* B梁寸法指定テーブル */
#app-flat .bpos-row{display:grid;grid-template-columns:28px 1fr auto;gap:4px;align-items:center;margin-bottom:4px}
#app-flat .bpos-row .bpos-label{font-size:10px;color:var(--ac);font-weight:700;font-family:'Share Tech Mono',monospace;text-align:center}
#app-flat .bpos-row input{padding:4px 6px;font-size:11px}
#app-flat .bpos-row .btn-del{padding:3px 8px;font-size:10px;background:rgba(198,40,40,.08);color:var(--ng);border:1px solid rgba(198,40,40,.2);border-radius:3px;cursor:pointer}

/* 計算結果タブ (簡易 / グリレージ) */
#app-flat .f-result-tabs{display:flex;gap:4px;margin-bottom:10px}
#app-flat .f-result-tab{flex:1;padding:8px 12px;border:1px solid var(--bd);background:var(--s1);color:var(--tx2);border-radius:4px;cursor:pointer;font-size:10px;font-weight:600;transition:all .2s}
#app-flat .f-result-tab.active{background:var(--ac);border-color:var(--ac);color:#fff}
#app-flat .f-result-tab:hover:not(.active){background:var(--s2)}

/* 計算結果 */
#app-flat .f-result-summary{padding:8px 10px;margin-bottom:10px;border-radius:6px;font-size:11px;font-weight:700;text-align:center}
#app-flat .f-result-summary.ok{background:rgba(46,125,50,.08);color:var(--ok);border:1px solid rgba(46,125,50,.25)}
#app-flat .f-result-summary.ng{background:rgba(198,40,40,.08);color:var(--ng);border:1px solid rgba(198,40,40,.25)}

#app-flat .f-result-section{margin-bottom:10px}
#app-flat .f-result-section-hdr{font-size:11px;font-weight:700;color:var(--ac);letter-spacing:.04em;margin-bottom:4px;padding:4px 8px;background:var(--s3);border-radius:3px}

#app-flat table.f-result-tbl{width:100%;border-collapse:collapse;font-size:10px;font-family:'Share Tech Mono',monospace}
#app-flat table.f-result-tbl th{background:var(--s3);color:var(--tx2);font-weight:600;padding:4px 6px;border:1px solid var(--bd);text-align:center;white-space:nowrap}
#app-flat table.f-result-tbl td{padding:3px 6px;border:1px solid var(--bd);color:var(--tx);text-align:right;white-space:nowrap}
#app-flat table.f-result-tbl td.lbl{text-align:left;font-weight:700;color:var(--tx2)}
#app-flat table.f-result-tbl td.ok{color:var(--ok);font-weight:700}
#app-flat table.f-result-tbl td.ng{color:var(--ng);font-weight:700;background:rgba(198,40,40,.05)}
#app-flat table.f-result-tbl td.warn{color:var(--warn);font-weight:700}

#app-flat .f-calc-note{font-size:9px;color:var(--tx3);margin-top:6px;line-height:1.5}
