:root{--bg:#f5f5f7;--surface:#fff;--border:#e5e5ea;--text:#333;--text-muted:#888;--text-faint:#bbb;--accent:#007aff;--input-bg:#fff;--input-border:#ddd;--section-bg:#f9f9f9;--stat-bg:#f9f9f9;--shadow:#0000000d;--hint-bg:#f0f7ff;--hint-border:#cce0ff;--canvas-bg:#f0f0f0}[data-theme=dark]{--bg:#1a1a1a;--surface:#252525;--border:#333;--text:#e0e0e0;--text-muted:#888;--text-faint:#555;--accent:#4fc3f7;--input-bg:#1e1e1e;--input-border:#3a3a3a;--section-bg:#1e1e1e;--stat-bg:#1e1e1e;--shadow:#0000004d;--hint-bg:#0d2137;--hint-border:#1e4a6e;--canvas-bg:#111}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:background .2s,color .2s}.app-header{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 2px 4px var(--shadow);align-items:center;gap:16px;padding:14px 24px;display:flex}.app-header h1{color:var(--text);font-size:20px}.app-header p{color:var(--text-muted);flex:1;font-size:12px}.theme-toggle{background:var(--section-bg);border:1px solid var(--border);cursor:pointer;color:var(--text-muted);white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:13px;transition:all .2s;display:flex}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.app-main{flex:1;display:flex;overflow:hidden}.app-layout{flex-direction:column;height:100vh;display:flex}.sidebar-left{background:var(--surface);border-right:1px solid var(--border);width:320px;min-width:280px;padding:12px;overflow-y:auto}.content-center{background:var(--bg);flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow:hidden}.canvas-wrap{background:var(--canvas-bg);border:1px solid var(--border);border-radius:8px;flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}.export-wrap{flex-shrink:0}.sidebar-right{background:var(--surface);border-left:1px solid var(--border);flex-direction:column;width:280px;min-width:240px;padding:16px;display:flex;overflow-y:auto}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.controls-panel,.analysis-panel,.export-panel,.advanced-controls{background:var(--surface);color:var(--text)}.controls-panel h2,.analysis-panel h2,.export-panel h2,.advanced-controls h2{color:var(--text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;font-size:13px;font-weight:700}.cs{margin-bottom:10px}.cs h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;font-size:10px;font-weight:700}.cs-hint{color:var(--text-faint);text-transform:none;letter-spacing:0;font-weight:400}.row-2{grid-template-columns:1fr 1fr;gap:6px;display:grid}.ci{align-items:center;gap:6px;margin-bottom:4px;display:flex}.ci-lbl{color:var(--text-muted);white-space:nowrap;min-width:36px;font-size:11px}.controls-panel .ci{grid-template-columns:56px minmax(0,1fr);align-items:center;display:grid}.controls-panel .ci-lbl{min-width:0}.controls-panel .ci-inp,.controls-panel .ci-sel{width:100%}.ci-inp{border:1px solid var(--input-border);background:var(--input-bg);border-radius:4px;flex:1;align-items:center;display:flex;overflow:hidden}.ci-inp input{background:var(--input-bg);min-width:0;color:var(--text);border:none;outline:none;flex:1;padding:5px 6px;font-size:12px}.ci-inp:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px #007aff1a}.ci-unit{color:var(--text-faint);background:var(--section-bg);border-left:1px solid var(--border);white-space:nowrap;padding:0 5px;font-size:10px;line-height:27px}.ci-sel{border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);border-radius:4px;outline:none;flex:1;min-width:0;padding:5px 6px;font-size:11px}.ci-sel:focus{border-color:var(--accent)}.analysis-grid{grid-template-columns:1fr 1fr;gap:6px;margin-bottom:14px;display:grid}.stat{background:var(--stat-bg);border:1px solid var(--border);border-radius:5px;padding:8px 10px}.stat label{color:var(--text-muted);text-transform:uppercase;font-size:10px;display:block}.stat-val{color:var(--accent);margin-top:2px;font-size:15px;font-weight:700;display:block}.export-panel{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:12px 16px}.export-mat-row{align-items:center;gap:10px;margin-bottom:10px;display:flex}.mat-swatch{color:#ffffffd9;text-shadow:0 1px 2px #00000080;text-transform:capitalize;border:1px solid #00000026;border-radius:4px;justify-content:center;align-items:center;min-width:80px;height:26px;padding:0 8px;font-size:10px;font-weight:700;display:flex}.export-hint{color:var(--text-faint);font-size:10px}.export-buttons{flex-wrap:wrap;gap:8px;display:flex}.btn-export{border:1px solid var(--border);background:var(--surface);cursor:pointer;min-width:60px;color:var(--text);border-radius:5px;flex:1;padding:8px 10px;font-size:12px;font-weight:600;transition:all .15s}.btn-export:hover:not(.disabled){border-color:var(--accent);background:var(--hint-bg);color:var(--accent)}.btn-export.disabled{opacity:.45;cursor:not-allowed}.btn-dxf{color:#0288d1;border-color:#4fc3f7}.btn-dxf:hover{background:var(--hint-bg)}.btn-svg{color:#2e7d32;border-color:#81c784}.btn-svg:hover:not(.disabled){background:#e8f5e9}.btn-png{color:#7b1fa2;border-color:#ce93d8}.btn-png:hover{background:#f3e5f5}.btn-jpg{color:#e65100;border-color:#ffb74d}.btn-jpg:hover{background:#fff3e0}.export-legend{flex-direction:column;gap:2px;margin-top:8px;display:flex}.export-legend span{color:var(--text-faint);font-size:10px}.canvas-2d{max-width:100%;max-height:100%}.app-footer{background:var(--surface);border-top:1px solid var(--border);color:var(--text-muted);text-align:center;padding:8px 24px;font-size:11px}.app-footer span{color:var(--accent);font-weight:600}.spacing-info{background:var(--hint-bg);border:1px solid var(--hint-border);color:var(--text-muted);border-radius:4px;justify-content:space-between;align-items:center;margin-top:4px;padding:5px 8px;font-size:11px;display:flex}.spacing-info strong{color:var(--accent);font-size:12px}.real-values-card{background:var(--hint-bg);border:1px solid var(--accent);border-radius:7px;margin-top:12px;padding:10px 12px}.real-values-title{text-transform:uppercase;letter-spacing:.7px;color:var(--accent);align-items:center;gap:6px;margin-bottom:8px;font-size:10px;font-weight:700;display:flex}.real-values-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.real-values-block{margin-bottom:8px}.real-values-block:last-child{margin-bottom:0}.real-values-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:4px;font-size:9px;font-weight:700}.real-values-row{grid-template-columns:1fr 1fr;gap:6px;display:grid}.real-values-cell{background:var(--surface);border:1px solid var(--border);border-radius:5px;flex-direction:column;align-items:center;padding:5px 6px;display:flex}.real-values-cell strong{color:var(--accent);font-size:13px}.rv-axis{color:var(--text-muted);font-size:9px}.rv-margin-grid{grid-template-rows:auto auto auto;grid-template-columns:1fr auto 1fr;place-items:center;gap:3px;display:grid}.rv-margin-cell{background:var(--surface);border:1px solid var(--border);border-radius:5px;flex-direction:column;align-items:center;min-width:42px;padding:4px 8px;display:flex}.rv-margin-cell strong{color:var(--accent);font-size:13px;line-height:1}.rv-margin-center{color:var(--text-faint);background:var(--surface);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:9px;display:flex}.radio-group{flex-direction:column;gap:6px;display:flex}.radio-group label{cursor:pointer;color:var(--text);align-items:center;gap:6px;font-size:12px;display:flex}.locked-message{color:#ff9500;background:#fff5e6;border-radius:4px;padding:6px 8px;font-size:11px}.btn-small{border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text);border-radius:4px;width:100%;padding:6px 10px;font-size:11px;font-weight:600;transition:all .15s}.btn-small:hover{border-color:var(--accent);color:var(--accent)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}.btn-pdf{color:#c62828;border-color:#ef5350}.btn-pdf:hover{background:#ffebee}.perfo-toggle{background:var(--section-bg);border:1px solid var(--border);border-radius:6px;gap:4px;margin-bottom:8px;padding:3px;display:flex}.perfo-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;flex:1;padding:5px 8px;font-size:11px;font-weight:600;transition:all .15s}.perfo-btn.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 3px var(--shadow)}.perfo-btn:hover:not(.active){color:var(--text)}.compact-section{padding-top:2px}.compact-subtitle{color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin:6px 0 4px;font-size:10px;font-weight:700}.advanced-controls-compact .cs{margin-bottom:8px}.advanced-mode-card{padding-bottom:10px}.advanced-mode-card h3{margin-bottom:8px}.advanced-collapse-toggle{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:8px;margin:0 0 6px;padding:0;font-size:12px;font-weight:700;display:flex}.advanced-collapse-toggle:hover{color:var(--accent)}.advanced-header-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.advanced-header-row .advanced-collapse-toggle{flex:1;margin-bottom:0}.advanced-header-toggle{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:5px;padding:4px 8px;font-size:10px;font-weight:700;transition:all .15s}.advanced-header-toggle.active{border-color:var(--accent);color:var(--accent);background:var(--surface);box-shadow:0 1px 3px var(--shadow)}.advanced-header-toggle:hover{color:var(--text)}.advanced-mode-card small{margin-top:6px;line-height:1.35;display:block}.advanced-block-separator{background:var(--border);opacity:.55;height:1px;margin:8px 2px 10px}.advanced-fixations-wrap .cs{padding-top:4px}.advanced-fixations-card{padding-top:2px}.advanced-fixations-wrap .cs h3{margin-bottom:4px}@keyframes border-rotate{0%{filter:hue-rotate()}to{filter:hue-rotate(360deg)}}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=900px) and (width>=701px){.app-main{flex-direction:column;overflow-y:auto}.sidebar-left{width:100%;min-width:unset;border-right:none;border-bottom:1px solid var(--border);max-height:380px;overflow-y:auto}.content-center{padding:10px}.sidebar-right{width:100%;min-width:unset;border-left:none;border-top:1px solid var(--border);flex-flow:wrap;gap:12px;padding:12px}.sidebar-right>*{flex:1;min-width:240px}}@media (width<=700px){.app-header{flex-wrap:wrap;gap:8px;padding:10px 14px}.app-header h1{font-size:16px}.app-header p{font-size:11px;display:none}.app-main{flex-direction:column;height:calc(100vh - 92px);overflow:hidden}.mobile-tabs{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.mobile-tab{text-align:center;cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 4px;font-size:12px;font-weight:600;transition:all .15s}.mobile-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.sidebar-left,.content-center,.sidebar-right{width:100%;min-width:unset;max-height:unset;border:none;flex:1;overflow-y:auto}.sidebar-left.mobile-panel,.content-center.mobile-panel,.sidebar-right.mobile-panel{height:100%;display:none}.sidebar-left.mobile-panel.active,.content-center.mobile-panel.active,.sidebar-right.mobile-panel.active{flex-direction:column;display:flex}.canvas-wrap{min-height:260px}.sidebar-right{flex-flow:column}.sidebar-right>*{min-width:unset}}@media (width>=701px){.mobile-tabs{display:none}}
