:root{--elma-blue: #2563eb;--elma-blue-dark: #1d4ed8;--elma-blue-light: #dbeafe;--color-success: #0d9488;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--surface-0: #ffffff;--surface-1: #f8fafc;--surface-2: #f1f5f9;--surface-3: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-inverse: #ffffff;--border: #e2e8f0;--border-strong: #cbd5e1;--border-focus: var(--elma-blue);--duct-spiro: #1565c0;--duct-fab: #6a1b9a;--duct-flex: #2e7d32;--drain-color: #d63384;--scale-color: #ff6d00;--measure-color: #f59e0b;--selection-color: #f97316;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--font-ui: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--font-display: "Outfit", "Inter", sans-serif;--text-xs: 10px;--text-sm: 11px;--text-base: 12px;--text-md: 13px;--text-lg: 14px;--text-xl: 16px;--text-2xl: 20px;--sidebar-width: 340px;--toolbar-height: 44px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 2px 8px rgba(0,0,0,.1);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--z-toolbar: 100;--z-sidebar: 90;--z-modal: 200;--z-toast: 300}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-ui);font-size:var(--text-base);color:var(--text-primary);background:var(--surface-2);height:100%;overflow:hidden}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:5px 12px;font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background .1s,border-color .1s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--elma-blue);color:var(--text-inverse);border-color:var(--elma-blue-dark)}.btn-primary:hover:not(:disabled){background:var(--elma-blue-dark)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--surface-3);color:var(--text-primary)}.btn-danger{background:var(--color-danger);color:#fff;border-color:#dc2626}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:3px 8px;font-size:var(--text-xs)}.btn-icon{padding:5px;width:28px;height:28px;justify-content:center}.btn-icon.active{background:var(--elma-blue-light);color:var(--elma-blue);border-color:var(--elma-blue)}.form-group{display:flex;flex-direction:column;gap:4px}label{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);letter-spacing:.03em}input,select,textarea{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--text-primary);background:var(--surface-0);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:5px 8px;width:100%;transition:border-color .1s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 2px #2563eb1f}.card{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.card-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);font-size:var(--text-md);font-weight:600;display:flex;align-items:center;gap:var(--space-2)}.card-body{padding:var(--space-4)}.table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.table th{padding:6px 10px;text-align:left;font-weight:600;font-size:var(--text-xs);color:var(--text-secondary);background:var(--surface-1);border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:5px 10px;border-bottom:1px solid var(--border);color:var(--text-primary)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--surface-1)}.table .mono{font-family:var(--font-mono);font-size:var(--text-xs)}.badge{display:inline-flex;align-items:center;padding:1px 6px;font-size:var(--text-xs);font-weight:600;border-radius:100px}.badge-blue{background:var(--elma-blue-light);color:var(--elma-blue-dark)}.badge-green{background:#d1fae5;color:#065f46}.badge-orange{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-gray{background:var(--surface-3);color:var(--text-secondary)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#0f172a8c;display:flex;align-items:center;justify-content:center}.modal{background:var(--surface-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:360px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:var(--text-xl);font-weight:700;font-family:var(--font-display)}.modal-body{padding:var(--space-5) var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:var(--space-2)}#toast-container{position:fixed;bottom:var(--space-5);right:var(--space-5);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2)}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--text-primary);color:var(--text-inverse);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:var(--text-sm);min-width:260px;animation:toast-in .2s ease}.toast-success{border-left:3px solid var(--color-success)}.toast-error{border-left:3px solid var(--color-danger)}.toast-warning{border-left:3px solid var(--color-warning)}.toast-info{border-left:3px solid var(--color-info)}@keyframes toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toolbar{background:var(--surface-0);border-bottom:1px solid var(--border);display:flex;flex-direction:column;padding:4px var(--space-3);z-index:var(--z-toolbar);flex-shrink:0;gap:2px}.toolbar-row{display:flex;align-items:center;gap:4px;min-height:32px;flex-wrap:nowrap;width:100%}.toolbar-sep{width:1px;height:20px;background:var(--border-strong);margin:0 4px;flex-shrink:0}.toolbar-group{display:flex;align-items:center;gap:2px;flex-shrink:0}.toolbar-label{font-size:10px;color:var(--text-tertiary);font-weight:600;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.btn-icon{display:flex;align-items:center;gap:5px;white-space:nowrap;padding:4px 8px!important;font-size:var(--text-xs)!important}.sidebar{width:var(--sidebar-width);background:var(--surface-0);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.sidebar-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);font-size:var(--text-md);font-weight:600;display:flex;align-items:center;justify-content:space-between}.sidebar-body{flex:1;overflow-y:auto;padding:var(--space-3)}#plan-container{flex:1;position:relative;background:var(--surface-2);overflow:hidden}#konva-container{width:100%;height:100%;cursor:default}.checklist-item{padding:6px 8px;margin-bottom:2px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--surface-0);transition:background .1s}.checklist-item:hover{background:var(--surface-1)}.checklist-item.selected{border-color:var(--elma-blue);background:var(--elma-blue-light)}.checklist-item.verified{opacity:.55}.checklist-item.verified .item-id{text-decoration:line-through;color:var(--text-tertiary)}.item-header{display:flex;align-items:center;gap:var(--space-2)}.item-id{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:600}.item-type{font-size:var(--text-xs);color:var(--text-secondary)}.item-kw{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--elma-blue);margin-left:auto}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6) var(--space-4);text-align:center;gap:var(--space-3)}.empty-state-icon{font-size:32px;opacity:.4}.empty-state-title{font-size:var(--text-lg);font-weight:600;color:var(--text-secondary)}.empty-state-desc{font-size:var(--text-sm);color:var(--text-tertiary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}#app{display:flex;flex-direction:column;height:100vh;overflow:hidden}#nav{height:56px;min-height:56px;background:var(--text-primary);color:var(--text-inverse);font-family:var(--font-ui);display:flex;align-items:center;gap:var(--space-4);padding:0 var(--space-5);flex-shrink:0;z-index:110;box-shadow:0 1px #ffffff0f}.nav-logo{display:flex;align-items:center;cursor:default;-webkit-user-select:none;user-select:none}.nav-logo-img{height:36px;width:auto;max-width:200px;display:block;object-fit:contain}.nav-links{display:flex;align-items:center;gap:var(--space-1);margin-left:var(--space-2)}.nav-link{padding:5px 10px;font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;color:#ffffffb3;border-radius:var(--radius-sm);cursor:pointer;border:none;background:none;transition:background .1s,color .1s}.nav-link:hover{background:#ffffff14;color:#fff}.nav-link.active{background:#ffffff1f;color:#fff}.nav-right{margin-left:auto;display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-ui)}.nav-user{font-size:var(--text-sm);color:#fff9}.nav-org{font-size:var(--text-sm);font-weight:600;color:#ffffffe6}.view{display:none;flex:1;overflow:hidden}.view.active{display:flex;flex-direction:column}#view-projects{flex-direction:column}.projects-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border);background:var(--surface-0);display:flex;align-items:center;gap:var(--space-3)}.projects-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700}.projects-search{flex:1;max-width:320px}.projects-list{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}.project-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface-0);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .1s,box-shadow .1s}.project-row:hover{border-color:var(--elma-blue);box-shadow:var(--shadow-sm)}.project-job{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);width:90px;flex-shrink:0}.project-name{font-size:var(--text-md);font-weight:600;flex:1}.project-client{font-size:var(--text-sm);color:var(--text-secondary);width:160px}.project-updated{font-size:var(--text-xs);color:var(--text-tertiary);width:100px;text-align:right}#view-plan{flex-direction:row}.plan-layout{display:flex;flex-direction:column;flex:1;overflow:hidden}.plan-body{display:flex;flex:1;overflow:hidden}#view-login{justify-content:center;align-items:center;background:var(--surface-1)}.login-card{width:100%;max-width:380px;padding:var(--space-6)}.login-logo{font-family:var(--font-display);font-size:28px;font-weight:700;text-align:center;margin-bottom:var(--space-6)}.login-logo span{color:var(--elma-blue)}.login-form{display:flex;flex-direction:column;gap:var(--space-4)}.login-error{color:var(--color-danger);font-size:var(--text-sm);text-align:center}.takeoff-panel{height:260px;flex-shrink:0;border-top:1px solid var(--border);background:var(--surface-0);overflow:hidden;display:flex;flex-direction:column}.takeoff-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 var(--space-3);flex-shrink:0}.takeoff-tab{padding:6px 12px;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px}.takeoff-tab.active{color:var(--elma-blue);border-bottom-color:var(--elma-blue)}.takeoff-body{flex:1;overflow-y:auto}.takeoff-totals{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);display:flex;align-items:center;gap:var(--space-5);background:var(--surface-1);flex-shrink:0;font-size:var(--text-sm)}.total-label{color:var(--text-secondary)}.total-value{font-family:var(--font-mono);font-weight:700;font-size:var(--text-md)}.total-value.grand{font-size:var(--text-xl);color:var(--elma-blue)}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:150;background:#ffffffd9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4)}.spinner{width:32px;height:32px;border:3px solid var(--border-strong);border-top-color:var(--elma-blue);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{font-size:var(--text-sm);color:var(--text-secondary)}.progress-bar-track{width:240px;height:4px;background:var(--surface-3);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--elma-blue);border-radius:2px;transition:width .3s ease}#konva-container,#konva-container *{touch-action:none;user-select:none;-webkit-user-select:none}
