.user-menu{position:relative}.user-menu__login-btn{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-md);background:var(--color-accent);color:#fff;border-radius:var(--border-radius-sm);font-size:.875rem;font-weight:500;text-decoration:none;transition:background-color .15s ease}.user-menu__login-btn:hover{background:var(--color-accent-hover)}.user-menu__trigger{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs);background:transparent;border:1px solid transparent;border-radius:var(--border-radius-sm);cursor:pointer;color:var(--color-text-primary);transition:background-color .15s ease,border-color .15s ease}.user-menu__trigger:hover{background:var(--color-bg-secondary);border-color:var(--color-border)}.user-menu__avatar{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-accent);color:#fff;border-radius:50%;font-size:.75rem;font-weight:600}.user-menu__avatar--large{width:40px;height:40px;font-size:1rem}.user-menu__name{font-size:.875rem;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu__arrow{transition:transform .15s ease}.user-menu__arrow--open{transform:rotate(180deg)}.user-menu__dropdown{position:absolute;top:calc(100% + var(--spacing-xs));right:0;min-width:240px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-md);box-shadow:0 4px 12px #0000004d;z-index:1000;overflow:hidden}.user-menu__header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md)}.user-menu__info{display:flex;flex-direction:column;gap:2px;min-width:0}.user-menu__username{font-size:.875rem;font-weight:600;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu__email{font-size:.75rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu__divider{height:1px;background:var(--color-border);margin:0}.user-menu__item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;color:var(--color-text-primary);font-size:.875rem;text-align:left;text-decoration:none;cursor:pointer;transition:background-color .15s ease}.user-menu__item:hover{background:var(--color-bg-tertiary)}.user-menu__item svg{color:var(--color-text-secondary)}.user-menu__item--danger{color:#ef4444}.user-menu__item--danger:hover{background:#ef44441a}.user-menu__item--danger svg{color:#ef4444}.topnav{grid-area:topnav;display:flex;align-items:center;padding:0 var(--spacing-md);background-color:var(--color-bg-primary);border-bottom:1px solid var(--color-border);height:var(--topnav-height);gap:var(--spacing-lg)}.topnav-left{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.topnav-logo{font-size:var(--font-size-xl);font-weight:700;color:var(--color-accent);letter-spacing:1px}.topnav-title{font-size:var(--font-size-lg);font-weight:500;color:var(--color-text-primary)}.topnav-divider{color:var(--color-border);font-weight:300;margin:0 var(--spacing-xs)}.topnav-project{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:none;border:none;padding:var(--spacing-xs) var(--spacing-sm);margin:0;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.topnav-project--clickable:hover{color:var(--color-accent);background-color:var(--color-bg-hover)}.topnav-project--clickable:active{background-color:var(--color-bg-tertiary)}.topnav-right{display:flex;align-items:center;gap:var(--spacing-md);margin-left:auto}.topnav-tabs{display:flex;align-items:center;gap:var(--spacing-xs);height:100%;padding-left:var(--spacing-md);border-left:1px solid var(--color-border)}.topnav-tab{display:flex;align-items:center;height:100%;padding:0 var(--spacing-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted);text-decoration:none;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.topnav-tab:hover{color:var(--color-text-primary);background-color:var(--color-bg-hover)}.topnav-tab--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.topnav-tab--active:hover{color:var(--color-accent)}.topnav-status{display:flex;align-items:center;gap:var(--spacing-xs)}.status-dot{width:8px;height:8px;border-radius:50%;background-color:var(--color-text-muted)}.status-dot--connected{background-color:var(--color-success);box-shadow:0 0 6px var(--color-success)}.status-dot--disconnected{background-color:var(--color-error)}.status-text{font-size:var(--font-size-sm);color:var(--color-text-muted)}.sidebar{grid-area:sidebar;background:linear-gradient(180deg,#0d0d0d,#0a0a0a);border-right:1px solid var(--color-border);width:var(--sidebar-width);overflow-y:auto;display:flex;flex-direction:column;box-shadow:2px 0 12px #0000004d,inset -1px 0 #ffffff05}.sidebar-header{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 100%)}.sidebar-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--color-text-muted);display:flex;align-items:center;gap:var(--spacing-sm)}.sidebar-title:before{content:"";width:3px;height:12px;background:linear-gradient(180deg,var(--color-accent) 0%,#0088aa 100%);border-radius:2px}.sidebar-nav{list-style:none;margin:0;padding:var(--spacing-xs) 0}.sidebar-nav-item{margin:0;padding:0 var(--spacing-xs)}.sidebar-nav-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-sm);margin:2px 0;color:var(--color-text-muted);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-sm);border-left:2px solid transparent;position:relative;transition:all .2s ease}.sidebar-nav-link:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:2px;height:0;background:var(--color-accent);border-radius:1px;transition:height .2s ease}.sidebar-nav-link:hover{background:#ffffff0a;color:var(--color-text-secondary)}.sidebar-nav-link:hover .sidebar-nav-icon{color:var(--color-text-secondary);transform:scale(1.05)}.sidebar-nav-link--active{background:linear-gradient(90deg,rgba(0,212,255,.1) 0%,transparent 100%);color:var(--color-accent);border-left-color:transparent}.sidebar-nav-link--active:before{height:60%;box-shadow:0 0 8px var(--color-accent)}.sidebar-nav-link--active .sidebar-nav-icon{color:var(--color-accent);filter:drop-shadow(0 0 4px var(--color-accent))}.sidebar-nav-link--active .sidebar-nav-label{text-shadow:0 0 10px rgba(0,212,255,.3)}.sidebar-nav-icon{width:18px;height:18px;flex-shrink:0;color:var(--color-text-muted);transition:all .2s ease}.sidebar-nav-icon svg{width:100%;height:100%}.sidebar-nav-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav-item--results{margin-top:var(--spacing-md);padding-top:var(--spacing-sm);border-top:1px solid rgba(255,255,255,.06)}.sidebar-nav-link--results{background:linear-gradient(135deg,#10b98126,#06b6d41a);border:1px solid rgba(16,185,129,.3);border-left:3px solid #10b981;border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md)!important;color:#10b981;font-weight:600;position:relative;overflow:hidden}.sidebar-nav-link--results:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 0%,rgba(16,185,129,.1) 100%);opacity:0;transition:opacity .3s ease}.sidebar-nav-link--results:hover{background:linear-gradient(135deg,#10b98140,#06b6d426);border-color:#10b98180;color:#34d399;transform:translate(2px)}.sidebar-nav-link--results:hover:after{opacity:1}.sidebar-nav-link--results .sidebar-nav-icon{color:#10b981;filter:drop-shadow(0 0 3px rgba(16,185,129,.5))}.sidebar-nav-link--results:hover .sidebar-nav-icon{color:#34d399;filter:drop-shadow(0 0 6px rgba(16,185,129,.7));transform:scale(1.1)}.sidebar-nav-link--results .sidebar-nav-label{text-shadow:0 0 8px rgba(16,185,129,.3)}.sidebar-nav-link--results.sidebar-nav-link--active{background:linear-gradient(135deg,#10b9814d,#06b6d433);border-color:#10b981;color:#34d399;box-shadow:0 0 20px #10b98133,inset 0 1px #ffffff1a}.sidebar-nav-link--results.sidebar-nav-link--active:before{background:#10b981;box-shadow:0 0 12px #10b981}.sidebar-nav-link--results.sidebar-nav-link--active .sidebar-nav-icon{color:#34d399;filter:drop-shadow(0 0 8px rgba(16,185,129,.8))}.sidebar-quick-controls{padding:var(--spacing-sm) var(--spacing-xs);border-top:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,#0000001a,#0003)}.sidebar-quick-controls__header{padding:0 var(--spacing-xs) 4px}.sidebar-quick-controls__title{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);opacity:.7}.sidebar-quick-controls__list{display:flex;flex-direction:column;gap:4px}.quick-control{display:flex;flex-direction:column;gap:4px;padding:6px 8px;background:#ffffff05;border-radius:var(--radius-sm);border:1px solid transparent;transition:all .15s ease}.quick-control:hover{background:#ffffff0a;border-color:#ffffff0f}.quick-control__label{font-size:9px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.quick-control__input{display:flex;align-items:center;justify-content:space-between;gap:4px}.quick-control__value{font-size:11px;font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary);text-align:right;cursor:pointer;padding:2px 3px;border-radius:3px;transition:all .15s ease}.quick-control__value:hover{background:#00d4ff1a;color:var(--color-accent)}.quick-control__unit{font-size:9px;font-weight:400;color:var(--color-text-muted);min-width:24px}.quick-control__edit-input{width:55px;min-width:0;padding:2px 4px;font-size:12px;font-weight:600;font-family:var(--font-mono);color:var(--color-accent);text-align:right;background:#00d4ff1a;border:1px solid var(--color-accent);border-radius:3px;outline:none;box-shadow:0 0 6px #00d4ff4d}.quick-control__edit-input:focus{background:#00d4ff26;box-shadow:0 0 8px #00d4ff66}.quick-control__edit-input::-webkit-outer-spin-button,.quick-control__edit-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quick-control__edit-input[type=number]{-moz-appearance:textfield}.quick-control__btn{width:18px;height:18px;padding:0;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:3px;color:var(--color-text-muted);cursor:pointer;transition:all .15s ease}.quick-control__btn svg{width:11px;height:11px}.quick-control__btn:hover:not(:disabled){background:#10b98133;border-color:#10b98166;color:#10b981}.quick-control__btn:active:not(:disabled){transform:scale(.9)}.quick-control__btn:disabled{opacity:.3;cursor:not-allowed}.quick-control__btn--up:hover:not(:disabled){transform:scale(1.05)}.quick-control__btn--up:active:not(:disabled){transform:scale(.9)}.sidebar-footer{margin-top:auto;padding:var(--spacing-sm) var(--spacing-xs);border-top:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.2) 100%)}.sidebar-nav-link--settings{opacity:.7}.sidebar-nav-link--settings:hover,.sidebar-nav-link--settings.sidebar-nav-link--active{opacity:1}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:#fff3}.well-schematic-container{display:flex;flex-direction:column;width:100%;height:100%;background-color:var(--color-bg-primary);overflow:hidden;position:relative}.well-schematic-svg{flex:1;width:100%;min-height:0}.schematic-info-bar{display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-start;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-panel);border-bottom:1px solid var(--color-border);min-height:60px;height:60px;box-sizing:border-box;overflow:hidden}.info-item{display:flex;flex-direction:column;align-items:center;gap:1px;min-width:45px;flex-shrink:0}.info-label{font-size:8px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.info-value{font-size:11px;font-weight:600;color:var(--color-text-primary);font-family:var(--font-mono);white-space:nowrap}.info-value.status-ok{color:var(--color-success)}.info-value.status-warning{color:var(--color-warning)}.info-divider{display:none}.export-btn{padding:4px 8px;background:var(--color-bg-tertiary, #1f1f1f);border:1px solid var(--color-border, #2d2d2d);border-radius:4px;color:var(--color-text-secondary, #a3a3a3);font-size:10px;font-weight:500;cursor:pointer;transition:all .15s ease;margin-left:auto;flex-shrink:0;white-space:nowrap}.export-btn:hover{background:var(--color-bg-active, #262626);border-color:var(--color-accent, #3b82f6);color:var(--color-text-primary, #fafafa)}.export-btn:active{transform:scale(.98)}.schematic-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-lg);text-align:center}.schematic-empty p{margin:0;color:var(--color-text-muted);font-size:var(--font-size-md)}.schematic-empty .empty-hint{margin-top:var(--spacing-xs);font-size:var(--font-size-sm);opacity:.7}.depth-scale-label{font-weight:600;text-transform:uppercase;letter-spacing:.5px}.casing-section{transition:stroke-width .15s ease}.casing-section:hover{stroke-width:3}.casing-section.openhole{stroke-dasharray:4,2}.drillstring-segment{transition:opacity .15s ease}.drillstring-segment:hover{opacity:.9}.formation-fill{transition:fill-opacity .15s ease}.bit-indicator polygon{transition:fill .15s ease}.bit-indicator:hover polygon{fill:#777}.casing-shoe polygon{transition:fill .15s ease}.liner-hanger line{stroke-linecap:round}.well-schematic__segment-hitbox{fill:transparent;cursor:pointer}.well-schematic__segment-hitbox--hovered{fill:#3b82f614}.well-schematic__segment-hitbox--selected{fill:#3b82f61f}.well-schematic__tooltip{position:absolute;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-sm);font-size:var(--font-size-sm);pointer-events:none;z-index:5;box-shadow:var(--shadow-md)}.well-schematic__tooltip-row{display:flex;justify-content:space-between;gap:var(--spacing-md)}.well-schematic__tooltip-label{color:var(--color-text-secondary)}.well-schematic__tooltip-value{color:var(--color-text-primary);font-weight:500}@media (max-width: 480px){.schematic-info-bar{gap:var(--spacing-xs);padding:var(--spacing-xs)}.info-item{min-width:40px}.info-label{font-size:7px}.info-value{font-size:10px}.export-btn{padding:3px 6px;font-size:9px}}.bit-depth-control{display:flex;flex-direction:column;width:50px;flex-shrink:0;background-color:var(--color-bg-panel);border-left:1px solid var(--color-border)}.bit-depth-info{height:60px;min-height:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border-bottom:1px solid var(--color-border);box-sizing:border-box}.bit-depth-value-display{display:flex;flex-direction:column;align-items:center;text-align:center}.bit-depth-label{font-size:8px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px}.bit-depth-value{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent);font-family:var(--font-mono)}.bit-depth-percentage{font-size:8px;color:var(--color-text-muted)}.at-bottom-indicator{font-size:8px;color:var(--color-success);font-weight:600;padding:1px 4px;background-color:#2ed57333;border-radius:2px}.vertical-slider-container{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;padding-top:20px;padding-bottom:30px;min-height:100px}.slider-marker{position:absolute;left:50%;transform:translate(-50%);font-size:8px;color:var(--color-text-muted);font-family:var(--font-mono);line-height:1;background-color:var(--color-bg-panel);padding:1px 2px;z-index:1}.slider-marker.top{top:8px}.slider-marker.bottom{bottom:18px}.bit-depth-slider.vertical{flex:1;width:100%;min-height:80px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer;margin:0;padding:0;writing-mode:vertical-lr;direction:rtl}.bit-depth-slider.vertical::-webkit-slider-runnable-track{width:6px;height:100%;background:linear-gradient(to bottom,var(--color-bg-hover) 0%,var(--color-accent) 100%);border-radius:3px;border:1px solid var(--color-border)}.bit-depth-slider.vertical::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:10px;background-color:var(--color-accent);border:1px solid var(--color-bg-primary);border-radius:2px;cursor:grab;box-shadow:0 1px 3px #0006;margin-left:-6px}.bit-depth-slider.vertical::-webkit-slider-thumb:hover{background-color:#00e5ff;box-shadow:0 2px 6px #00d4ff80}.bit-depth-slider.vertical::-webkit-slider-thumb:active{cursor:grabbing;box-shadow:0 3px 8px #00d4ffb3}.bit-depth-slider.vertical::-moz-range-track{width:6px;height:100%;background:linear-gradient(to bottom,var(--color-bg-hover) 0%,var(--color-accent) 100%);border-radius:3px;border:1px solid var(--color-border)}.bit-depth-slider.vertical::-moz-range-thumb{width:18px;height:10px;background-color:var(--color-accent);border:1px solid var(--color-bg-primary);border-radius:2px;cursor:grab;box-shadow:0 1px 3px #0006}.bit-depth-slider.vertical::-moz-range-thumb:hover{background-color:#00e5ff;box-shadow:0 2px 6px #00d4ff80}.bit-depth-slider.vertical::-moz-range-thumb:active{cursor:grabbing;box-shadow:0 3px 8px #00d4ffb3}.schematic-panel{display:flex;flex-direction:column;background-color:var(--color-bg-secondary);border-left:1px solid var(--color-border);flex:1;min-width:0}.schematic-header{padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid var(--color-border);flex-shrink:0;display:flex;align-items:center;min-height:32px}.schematic-title{margin:0;font-size:12px;font-weight:500;color:var(--color-text-primary)}.schematic-body{flex:1;display:flex;min-height:0;overflow:hidden}.schematic-canvas{flex:1;display:flex;flex-direction:column;background-color:var(--color-bg-primary);min-height:0;min-width:0;overflow:hidden}.statusbar{grid-area:status;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-md);background-color:var(--color-bg-primary);border-top:1px solid var(--color-border);height:var(--statusbar-height);font-size:var(--font-size-sm)}.statusbar-left{display:flex;align-items:center;gap:var(--spacing-xs)}.statusbar-indicator{width:8px;height:8px;border-radius:50%;background-color:var(--color-text-muted)}.statusbar-indicator--ready{background-color:var(--color-success)}.statusbar-indicator--error{background-color:var(--color-error)}.statusbar-indicator--warning{background-color:var(--color-warning)}.statusbar-status{color:var(--color-text-muted)}.statusbar-center{flex:1;text-align:center}.statusbar-messages{color:var(--color-text-muted)}.statusbar-right{display:flex;align-items:center;gap:var(--spacing-md)}.statusbar-date,.statusbar-time{color:var(--color-text-muted)}.statusbar-time{font-family:Consolas,Monaco,monospace}.resizer{position:relative;flex-shrink:0;z-index:10}.resizer.vertical{width:4px;cursor:col-resize;background-color:transparent;transition:background-color .15s ease}.resizer.horizontal{height:4px;cursor:row-resize;background-color:transparent;transition:background-color .15s ease}.resizer:hover,.resizer.dragging{background-color:var(--color-accent)}.resizer-handle{position:absolute;background-color:transparent}.resizer.vertical .resizer-handle{top:0;bottom:0;left:-2px;right:-2px;width:8px}.resizer.horizontal .resizer-handle{left:0;right:0;top:-2px;bottom:-2px;height:8px}.resizer.vertical:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:20px;background-color:var(--color-border);border-radius:1px;opacity:0;transition:opacity .15s ease}.resizer.vertical:hover:before,.resizer.vertical.dragging:before{opacity:1}.app-shell{display:grid;grid-template-areas:"topnav topnav" "sidebar main-area" "status status";grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--topnav-height) 1fr var(--statusbar-height);height:100vh;width:100vw;overflow:hidden;background-color:var(--color-bg-primary)}.main-area{grid-area:main-area;display:flex;min-height:0;overflow:hidden}.content-panel{flex:1;min-width:0;overflow:auto;background-color:var(--color-bg-secondary);padding:var(--spacing-md)}.formation-dropdown-container{position:relative;display:inline-block;width:100%;min-width:140px}.formation-dropdown-trigger{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-input);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:inherit;cursor:pointer;text-align:left;transition:border-color var(--transition-fast)}.formation-dropdown-trigger:hover{border-color:var(--color-accent)}.formation-dropdown-trigger:focus{outline:none;border-color:var(--color-accent)}.formation-dropdown-trigger:disabled{background:var(--color-bg-panel);color:var(--color-text-muted);cursor:not-allowed}.formation-dropdown-trigger.error{border-color:var(--color-error)}.formation-swatch,.formation-dropdown-trigger svg,.formation-option svg,.formation-readonly svg{flex-shrink:0}.formation-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{flex-shrink:0;font-size:10px;color:var(--color-text-muted)}.formation-dropdown-panel{position:absolute;top:100%;left:0;right:0;z-index:100;margin-top:2px;background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0006;max-height:300px;overflow:hidden;display:flex;flex-direction:column}.formation-search{padding:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.formation-search input{width:100%;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-input);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:inherit}.formation-search input:focus{outline:none;border-color:var(--color-accent)}.formation-search input::placeholder{color:var(--color-text-muted)}.formation-list{flex:1;overflow-y:auto;padding:var(--spacing-xs) 0}.formation-category{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);background:var(--color-bg-secondary);border-top:1px solid var(--color-border)}.formation-category:first-child{border-top:none}.formation-option{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);padding-left:var(--spacing-md);cursor:pointer;transition:background var(--transition-fast)}.formation-option:hover{background:var(--color-bg-hover)}.formation-option.selected{background:#00d4ff1a}.formation-option svg{flex-shrink:0}.formation-option .formation-name{font-size:var(--font-size-sm);color:var(--color-text-primary)}.no-results{padding:var(--spacing-md);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.formation-readonly{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0}.formation-readonly svg{flex-shrink:0}.formation-readonly .formation-name{font-size:var(--font-size-sm);color:var(--color-text-primary)}.numeric-input{display:flex;flex-direction:column;gap:var(--spacing-xs)}.numeric-input__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.numeric-input__wrapper{display:flex;align-items:center;gap:var(--spacing-xs)}.numeric-input__btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-md);cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.numeric-input__btn:hover:not(:disabled){background-color:var(--color-border);color:var(--color-text-primary)}.numeric-input__btn:disabled{opacity:.4;cursor:not-allowed}.numeric-input__field{width:100px;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-md);text-align:center;font-family:var(--font-mono)}.numeric-input__field:focus{outline:none;border-color:var(--color-accent)}.numeric-input__field:disabled{opacity:.6;cursor:not-allowed}.numeric-input__field--invalid{border-color:var(--color-error);background-color:#ef44441a}.numeric-input__unit{font-size:var(--font-size-sm);color:var(--color-text-muted);min-width:40px}.numeric-input--compact .numeric-input__field{width:70px;padding:4px var(--spacing-xs)}.numeric-input--compact .numeric-input__btn{width:24px;height:24px;font-size:var(--font-size-sm)}.numeric-input--no-buttons .numeric-input__btn{display:none}.numeric-input--no-buttons .numeric-input__field{width:120px}.radio-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.radio-group__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.radio-group__options{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.radio-group__option{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);transition:background-color .15s ease}.radio-group__option:hover:not(.radio-group__option--disabled){background-color:var(--color-bg-tertiary)}.radio-group__option--disabled{opacity:.5;cursor:not-allowed}.radio-group__input{position:absolute;opacity:0;pointer-events:none}.radio-group__indicator{width:18px;height:18px;border:2px solid var(--color-border-light);border-radius:50%;position:relative;transition:all .15s ease}.radio-group__option--selected .radio-group__indicator{border-color:var(--color-accent)}.radio-group__indicator:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);width:8px;height:8px;background-color:var(--color-accent);border-radius:50%;transition:transform .15s ease}.radio-group__option--selected .radio-group__indicator:after{transform:translate(-50%,-50%) scale(1)}.radio-group__text{font-size:var(--font-size-md);color:var(--color-text-primary)}.radio-group--buttons .radio-group__options{gap:0}.radio-group--buttons .radio-group__option{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:0;background-color:var(--color-bg-primary)}.radio-group--buttons .radio-group__option:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.radio-group--buttons .radio-group__option:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0;border-left:none}.radio-group--buttons .radio-group__option:not(:first-child):not(:last-child){border-left:none}.radio-group--buttons .radio-group__option--selected{background-color:var(--color-accent);border-color:var(--color-accent)}.radio-group--buttons .radio-group__option--selected .radio-group__text{color:var(--color-bg-primary)}.radio-group--buttons .radio-group__indicator{display:none}.simple-chart{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.simple-chart--empty{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.simple-chart__grid-line{stroke:var(--color-border);stroke-width:1;stroke-dasharray:2,2}.simple-chart__axis{stroke:var(--color-border-light);stroke-width:1}.simple-chart__tick-label{fill:var(--color-text-muted);font-size:10px;font-family:var(--font-mono)}.simple-chart__axis-label{fill:var(--color-text-secondary);font-size:11px}.simple-chart__line{transition:stroke .15s ease}.simple-chart__point{transition:r .15s ease}.simple-chart__point:hover{r:6}.trajectory-plot-container{position:relative;width:auto;height:auto;min-height:350px}.trajectory-plot{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);max-width:100%;max-height:100%}.trajectory-plot--empty{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:var(--font-size-sm);width:100%;height:100%;min-height:300px;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.trajectory-plot__grid-line{stroke:var(--color-border);stroke-width:1;stroke-dasharray:2,2}.trajectory-plot__axis{stroke:var(--color-border-light);stroke-width:1}.trajectory-plot__tick-label{fill:var(--color-text-muted);font-size:10px;font-family:var(--font-mono)}.trajectory-plot__axis-label{fill:var(--color-text-secondary);font-size:11px}.trajectory-plot__line{transition:stroke .15s ease}.trajectory-plot__point-group,.trajectory-plot__point-hitarea{cursor:pointer}.trajectory-plot__point{transition:r .2s ease,filter .2s ease;pointer-events:none}.trajectory-plot__point--active{filter:drop-shadow(0 0 6px var(--color-accent))}.trajectory-plot__point-label{fill:var(--color-text-muted);font-size:9px;font-family:var(--font-mono);pointer-events:none}.trajectory-plot__tooltip{position:absolute;transform:translate(-50%,-110%);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 16px #0006;padding:0;pointer-events:none;z-index:100;min-width:150px;animation:tooltip-fade-in .15s ease}@keyframes tooltip-fade-in{0%{opacity:0;transform:translate(-50%,-105%)}to{opacity:1;transform:translate(-50%,-110%)}}.trajectory-plot__tooltip-header{padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-accent);color:var(--color-bg-primary);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-md) var(--radius-md) 0 0;text-align:center}.trajectory-plot__tooltip-content{padding:var(--spacing-xs) var(--spacing-sm)}.trajectory-plot__tooltip-row{display:flex;justify-content:space-between;gap:var(--spacing-md);padding:2px 0;font-size:var(--font-size-sm)}.trajectory-plot__tooltip-label{color:var(--color-text-muted)}.trajectory-plot__tooltip-value{color:var(--color-text-primary);font-family:var(--font-mono);font-weight:500}.temperature-chart{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.temperature-chart--empty{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.temperature-chart__grid-line{stroke:var(--color-border);stroke-width:1;stroke-dasharray:2,2}.temperature-chart__axis{stroke:var(--color-border-light);stroke-width:1}.temperature-chart__tick-label{fill:var(--color-text-muted);font-size:10px;font-family:var(--font-mono)}.temperature-chart__axis-label{fill:var(--color-text-secondary);font-size:11px}.temperature-chart__line{transition:stroke .15s ease}.temperature-chart__point{transition:r .15s ease}.temperature-chart__point:hover{r:7}.cfr-depth-chart{width:100%;height:100%;background:linear-gradient(180deg,#0d0d0d,#141414);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;flex:1;box-shadow:0 4px 20px #0006,inset 0 1px #ffffff08;overflow:hidden}.cfr-depth-chart__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 100%);border-bottom:1px solid var(--color-border)}.cfr-depth-chart__title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);letter-spacing:.3px;display:flex;align-items:center;gap:var(--spacing-sm)}.cfr-depth-chart__title:before{content:"";width:3px;height:16px;background:linear-gradient(180deg,var(--color-accent) 0%,#0088aa 100%);border-radius:2px}.cfr-depth-chart__controls{display:flex;align-items:center;gap:var(--spacing-md)}.cfr-depth-chart__toggle-group{display:flex;gap:2px;background:#0000004d;padding:2px;border-radius:6px;border:1px solid rgba(255,255,255,.05)}.cfr-depth-chart__toggle{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:4px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;border:none;background:transparent;font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-muted)}.cfr-depth-chart__toggle:hover{color:var(--color-text-secondary);background:#ffffff08}.cfr-depth-chart__toggle--active{background:#ffffff14;color:var(--color-text-primary)}.cfr-depth-chart__toggle--cfr.cfr-depth-chart__toggle--active{color:#60a5fa;background:#3b82f626;box-shadow:0 0 8px #3b82f633}.cfr-depth-chart__toggle--critical.cfr-depth-chart__toggle--active{color:#34d399;background:#10b98126;box-shadow:0 0 8px #10b98133}.cfr-depth-chart__toggle--actual.cfr-depth-chart__toggle--active{color:#fbbf24;background:#f59e0b26;box-shadow:0 0 8px #f59e0b33}.cfr-depth-chart__toggle-indicator{width:6px;height:6px;border-radius:50%;transition:all .2s ease}.cfr-depth-chart__toggle--cfr .cfr-depth-chart__toggle-indicator{background:#3b82f6;box-shadow:0 0 6px #3b82f6}.cfr-depth-chart__toggle--critical .cfr-depth-chart__toggle-indicator{background:#10b981;box-shadow:0 0 6px #10b981}.cfr-depth-chart__toggle--actual .cfr-depth-chart__toggle-indicator{background:#f59e0b;box-shadow:0 0 6px #f59e0b}.cfr-depth-chart__toggle:not(.cfr-depth-chart__toggle--active) .cfr-depth-chart__toggle-indicator{opacity:.3;box-shadow:none}.cfr-depth-chart__chart-area{flex:1;min-height:0;padding:var(--spacing-xs)}.cfr-depth-chart svg{width:100%;height:100%}.cfr-depth-chart--empty{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-style:italic;font-size:var(--font-size-sm)}.cfr-depth-chart__formation-column rect:first-child{filter:drop-shadow(2px 0 4px rgba(0,0,0,.3))}.cfr-depth-chart__formation-label{font-size:9px;fill:#1a1a1a;font-weight:600;text-shadow:0 0 3px rgba(255,255,255,.9),0 1px 2px rgba(0,0,0,.3);pointer-events:none;letter-spacing:.3px}.cfr-depth-chart__column-header{font-size:10px;fill:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.cfr-depth-chart__trajectory-column rect:first-child{filter:drop-shadow(2px 0 4px rgba(0,0,0,.3))}.cfr-depth-chart__trajectory-label{font-size:10px;fill:var(--color-text-primary);font-weight:600;pointer-events:none;letter-spacing:.3px}.cfr-depth-chart__trajectory-mode{font-size:8px;font-weight:700;text-transform:uppercase;pointer-events:none;letter-spacing:.5px;opacity:.8}.cfr-depth-chart__segment-separator{stroke:#ffffff14;stroke-width:1;stroke-dasharray:2,4}.cfr-depth-chart__axis{stroke:#ffffff26;stroke-width:1}.cfr-depth-chart__tick-label{font-size:9px;fill:var(--color-text-muted);font-weight:500}.cfr-depth-chart__axis-label{font-size:10px;fill:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.cfr-depth-chart__axis-label--cfr{fill:#60a5fa}.cfr-depth-chart__axis-label--velocity{fill:#34d399}.cfr-depth-chart__tick-label--cfr{fill:#60a5fa}.cfr-depth-chart__tick-label--velocity{fill:#34d399}.cfr-depth-chart__trend-line{stroke-width:2;fill:none;stroke-linejoin:round;stroke-linecap:round;transition:stroke-width .2s ease}.cfr-depth-chart__trend-line--cfr{stroke:#3b82f6}.cfr-depth-chart__trend-line--critical-velocity{stroke:#10b981;filter:drop-shadow(0 0 4px rgba(16,185,129,.4))}.cfr-depth-chart__trend-line--actual-velocity{stroke:#f59e0b;filter:drop-shadow(0 0 4px rgba(245,158,11,.4))}.cfr-depth-chart__segment-line{stroke-linecap:round;pointer-events:none}.cfr-depth-chart__segment-area{cursor:pointer;transition:all .2s ease}.cfr-depth-chart__segment-area--selected{stroke:var(--color-accent);stroke-width:1}.cfr-depth-chart__segment-area--hovered{fill-opacity:.12}.cfr-depth-chart__sag-zone{fill:#fbbf2414;stroke:#fbbf2466;stroke-width:1;stroke-dasharray:6,3}.cfr-depth-chart__reference-line{stroke:var(--color-accent);stroke-width:1.5;stroke-dasharray:8,4;filter:drop-shadow(0 0 6px rgba(0,212,255,.5))}.cfr-depth-chart__reference-label{font-size:9px;fill:var(--color-accent);font-weight:600;letter-spacing:.3px}.cfr-depth-chart__reference-badge{fill:#000000b3;stroke:var(--color-accent);stroke-width:1;rx:4}.cfr-depth-chart__legend{display:flex;gap:var(--spacing-xs);justify-content:center;flex-wrap:wrap;padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--color-border);background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.2) 100%)}.cfr-depth-chart__legend-section{display:flex;gap:var(--spacing-xs);align-items:center;padding:0 var(--spacing-sm);border-right:1px solid rgba(255,255,255,.06)}.cfr-depth-chart__legend-section:last-child{border-right:none}.cfr-depth-chart__legend-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--color-text-muted);padding:2px 6px;border-radius:4px;transition:all .15s ease}.cfr-depth-chart__legend-item:hover{background:#ffffff0d;color:var(--color-text-secondary)}.cfr-depth-chart__legend-color{width:10px;height:10px;border-radius:2px;flex-shrink:0}.cfr-depth-chart__legend-color--cfr-line{width:14px;height:2px;background:#3b82f6;border-radius:1px;box-shadow:0 0 4px #3b82f680}.cfr-depth-chart__legend-color--critical-velocity-line{width:14px;height:2px;border-radius:1px;background:repeating-linear-gradient(90deg,#10b981 0px,#10b981 2px,transparent 2px,transparent 4px);box-shadow:0 0 4px #10b98180}.cfr-depth-chart__legend-color--actual-velocity-line{width:14px;height:2px;border-radius:1px;background:repeating-linear-gradient(90deg,#f59e0b 0px,#f59e0b 4px,transparent 4px,transparent 7px);box-shadow:0 0 4px #f59e0b80}.cfr-depth-chart__legend-color--settling{background:#3b82f6;box-shadow:0 0 4px #3b82f666}.cfr-depth-chart__legend-color--lifting{background:#f59e0b;box-shadow:0 0 4px #f59e0b66}.cfr-depth-chart__legend-color--rolling{background:#ef4444;box-shadow:0 0 4px #ef444466}.cfr-depth-chart__legend-color--sag{background:#fbbf2433;border:1px dashed rgba(251,191,36,.6)}.cfr-depth-chart__legend-color--flow{width:14px;height:2px;background:repeating-linear-gradient(90deg,var(--color-accent) 0px,var(--color-accent) 5px,transparent 5px,transparent 8px);box-shadow:0 0 4px #00d4ff80}.cfr-depth-chart__tooltip{position:absolute;background:linear-gradient(135deg,#141414fa,#0a0a0afa);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);font-size:11px;pointer-events:none;z-index:100;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:180px}.cfr-depth-chart__tooltip:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(0,212,255,.3),transparent)}.cfr-depth-chart__tooltip-header{font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);padding-bottom:var(--spacing-xs);border-bottom:1px solid rgba(255,255,255,.06);font-size:10px;text-transform:uppercase;letter-spacing:.5px}.cfr-depth-chart__tooltip-row{display:flex;justify-content:space-between;gap:var(--spacing-md);padding:2px 0}.cfr-depth-chart__tooltip-label{color:var(--color-text-muted);font-weight:500}.cfr-depth-chart__tooltip-value{color:var(--color-text-primary);font-weight:600;font-family:SF Mono,Consolas,monospace}.cfr-depth-chart__tooltip-divider{height:1px;background:#ffffff0f;margin:var(--spacing-xs) 0}.cfr-depth-chart__tooltip-warning{display:flex;align-items:center;gap:4px;margin-top:var(--spacing-xs);padding:4px 6px;background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:4px;color:#fbbf24;font-weight:500}.cfr-depth-chart__tooltip-change{margin-top:2px}.cfr-depth-chart__tooltip-change-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:10px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px}.cfr-depth-chart__tooltip-change-value{font-size:11px;font-weight:700;font-family:SF Mono,Consolas,monospace}.cfr-depth-chart__tooltip-factors{display:flex;flex-direction:column;gap:2px}.cfr-depth-chart__tooltip-factor{font-size:10px;color:var(--color-text-muted);padding-left:2px;line-height:1.4}.cfr-depth-chart__hairline{pointer-events:none}.cfr-depth-chart__hairline line{pointer-events:none}.cfr-depth-chart__hairline circle{transition:r .1s ease;filter:drop-shadow(0 0 4px rgba(255,255,255,.3))}.cfr-depth-chart__hairline text{font-family:SF Mono,Consolas,monospace;pointer-events:none}.cfr-depth-chart__hairline rect{pointer-events:none}.conc-depth-chart{width:100%;height:100%;background:linear-gradient(180deg,#0d0d0d,#141414);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;flex:1;box-shadow:0 4px 20px #0006,inset 0 1px #ffffff08;overflow:hidden}.conc-depth-chart__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 100%);border-bottom:1px solid var(--color-border)}.conc-depth-chart__title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);letter-spacing:.3px;display:flex;align-items:center;gap:var(--spacing-sm)}.conc-depth-chart__title:before{content:"";width:3px;height:16px;background:linear-gradient(180deg,#10b981,#f59e0b);border-radius:2px}.conc-depth-chart__controls{display:flex;align-items:center;gap:var(--spacing-md)}.conc-depth-chart__toggle-group{display:flex;gap:2px;background:#0000004d;padding:2px;border-radius:6px;border:1px solid rgba(255,255,255,.05)}.conc-depth-chart__toggle{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:4px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;border:none;background:transparent;font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-muted)}.conc-depth-chart__toggle:hover{color:var(--color-text-secondary);background:#ffffff08}.conc-depth-chart__toggle--active{background:#ffffff14;color:var(--color-text-primary)}.conc-depth-chart__toggle--bed.conc-depth-chart__toggle--active{color:#34d399;background:#10b98126;box-shadow:0 0 8px #10b98133}.conc-depth-chart__toggle--conc.conc-depth-chart__toggle--active{color:#fbbf24;background:#f59e0b26;box-shadow:0 0 8px #f59e0b33}.conc-depth-chart__toggle-indicator{width:6px;height:6px;border-radius:50%;transition:all .2s ease}.conc-depth-chart__toggle--bed .conc-depth-chart__toggle-indicator{background:#10b981;box-shadow:0 0 6px #10b981}.conc-depth-chart__toggle--conc .conc-depth-chart__toggle-indicator{background:#f59e0b;box-shadow:0 0 6px #f59e0b}.conc-depth-chart__toggle:not(.conc-depth-chart__toggle--active) .conc-depth-chart__toggle-indicator{opacity:.3;box-shadow:none}.conc-depth-chart__chart-area{flex:1;min-height:0;padding:var(--spacing-xs)}.conc-depth-chart svg{width:100%;height:100%}.conc-depth-chart--empty{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-style:italic;font-size:var(--font-size-sm)}.conc-depth-chart__formation-label{font-size:8px;fill:#1a1a1a;font-weight:600;text-shadow:0 0 3px rgba(255,255,255,.9),0 1px 2px rgba(0,0,0,.3);pointer-events:none;letter-spacing:.2px}.conc-depth-chart__column-header{font-size:9px;fill:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.conc-depth-chart__column-header--bed{fill:#34d399;font-weight:700}.conc-depth-chart__column-header--conc{fill:#fbbf24;font-weight:700}.conc-depth-chart__mode-label{font-size:11px;font-weight:700;text-transform:uppercase;pointer-events:none;letter-spacing:.5px}.conc-depth-chart__bed-profile path{transition:opacity .2s ease}.conc-depth-chart__bar{cursor:pointer;transition:all .15s ease}.conc-depth-chart__bar:hover{filter:brightness(1.2)}.conc-depth-chart__tick-label{font-size:9px;fill:var(--color-text-muted);font-weight:500}.conc-depth-chart__axis-label{font-size:9px;fill:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.conc-depth-chart__axis-label--bed{fill:#34d399}.conc-depth-chart__axis-label--conc{fill:#fbbf24}.conc-depth-chart__hairline{pointer-events:none}.conc-depth-chart__hairline line{pointer-events:none}.conc-depth-chart__hairline circle{transition:r .1s ease;filter:drop-shadow(0 0 4px rgba(255,255,255,.3))}.conc-depth-chart__hairline text{font-family:SF Mono,Consolas,monospace;pointer-events:none}.conc-depth-chart__legend{display:flex;gap:var(--spacing-xs);justify-content:center;flex-wrap:wrap;padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--color-border);background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.2) 100%)}.conc-depth-chart__legend-section{display:flex;gap:var(--spacing-xs);align-items:center;padding:0 var(--spacing-sm);border-right:1px solid rgba(255,255,255,.06)}.conc-depth-chart__legend-section:last-child{border-right:none}.conc-depth-chart__legend-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--color-text-muted);padding:2px 6px;border-radius:4px;transition:all .15s ease}.conc-depth-chart__legend-item:hover{background:#ffffff0d;color:var(--color-text-secondary)}.conc-depth-chart__legend-color{width:10px;height:10px;border-radius:2px;flex-shrink:0}.conc-depth-chart__legend-color--low{background:#10b981;box-shadow:0 0 4px #10b98166}.conc-depth-chart__legend-color--medium{background:#f59e0b;box-shadow:0 0 4px #f59e0b66}.conc-depth-chart__legend-color--high{background:#ef4444;box-shadow:0 0 4px #ef444466}.conc-depth-chart__legend-color--settling{background:#3b82f6;box-shadow:0 0 4px #3b82f666}.conc-depth-chart__legend-color--lifting{background:#f59e0b;box-shadow:0 0 4px #f59e0b66}.conc-depth-chart__legend-color--rolling{background:#ef4444;box-shadow:0 0 4px #ef444466}.conc-depth-chart__tooltip{position:absolute;background:linear-gradient(135deg,#141414fa,#0a0a0afa);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);font-size:11px;pointer-events:none;z-index:100;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:180px}.conc-depth-chart__tooltip:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(16,185,129,.3),transparent)}.conc-depth-chart__tooltip-header{font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);padding-bottom:var(--spacing-xs);border-bottom:1px solid rgba(255,255,255,.06);font-size:10px;text-transform:uppercase;letter-spacing:.5px}.conc-depth-chart__tooltip-row{display:flex;justify-content:space-between;gap:var(--spacing-md);padding:2px 0}.conc-depth-chart__tooltip-label{color:var(--color-text-muted);font-weight:500}.conc-depth-chart__tooltip-value{color:var(--color-text-primary);font-weight:600;font-family:SF Mono,Consolas,monospace}.conc-depth-chart__tooltip-divider{height:1px;background:#ffffff0f;margin:var(--spacing-xs) 0}.conc-depth-chart__tooltip-risk{display:flex;align-items:center;gap:4px;margin-top:var(--spacing-xs);padding:4px 6px;border-radius:4px;font-weight:500}.conc-depth-chart__tooltip-risk--high{background:#ef444426;border:1px solid rgba(239,68,68,.4);color:#f87171}.conc-depth-chart__tooltip-risk--medium{background:#f59e0b26;border:1px solid rgba(245,158,11,.4);color:#fbbf24}.page{height:100%;display:flex;flex-direction:column}.page-header{margin-bottom:var(--spacing-lg)}.page-title{margin:0;font-size:var(--font-size-xl);font-weight:600;color:var(--color-text-primary)}.page-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg)}.placeholder-card{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg)}.placeholder-card h2{margin:0 0 var(--spacing-sm);font-size:var(--font-size-lg);font-weight:500;color:var(--color-text-primary)}.placeholder-card p{margin:0 0 var(--spacing-md);color:var(--color-text-muted);font-size:var(--font-size-md)}.placeholder-list{margin:0 0 var(--spacing-md);padding-left:var(--spacing-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.placeholder-list li{margin-bottom:var(--spacing-xs)}.placeholder-phase{margin:0;padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-accent);font-style:italic}.mud-config{display:grid;grid-template-columns:1fr 380px;gap:var(--spacing-lg)}.mud-config__main{display:flex;flex-direction:column;gap:var(--spacing-lg)}.mud-config__chart{display:flex;flex-direction:column}.config-section__description{margin:0 0 var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-muted);font-family:var(--font-mono)}.mud-type-row{flex-direction:row;align-items:flex-end;gap:var(--spacing-xl)}.rheology-params{flex-direction:row;flex-wrap:wrap;gap:var(--spacing-lg)}.rheology-params>*{flex:1;min-width:180px}.viscometer-table{width:100%;max-width:300px;border-collapse:collapse;margin-bottom:var(--spacing-md)}.viscometer-table th,.viscometer-table td{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);text-align:center}.viscometer-table th{background-color:var(--color-bg-tertiary);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.viscometer-table__rpm{font-family:var(--font-mono);color:var(--color-text-muted);background-color:var(--color-bg-secondary)}.viscometer-table__input{width:80px;padding:var(--spacing-xs);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-mono);text-align:center}.viscometer-table__input:focus{outline:none;border-color:var(--color-accent)}.viscometer-table__input:disabled{opacity:.6;cursor:not-allowed}.btn{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .15s ease;border:none}.btn--secondary{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background-color:var(--color-border);color:var(--color-text-primary)}.btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1200px){.mud-config{grid-template-columns:1fr}.mud-config__chart{order:-1}}.bit-config{display:flex;flex-direction:column;gap:var(--spacing-lg);max-width:700px}.bit-properties{flex-direction:row;gap:var(--spacing-xl)}.form-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-field__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.form-field__select{padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-md);min-width:180px}.form-field__select:focus{outline:none;border-color:var(--color-accent)}.form-field__select:disabled{opacity:.6;cursor:not-allowed}.nozzle-count{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.nozzle-count__controls{display:flex;align-items:center;gap:var(--spacing-xs)}.nozzle-count__btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-lg);cursor:pointer;transition:all .15s ease}.nozzle-count__btn:hover:not(:disabled){background-color:var(--color-border);color:var(--color-text-primary)}.nozzle-count__btn:disabled{opacity:.4;cursor:not-allowed}.nozzle-count__value{min-width:40px;text-align:center;font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);font-family:var(--font-mono)}.nozzle-table{width:100%;max-width:350px;border-collapse:collapse}.nozzle-table th,.nozzle-table td{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);text-align:center}.nozzle-table th{background-color:var(--color-bg-tertiary);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.nozzle-table__number{font-family:var(--font-mono);color:var(--color-text-muted);background-color:var(--color-bg-secondary);width:80px}.nozzle-table__input{width:80px;padding:var(--spacing-xs);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-mono);text-align:center}.nozzle-table__input:focus{outline:none;border-color:var(--color-accent)}.nozzle-table__input:disabled{opacity:.6;cursor:not-allowed}.config-section--highlight{background-color:var(--color-bg-tertiary);border-color:var(--color-accent)}.tfa-display{display:flex;gap:var(--spacing-xl);margin-bottom:var(--spacing-sm)}.tfa-value{display:flex;align-items:baseline;gap:var(--spacing-xs)}.tfa-value__number{font-size:var(--font-size-xxl);font-weight:600;font-family:var(--font-mono);color:var(--color-accent)}.tfa-value--secondary .tfa-value__number{font-size:var(--font-size-lg);color:var(--color-text-secondary)}.tfa-value__unit{font-size:var(--font-size-md);color:var(--color-text-muted)}.tfa-formula{margin:0;font-size:var(--font-size-sm);color:var(--color-text-muted);font-family:var(--font-mono)}.trajectory{display:grid;grid-template-columns:1fr 420px;gap:var(--spacing-lg)}.trajectory__table-section{overflow:hidden}.trajectory__chart-section{display:flex;flex-direction:column}.trajectory__chart-wrapper{display:flex;align-items:flex-start;justify-content:flex-end;min-height:380px;padding:var(--spacing-sm) 0 0 0}.survey-table-container{overflow-x:auto;margin-bottom:var(--spacing-md)}.survey-table{width:100%;border-collapse:collapse;min-width:500px}.survey-table th,.survey-table td{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);text-align:center}.survey-table th{background-color:var(--color-bg-tertiary);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.survey-table__index{font-family:var(--font-mono);color:var(--color-text-muted);background-color:var(--color-bg-secondary);width:40px}.survey-table__input{width:80px;padding:var(--spacing-xs);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-mono);text-align:center}.survey-table__input:focus{outline:none;border-color:var(--color-accent)}.survey-table__input:disabled{opacity:.6;cursor:not-allowed;background-color:transparent;border-color:transparent}.survey-table__calculated{font-family:var(--font-mono);color:var(--color-text-muted);background-color:var(--color-bg-secondary)}.survey-table__delete-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background-color:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-lg);cursor:pointer;transition:all .15s ease}.survey-table__delete-btn:hover:not(:disabled){background-color:var(--color-error);color:#fff;border-color:var(--color-error)}.survey-table__delete-btn:disabled{opacity:.3;cursor:not-allowed}.survey-note{margin:0;font-size:var(--font-size-sm);color:var(--color-text-muted);font-style:italic}@media (max-width: 1100px){.trajectory{grid-template-columns:1fr}.trajectory__chart-section{order:-1}}.temperature{display:grid;grid-template-columns:1fr 380px;gap:var(--spacing-lg)}.temperature__config{display:flex;flex-direction:column;gap:var(--spacing-lg)}.temperature__chart{display:flex;flex-direction:column}.gradient-params{display:flex;flex-direction:column;gap:var(--spacing-md)}.calculated-value{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-tertiary);border-radius:var(--radius-sm);margin-top:var(--spacing-sm)}.calculated-value__label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.calculated-value__value{font-size:var(--font-size-lg);font-weight:600;font-family:var(--font-mono);color:var(--color-accent)}.temp-table{width:100%;max-width:400px;border-collapse:collapse;margin-bottom:var(--spacing-md)}.temp-table th,.temp-table td{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);text-align:center}.temp-table th{background-color:var(--color-bg-tertiary);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.temp-table__index{font-family:var(--font-mono);color:var(--color-text-muted);background-color:var(--color-bg-secondary);width:40px}.temp-table__empty{color:var(--color-text-muted);font-style:italic;padding:var(--spacing-md)!important}.temp-table__input{width:80px;padding:var(--spacing-xs);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-mono);text-align:center}.temp-table__input:focus{outline:none;border-color:var(--color-accent)}.temp-table__input:disabled{opacity:.6;cursor:not-allowed;background-color:transparent;border-color:transparent}.temp-table__delete-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background-color:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-lg);cursor:pointer;transition:all .15s ease}.temp-table__delete-btn:hover{background-color:var(--color-error);color:#fff;border-color:var(--color-error)}@media (max-width: 1100px){.temperature{grid-template-columns:1fr}.temperature__chart{order:-1}}.calibration{display:flex;flex-direction:column;gap:var(--spacing-lg);max-width:700px}.calibration-hint{margin:var(--spacing-sm) 0 0;font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.5}.config-section--preview{background-color:var(--color-bg-tertiary)}.preview-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--color-border);min-width:150px}.preview-item--final{border-color:var(--color-accent);background-color:#3b82f61a}.preview-item__value--accent{color:var(--color-accent)}.preview-arrow{font-size:var(--font-size-xl);color:var(--color-text-muted)}@media (max-width: 700px){.preview-grid{flex-direction:column;align-items:stretch}.preview-arrow{transform:rotate(90deg);text-align:center}.preview-item{min-width:auto}}.cuttings{display:flex;flex-direction:column;gap:var(--spacing-lg);max-width:800px}.drilling-params,.cuttings-props{flex-direction:row;gap:var(--spacing-xl)}.calculated-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.calculated-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.calculated-item__label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.calculated-item__value{font-size:var(--font-size-lg);font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary)}.calculated-item__value--large{font-size:var(--font-size-xl)}.calculated-item--good{border-color:var(--color-success)}.calculated-item--good .calculated-item__value{color:var(--color-success)}.calculated-item--warning{border-color:var(--color-warning);background-color:#eab3081a}.calculated-item--warning .calculated-item__value{color:var(--color-warning)}.calculated-item--danger{border-color:var(--color-error);background-color:#ef44441a}.calculated-item--danger .calculated-item__value{color:var(--color-error)}.warning-limits{flex-direction:row;gap:var(--spacing-xl)}.warning-limit{display:flex;align-items:flex-end;gap:var(--spacing-sm)}.warning-limit__indicator{width:12px;height:12px;border-radius:50%;margin-bottom:8px}.warning-limit--optimum .warning-limit__indicator{background-color:var(--color-warning)}.warning-limit--danger .warning-limit__indicator{background-color:var(--color-error)}@media (max-width: 600px){.drilling-params,.cuttings-props,.warning-limits{flex-direction:column;gap:var(--spacing-md)}}.data-table-container{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.data-table-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.data-table-title{display:flex;align-items:center;gap:var(--spacing-sm)}.data-table-title h3{margin:0;font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary)}.data-table-status{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-success)}.status-dot.editing{background:var(--color-warning)}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.data-table thead{background:var(--color-bg-secondary)}.data-table th{padding:var(--spacing-sm) var(--spacing-sm);text-align:left;font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap}.data-table th.numeric{text-align:right}.data-table th.center{text-align:center}.data-table tbody tr{background:var(--color-bg-panel);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-bg-hover)}.data-table tbody tr.selected{background:#00d4ff1a;border-left:3px solid var(--color-accent)}.data-table tbody tr.has-error{background:#ff47570d}.data-table td{padding:var(--spacing-xs) var(--spacing-sm);color:var(--color-text-primary);vertical-align:middle}.data-table td.numeric{text-align:right;font-variant-numeric:tabular-nums}.data-table td.center{text-align:center}.data-table td.muted{color:var(--color-text-muted)}.row-number{color:var(--color-text-muted);font-size:var(--font-size-xs);min-width:30px}.data-table tbody tr.add-row{background:transparent}.data-table tbody tr.add-row:hover{background:var(--color-bg-hover)}.add-row-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:none;color:var(--color-accent);font-size:var(--font-size-sm);cursor:pointer;transition:color var(--transition-fast)}.add-row-btn:hover{color:var(--color-accent-hover)}.add-row-btn:disabled{color:var(--color-text-muted);cursor:not-allowed}.delete-row-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.delete-row-btn:hover{background:#ff47571a;color:var(--color-error)}.delete-row-btn:disabled{opacity:.3;cursor:not-allowed}.data-table-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border-top:1px solid var(--color-border)}.data-table-summary{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.data-table-summary strong{color:var(--color-text-primary)}.editable-cell{position:relative}.editable-cell input{width:100%;min-width:60px;padding:var(--spacing-xs);background:var(--color-bg-input);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:inherit;text-align:inherit;transition:border-color var(--transition-fast)}.editable-cell input:focus{outline:none;border-color:var(--color-accent)}.editable-cell input.error{border-color:var(--color-error);background:#ff47571a}.editable-cell input.numeric{text-align:right}.editable-cell .error-tooltip{position:absolute;top:100%;left:0;z-index:10;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-error);color:#fff;font-size:var(--font-size-xs);border-radius:var(--radius-sm);white-space:nowrap;margin-top:2px}.table-dropdown{width:100%;min-width:100px;padding:var(--spacing-xs);background:var(--color-bg-input);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-family:inherit;cursor:pointer;transition:border-color var(--transition-fast)}.table-dropdown:focus{outline:none;border-color:var(--color-accent)}.table-dropdown:disabled{background:var(--color-bg-panel);color:var(--color-text-muted);cursor:not-allowed}.readonly-value{padding:var(--spacing-xs) 0}.table-toolbar{display:flex;gap:var(--spacing-sm)}.table-toolbar button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);font-family:inherit;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-edit{background:transparent;border:1px solid var(--color-border-light);color:var(--color-text-secondary)}.btn-edit:hover{border-color:var(--color-accent);color:var(--color-accent)}.btn-save{background:var(--color-success);border:none;color:#000}.btn-save:hover{background:#3ae882}.btn-save:disabled{background:var(--color-text-muted);cursor:not-allowed}.btn-cancel{background:transparent;border:1px solid var(--color-border-light);color:var(--color-text-muted)}.btn-cancel:hover{border-color:var(--color-text-secondary);color:var(--color-text-secondary)}.well-config-page{display:flex;flex-direction:column;height:100%;padding:var(--spacing-md);overflow:hidden}.well-config-header{flex-shrink:0;margin-bottom:var(--spacing-md)}.well-config-header .page-title{margin:0;font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.well-config-content{flex:1;overflow-y:auto;overflow-x:hidden}.tables-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}@media (max-width: 1200px){.well-config-page{padding:var(--spacing-sm)}.tables-container{gap:var(--spacing-md)}}.results-summary{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-bottom:var(--spacing-md);align-items:stretch}.summary-card{flex:1;min-width:140px;max-width:200px;background:linear-gradient(135deg,#141419e6,#0f0f12f2);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;justify-content:center;gap:2px;position:relative;overflow:hidden;transition:all .2s ease;box-shadow:0 2px 8px #0000004d,inset 0 1px #ffffff08}.summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.summary-card:hover{border-color:#ffffff1f;transform:translateY(-1px);box-shadow:0 4px 12px #0006,inset 0 1px #ffffff0d}.summary-card__label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;line-height:1.2;font-weight:500}.summary-card__value{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);line-height:1.2;font-family:var(--font-mono);display:flex;align-items:baseline;gap:4px}.summary-card__unit{font-size:11px;color:var(--color-text-muted);font-weight:500;font-family:var(--font-sans)}.summary-card__subtext{font-size:10px;color:var(--color-text-tertiary);line-height:1.3;opacity:.8}.summary-card--status{align-items:center;text-align:center;min-width:80px;max-width:100px}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-weight:600;font-size:var(--font-size-sm)}.status-badge--ok{background:#22c55e26;color:#22c55e}.status-badge--warning{background:#fbbf2426;color:#fbbf24}.status-badge--critical{background:#ef444426;color:#ef4444}.status-badge__icon{font-size:var(--font-size-sm)}.summary-card--recommended{background:linear-gradient(135deg,#10b98126,#06b6d414);border-color:#10b98166;box-shadow:0 2px 12px #10b98126,inset 0 1px #10b9811a}.summary-card--recommended:before{background:linear-gradient(90deg,transparent,rgba(16,185,129,.5),transparent)}.summary-card--recommended .summary-card__label{color:#10b981cc}.summary-card--recommended .summary-card__value{color:#10b981;text-shadow:0 0 12px rgba(16,185,129,.4)}.summary-card--recommended:hover{border-color:#10b98199;box-shadow:0 4px 16px #10b98140,inset 0 1px #10b98126}.summary-card--sag-warning{background:linear-gradient(135deg,#fbbf241f,#f59e0b0f);border-color:#fbbf2466;box-shadow:0 2px 12px #fbbf241a,inset 0 1px #fbbf241a}.summary-card--sag-warning:before{background:linear-gradient(90deg,transparent,rgba(251,191,36,.5),transparent)}.summary-card--sag-warning .summary-card__label{color:#fbbf24cc}.summary-card--sag-warning .summary-card__value{color:#fbbf24;text-shadow:0 0 12px rgba(251,191,36,.4)}.summary-card--sag-warning:hover{border-color:#fbbf2499;box-shadow:0 4px 16px #fbbf2433,inset 0 1px #fbbf2426}@media (max-width: 768px){.summary-card{min-width:120px;max-width:none}}.segment-results-table{background:linear-gradient(180deg,#0d0d0d,#141414);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-shrink:0;box-shadow:0 4px 20px #0006,inset 0 1px #ffffff08;overflow:hidden}.segment-results-table__header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 100%);border-bottom:1px solid var(--color-border)}.segment-results-table__title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);letter-spacing:.3px;display:flex;align-items:center;gap:var(--spacing-sm)}.segment-results-table__title:before{content:"";width:3px;height:16px;background:linear-gradient(180deg,var(--color-accent) 0%,#0088aa 100%);border-radius:2px}.segment-results-table__container{max-height:300px;overflow-y:auto;overflow-x:auto}.segment-results-table__container::-webkit-scrollbar{width:6px;height:6px}.segment-results-table__container::-webkit-scrollbar-track{background:#0003}.segment-results-table__container::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.segment-results-table__container::-webkit-scrollbar-thumb:hover{background:#fff3}.segment-results-table__table{width:100%;border-collapse:collapse;font-size:11px}.segment-results-table__table th{position:sticky;top:0;background:linear-gradient(180deg,#1a1a1a,#141414);padding:var(--spacing-sm) var(--spacing-sm);text-align:left;font-weight:600;color:var(--color-text-muted);border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;text-transform:uppercase;font-size:9px;letter-spacing:.5px;transition:all .15s ease;z-index:10}.segment-results-table__table th:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(0,212,255,.2),transparent);opacity:0;transition:opacity .15s ease}.segment-results-table__table th:hover{background:linear-gradient(180deg,#222,#1a1a1a);color:var(--color-text-secondary)}.segment-results-table__table th:hover:after{opacity:1}.segment-results-table__th-content{display:flex;align-items:center;gap:4px}.segment-results-table__sort-icon{font-size:8px;color:var(--color-text-muted);opacity:.4;transition:all .15s ease}.segment-results-table__sort-icon--active{color:var(--color-accent);opacity:1;text-shadow:0 0 8px var(--color-accent)}.segment-results-table__table td{padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid rgba(255,255,255,.04);color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.segment-results-table__table tbody tr{cursor:pointer;transition:all .15s ease}.segment-results-table__table tbody tr:hover{background:#ffffff08}.segment-results-table__table tbody tr:hover td{color:var(--color-text-primary)}.segment-results-table__table tbody td:first-child{position:relative;padding-left:calc(var(--spacing-sm) + 4px)}.segment-results-table__table tbody td:first-child:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:transparent;transition:background .15s ease}.segment-results-table__table tr--selected{background:#00d4ff14!important}.segment-results-table__table tr--selected td:first-child:before{background:var(--color-accent);box-shadow:0 0 8px var(--color-accent)}.segment-results-table__table tr--selected td{color:var(--color-text-primary)}.segment-results-table__table tr--sag-risk{background:#fbbf2408}.segment-results-table__table tr--sag-risk td:first-child:before{background:#fbbf2480}.segment-results-table__table tr--sag-risk:hover{background:#fbbf2414}.segment-results-table__mode{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:4px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;min-width:36px;transition:all .15s ease}.segment-results-table__mode--settling{background:#3b82f61f;color:#60a5fa;border:1px solid rgba(59,130,246,.25);box-shadow:0 0 8px #3b82f626}.segment-results-table__mode--lifting{background:#f59e0b1f;color:#fbbf24;border:1px solid rgba(245,158,11,.25);box-shadow:0 0 8px #f59e0b26}.segment-results-table__mode--rolling{background:#ef44441f;color:#f87171;border:1px solid rgba(239,68,68,.25);box-shadow:0 0 8px #ef444426}.segment-results-table__sag-risk{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:#fbbf24;font-weight:600;font-size:12px;background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:4px;box-shadow:0 0 8px #fbbf2433}.segment-results-table__sag-risk--none{color:var(--color-text-muted);opacity:.3}.segment-results-table__velocity--adequate{color:#34d399;font-weight:600;text-shadow:0 0 8px rgba(16,185,129,.3)}.segment-results-table__velocity--inadequate{color:#f87171;font-weight:600;text-shadow:0 0 8px rgba(239,68,68,.3)}.segment-results-table__table td.numeric,.segment-results-table__table th.numeric{text-align:right;font-variant-numeric:tabular-nums}.segment-results-table__table td:first-child,.segment-results-table__table td:nth-child(2){color:var(--color-text-primary);font-weight:500}.segment-results-table__cfr{color:#60a5fa!important;font-weight:600}.segment-results-table__crit-vel{color:#34d399!important}.segment-results-table__empty{padding:var(--spacing-xl);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);font-style:italic}.segment-results-table__footer{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-md);background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.2) 100%);border-top:1px solid var(--color-border);font-size:10px;color:var(--color-text-muted)}.segment-results-table__row-count{display:flex;align-items:center;gap:4px}.segment-results-table__row-count-value{color:var(--color-accent);font-weight:600}.warnings-panel{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.warnings-panel--empty{display:none}.warnings-panel__header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#fbbf241a;border-bottom:1px solid rgba(251,191,36,.3)}.warnings-panel__icon{color:#fbbf24;font-size:var(--font-size-lg)}.warnings-panel__title{font-size:var(--font-size-md);font-weight:600;color:#fbbf24}.warnings-panel__count{margin-left:auto;background:#fbbf2433;color:#fbbf24;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500}.warnings-panel__list{list-style:none;margin:0;padding:0}.warnings-panel__item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);color:var(--color-text-primary);font-size:var(--font-size-sm)}.warnings-panel__item:last-child{border-bottom:none}.warnings-panel__item-icon{color:#fbbf24;flex-shrink:0;margin-top:2px}.warnings-panel__item-text{flex:1}.warnings-panel--critical .warnings-panel__header{background:#ef44441a;border-bottom-color:#ef44444d}.warnings-panel--critical .warnings-panel__icon,.warnings-panel--critical .warnings-panel__title,.warnings-panel--critical .warnings-panel__item-icon{color:#ef4444}.warnings-panel--critical .warnings-panel__count{background:#ef444433;color:#ef4444}.export-toolbar{display:flex;gap:var(--spacing-xs);align-items:center}.export-toolbar__btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.export-toolbar__btn:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:2px;height:0;background:var(--color-accent);border-radius:1px;transition:height .2s ease}.export-toolbar__btn:hover{background:#ffffff0a;color:var(--color-text-secondary)}.export-toolbar__btn:hover .export-toolbar__icon{color:var(--color-text-secondary);transform:scale(1.05)}.export-toolbar__btn:active{transform:scale(.98)}.export-toolbar__btn--success{background:linear-gradient(90deg,rgba(34,197,94,.15) 0%,transparent 100%);color:#22c55e}.export-toolbar__btn--success:before{height:60%;background:#22c55e;box-shadow:0 0 8px #22c55e}.export-toolbar__btn--success .export-toolbar__icon{color:#22c55e;filter:drop-shadow(0 0 4px rgba(34,197,94,.6))}.export-toolbar__btn--success .export-toolbar__label{text-shadow:0 0 10px rgba(34,197,94,.3)}.export-toolbar__icon{width:16px;height:16px;flex-shrink:0;color:var(--color-text-muted);transition:all .2s ease}.export-toolbar__icon svg{width:100%;height:100%}.export-toolbar__label{white-space:nowrap}.results-page{display:flex;flex-direction:column;height:100%;overflow:auto}.results-page__header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-md);border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-bg-primary);position:sticky;top:0;z-index:10}.results-page__title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.results-page__updating-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:4px 10px;background:#00c8ff26;border:1px solid rgba(0,200,255,.3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500;color:var(--color-accent)}.results-page__updating-spinner{width:12px;height:12px;border:2px solid rgba(0,200,255,.3);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.results-page__actions{display:flex;gap:var(--spacing-sm);align-items:center}.results-page__calculate-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-accent);border:none;border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-md);font-weight:500;cursor:pointer;transition:all .15s ease}.results-page__calculate-btn:hover:not(:disabled){background:var(--color-accent-hover)}.results-page__calculate-btn:disabled{opacity:.6;cursor:not-allowed}.results-page__content{flex:1;padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto}.results-page__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md)}.results-page__loading-spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.results-page__loading-text{font-size:var(--font-size-md);color:var(--color-text-secondary)}.results-page__error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);text-align:center;max-width:600px;margin:0 auto}.results-page__error-icon{font-size:48px;color:#ef4444}.results-page__error-title{font-size:var(--font-size-lg);font-weight:600;color:#ef4444}.results-page__error-message{color:var(--color-text-secondary);max-width:500px;font-family:monospace;background:var(--color-bg-tertiary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.results-page__error-help{text-align:left;width:100%;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-top:var(--spacing-sm)}.results-page__error-cause{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.results-page__error-cause+p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.results-page__error-suggestions-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.results-page__error-suggestions{list-style:none;margin:0;padding:0}.results-page__error-suggestions li{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:var(--spacing-xs) 0;padding-left:var(--spacing-md);position:relative}.results-page__error-suggestions li:before{content:"→";position:absolute;left:0;color:var(--color-accent)}.results-page__error-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.results-page__reset-btn{padding:var(--spacing-sm) var(--spacing-lg);background:#dc2626;border:none;border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .15s ease}.results-page__reset-btn:hover{background:#b91c1c}.results-page__error-btn{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:all .15s ease}.results-page__error-btn--primary{background:var(--color-accent);border:none;color:#fff}.results-page__error-btn--primary:hover{background:var(--color-accent-hover)}.results-page__error-btn--secondary{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.results-page__error-btn--secondary:hover{border-color:var(--color-border-hover);color:var(--color-text-primary)}.results-page__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);text-align:center;flex:1}.results-page__empty-icon{font-size:64px;color:var(--color-text-tertiary)}.results-page__empty-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.results-page__empty-message{color:var(--color-text-secondary);max-width:400px}.results-page__chart-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:column;height:550px;flex-shrink:0}.results-page__chart-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border);flex-shrink:0}.results-page__chart-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.results-page__chart-container{padding:var(--spacing-sm);flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.results-page__validation-errors{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:var(--spacing-md)}.results-page__validation-errors-title{font-size:var(--font-size-md);font-weight:600;color:#ef4444;margin-bottom:var(--spacing-sm)}.results-page__validation-errors-list{list-style:none;margin:0;padding:0}.results-page__validation-error-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;color:var(--color-text-primary);font-size:var(--font-size-sm)}.results-page__validation-error-link{color:var(--color-accent);text-decoration:none}.results-page__validation-error-link:hover{text-decoration:underline}.results-page__error-banner{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md)}.results-page__error-banner-icon{color:#ef4444;font-size:var(--font-size-md)}.results-page__error-banner-text{font-size:var(--font-size-sm);color:#ef4444}.results-page__timestamp{font-size:var(--font-size-sm);color:var(--color-text-tertiary);text-align:right}.settings{max-width:900px}.config-section{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg)}.config-section__title{margin:0 0 var(--spacing-xs);font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary)}.config-section__description{margin:0 0 var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-muted)}.config-section__content{display:flex;flex-direction:column;gap:var(--spacing-md)}.config-section--highlight{border-color:var(--color-accent);border-width:1px}.config-section--primary{background:linear-gradient(135deg,rgba(59,130,246,.05) 0%,var(--color-bg-primary) 100%);border-color:#3b82f64d}.export-import-buttons{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.export-btn,.import-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.export-btn:hover{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.import-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-accent)}.export-btn svg,.import-btn svg{flex-shrink:0}.import-message{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm)}.import-message--error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.import-message--success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#10b981}.import-message--warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:#f59e0b}.save-btn:disabled,.save-as-btn:disabled{opacity:.5;cursor:not-allowed}.saved-projects-loading{padding:var(--spacing-md);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.confirm-dialog{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:400px;width:90%;box-shadow:0 8px 32px #0006}.confirm-dialog__title{margin:0 0 var(--spacing-md);font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.confirm-dialog__message{margin:0 0 var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6}.confirm-dialog__buttons{display:flex;gap:var(--spacing-md);justify-content:flex-end}.confirm-dialog__btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.confirm-dialog__btn--cancel{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.confirm-dialog__btn--cancel:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.confirm-dialog__btn--confirm{background:var(--color-accent);border:1px solid var(--color-accent);color:#fff}.confirm-dialog__btn--confirm:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.confirm-dialog__btn--danger{background:#ef4444;border:1px solid #ef4444;color:#fff}.confirm-dialog__btn--danger:hover{background:#dc2626;border-color:#dc2626}.project-name-section{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.project-name-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.project-name-display{display:flex;align-items:center;gap:var(--spacing-sm)}.project-name-value{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.project-name-edit-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.project-name-edit-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-border);color:var(--color-text-primary)}.project-name-edit{display:flex;align-items:center;gap:var(--spacing-sm)}.project-name-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-md);max-width:300px}.project-name-input:focus{outline:none;border-color:var(--color-accent)}.project-name-btn{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.project-name-btn--save{background:var(--color-accent);border:1px solid var(--color-accent);color:#fff}.project-name-btn--save:hover{background:var(--color-accent-hover)}.project-name-btn--cancel{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.project-name-btn--cancel:hover{background:var(--color-bg-tertiary)}.save-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border:1px solid #10b981;border-radius:var(--radius-md);background:#10b9811a;color:#10b981;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.save-btn:hover{background:#10b981;color:#fff}.save-as-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.save-as-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-accent)}.save-as-input-container{margin-bottom:var(--spacing-lg)}.save-as-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-md)}.save-as-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f633}.confirm-dialog__btn:disabled{opacity:.5;cursor:not-allowed}.saved-projects-section{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.saved-projects-toggle{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) 0;background:transparent;border:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:color var(--transition-fast)}.saved-projects-toggle:hover{color:var(--color-text-primary)}.saved-projects-toggle svg{transition:transform var(--transition-fast)}.saved-projects-toggle svg.rotated{transform:rotate(180deg)}.saved-projects-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.saved-project-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.saved-project-info{display:flex;flex-direction:column;gap:2px;min-width:0}.saved-project-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-project-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.saved-project-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.saved-project-btn{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.saved-project-btn--load{background:var(--color-accent);border:1px solid var(--color-accent);color:#fff}.saved-project-btn--load:hover{background:var(--color-accent-hover)}.saved-project-btn--delete{width:28px;height:28px;background:transparent;border:1px solid transparent;color:var(--color-text-muted)}.saved-project-btn--delete:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.unit-presets{display:flex;gap:1rem;flex-wrap:wrap}.preset-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem 2rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);cursor:pointer;transition:all var(--transition-fast);min-width:160px}.preset-btn:hover{border-color:var(--color-accent);background:var(--color-bg-hover)}.preset-btn--us:hover{border-color:#3b82f6}.preset-btn--metric:hover{border-color:#10b981}.preset-btn__title{font-weight:600;font-size:var(--font-size-md);color:var(--color-text-primary)}.preset-btn__desc{font-size:var(--font-size-xs);color:var(--color-text-muted)}.unit-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-md) var(--spacing-xl)}.unit-setting{display:flex;align-items:center;gap:var(--spacing-md);min-width:0}.unit-setting__label{flex-shrink:0;width:120px;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.unit-setting__select{flex:1;min-width:0;width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:border-color var(--transition-fast)}.unit-setting__select:hover{border-color:var(--color-border-light)}.unit-setting__select:focus{outline:none;border-color:var(--color-accent)}.unit-summary{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-sm) var(--spacing-xl)}.unit-summary__item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0;border-bottom:1px dashed var(--color-border)}.unit-summary__category{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.unit-summary__unit{font-weight:600;font-size:var(--font-size-sm);color:var(--color-accent)}.calibration-row{display:flex;flex-direction:column;gap:var(--spacing-xs)}.calibration-hint{margin:0;font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.5;padding-left:var(--spacing-sm);border-left:2px solid var(--color-border)}.config-section--preview{background:linear-gradient(135deg,rgba(16,185,129,.05) 0%,var(--color-bg-primary) 100%);border-color:#10b9814d}.preview-grid{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.preview-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--color-border);min-width:120px;text-align:center}.preview-item--final{border-color:#10b981;background:linear-gradient(135deg,#10b98126,#10b9810d);box-shadow:0 0 12px #10b98126}.preview-item__label{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.preview-item__value{font-size:var(--font-size-lg);font-weight:600;font-family:var(--font-mono);color:var(--color-text-primary)}.preview-item__value--accent{color:#10b981;text-shadow:0 0 8px rgba(16,185,129,.4)}.preview-arrow{font-size:var(--font-size-xl);color:var(--color-text-muted);opacity:.5}@media (max-width: 768px){.unit-settings-grid{grid-template-columns:1fr}.unit-presets{flex-direction:column}.preset-btn{width:100%}.preview-grid{flex-direction:column;align-items:stretch}.preview-arrow{transform:rotate(90deg);text-align:center}.preview-item{min-width:auto}}.dashboard-page{display:flex;flex-direction:column;height:100%;overflow:auto}.dashboard-page__header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-md);border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-bg-primary);position:sticky;top:0;z-index:10}.dashboard-page__title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.dashboard-page__actions{display:flex;gap:var(--spacing-sm);align-items:center}.dashboard-page__content{flex:1;padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto}.dashboard-page__summary{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.summary-card{flex:1;min-width:150px;max-width:200px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.summary-card__label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs)}.summary-card__value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary);display:flex;align-items:baseline;gap:var(--spacing-xs)}.summary-card__unit{font-size:var(--font-size-sm);font-weight:400;color:var(--color-text-muted)}.summary-card__subtext{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.summary-card--success .summary-card__value{color:var(--color-success)}.summary-card--warning .summary-card__value{color:var(--color-warning)}.summary-card--danger .summary-card__value{color:var(--color-error)}.summary-card__progress{height:6px;background:var(--color-bg-hover);border-radius:3px;margin-top:var(--spacing-sm);overflow:hidden}.summary-card__progress-bar{height:100%;border-radius:3px;transition:width .3s ease}.summary-card__progress-bar--low{background:var(--color-success)}.summary-card__progress-bar--medium{background:var(--color-warning)}.summary-card__progress-bar--high{background:var(--color-error)}.dashboard-page__chart-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:column}.dashboard-page__chart-section--no-clip{overflow:visible}.dashboard-page__chart-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-panel);border-bottom:1px solid var(--color-border);flex-shrink:0}.dashboard-page__chart-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.dashboard-page__chart-container{padding:var(--spacing-sm);flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:300px}.dashboard-chart{position:relative;width:100%;height:100%}.dashboard-chart__tooltip{position:absolute;background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 8px;font-size:var(--font-size-xs);color:var(--color-text-primary);box-shadow:0 6px 16px #00000040;pointer-events:none;min-width:120px}.dashboard-chart__tooltip-title{font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.transport-pie{width:100%;padding:var(--spacing-sm);display:flex;gap:var(--spacing-md);align-items:center;justify-content:center;flex-wrap:wrap}.transport-pie__chart{position:relative;width:220px;height:220px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 100%);border:1px solid rgba(255,255,255,.06);border-radius:16px;box-shadow:0 0 14px #00000059,inset 0 1px #ffffff0a}.transport-pie__base{fill:#ffffff0a}.transport-pie__slice{cursor:pointer;transition:transform .2s ease,filter .2s ease,opacity .2s ease;transform-origin:center;opacity:.9}.transport-pie__slice:hover,.transport-pie__slice--active{opacity:1;filter:drop-shadow(0 0 8px rgba(0,212,255,.4));transform:scale(1.02)}.transport-pie__legend{display:flex;flex-direction:column;gap:6px;min-width:160px}.transport-pie__item{display:grid;grid-template-columns:12px 1fr auto;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);border:1px solid transparent;background:#ffffff05;color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.4px;cursor:pointer;transition:all .15s ease}.transport-pie__item:hover,.transport-pie__item--active{background:#00d4ff14;border-color:#00d4ff33;color:var(--color-text-primary)}.transport-pie__dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 8px #0000004d}.transport-pie__label{text-align:left}.transport-pie__value{font-family:var(--font-mono);font-size:11px;color:var(--color-text-muted)}@media (max-width: 480px){.transport-pie__legend{width:100%}.transport-pie__item{grid-template-columns:12px 1fr auto}}.dashboard-page__chart-section--no-clip .dashboard-page__chart-container{overflow:visible}.dashboard-page__chart-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}@media (max-width: 900px){.dashboard-page__chart-row{grid-template-columns:1fr}}.dashboard-page__table-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.dashboard-page__table-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-panel);border-bottom:1px solid var(--color-border)}.dashboard-page__table-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.dashboard-page__table-container{overflow-x:auto}.dashboard-page__table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.dashboard-page__table th{text-align:left;padding:var(--spacing-sm);background:var(--color-bg-panel);color:var(--color-text-secondary);font-weight:500;border-bottom:1px solid var(--color-border);white-space:nowrap}.dashboard-page__table td{padding:var(--spacing-sm);color:var(--color-text-primary);border-bottom:1px solid var(--color-border)}.dashboard-page__table tr:last-child td{border-bottom:none}.dashboard-page__table tr:hover td{background:var(--color-bg-hover)}.severity-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}.severity-badge--high{background:#ef444426;color:#ef4444}.severity-badge--medium{background:#ffa50226;color:var(--color-warning)}.severity-badge--low{background:#2ed57326;color:var(--color-success)}.severity-dot{width:6px;height:6px;border-radius:50%}.severity-dot--high{background:#ef4444}.severity-dot--medium{background:var(--color-warning)}.severity-dot--low{background:var(--color-success)}.dashboard-page__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);flex:1}.dashboard-page__loading-spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:dashboard-spin 1s linear infinite}@keyframes dashboard-spin{to{transform:rotate(360deg)}}.dashboard-page__loading-text{font-size:var(--font-size-md);color:var(--color-text-secondary)}.dashboard-page__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);text-align:center;flex:1}.dashboard-page__empty-icon{font-size:48px;color:var(--color-text-muted)}.dashboard-page__empty-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.dashboard-page__empty-message{color:var(--color-text-secondary);max-width:400px}.export-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.export-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.risk-heatmap__container{padding:var(--spacing-sm);min-height:0;display:flex;flex-direction:column;overflow:hidden}.risk-grid{display:flex;flex-direction:column;height:100%;min-height:0;gap:0}.risk-grid__scroll-wrapper{display:flex;flex-direction:column;position:relative;flex:1;min-height:0;flex-shrink:0;padding-bottom:20px;margin-bottom:16px;border-bottom:3px solid rgba(255,255,255,.25);background:transparent}.risk-grid__row{display:grid;grid-template-columns:110px repeat(4,1fr);gap:4px;align-items:stretch;flex-shrink:0}.risk-grid__row--header{background:#1a1a1a;border:1px solid var(--color-border);border-radius:6px;padding:4px;margin-bottom:4px;flex-shrink:0}.risk-grid__cell--header{padding:10px 4px;text-align:center;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-secondary);background:#ffffff0a;border-radius:4px}.risk-grid__cell--header.risk-grid__cell--depth{text-align:left;padding-left:8px}.risk-grid__cell--header.risk-grid__cell--overall{color:var(--color-accent);background:#00d4ff1a}.risk-grid__body{display:flex;flex-direction:column;gap:3px;padding-right:4px}.risk-grid__body::-webkit-scrollbar{width:5px}.risk-grid__body::-webkit-scrollbar-track{background:#0000004d;border-radius:3px}.risk-grid__body::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.risk-grid__cell{padding:10px 4px;border-radius:4px}.risk-grid__cell--depth{background:transparent;color:var(--color-text-secondary);font-size:11px;font-weight:500;text-align:left;padding-left:8px;display:flex;align-items:center}.risk-grid__cell--value{text-align:center;font-size:12px;font-weight:600;color:#fffffff2;text-shadow:0 1px 2px rgba(0,0,0,.5);cursor:help;transition:transform .1s ease}.risk-grid__cell--value:hover{transform:scale(1.06);z-index:1}.risk-grid__cell--overall{border:1px solid rgba(0,212,255,.3)}.risk-grid__legend-wrapper{margin-top:32px;border-top:none;width:100%;flex-shrink:0;display:block;clear:both;position:relative;background:#0003;border-radius:var(--radius-sm);padding:16px}.risk-grid__legend{display:flex;flex-direction:column;align-items:center;gap:4px;padding:0;margin:0;width:100%}.risk-grid__legend-scale{display:flex;width:100%;max-width:320px;height:8px;border-radius:4px;overflow:hidden}.risk-grid__legend-stop{flex:1}.risk-grid__legend-stop--low{background:linear-gradient(90deg,#288c504d,#288c50b3)}.risk-grid__legend-stop--med{background:linear-gradient(90deg,#b4821480,#b48214cc)}.risk-grid__legend-stop--high{background:linear-gradient(90deg,#dc3c3c99,#dc3c3ce6)}.risk-grid__legend-text{display:flex;width:100%;max-width:320px;justify-content:space-between;font-size:9px;color:var(--color-text-muted);text-transform:uppercase}.risk-grid__alerts{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.risk-grid__alerts-title{font-size:11px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px;display:flex;align-items:center;gap:6px}.risk-grid__alerts-title:before{content:"⚡"}.risk-grid__alert{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;margin-bottom:6px;font-size:11px}.risk-grid__alert--ok{background:#288c5026;border:1px solid rgba(40,140,80,.3);color:#4ade80}.risk-grid__alert--high{background:#dc3c3c1f;border:1px solid rgba(220,60,60,.3)}.risk-grid__alert--medium{background:#b482141f;border:1px solid rgba(180,130,20,.3)}.risk-grid__alert-badge{padding:2px 6px;border-radius:3px;font-size:9px;font-weight:700}.risk-grid__alert--high .risk-grid__alert-badge{background:#dc3c3c;color:#fff}.risk-grid__alert--medium .risk-grid__alert-badge{background:#b48214;color:#fff}.risk-grid__alert-type{font-weight:600;color:var(--color-text-primary)}.risk-grid__alert-depth{color:var(--color-text-muted)}.risk-grid__alert-score{margin-left:auto;color:var(--color-text-muted);font-size:10px}@media (max-width: 500px){.risk-grid__row{grid-template-columns:80px repeat(4,1fr)}.risk-grid__cell--header,.risk-grid__cell{padding:8px 2px;font-size:9px}}.tornado-bar{height:24px;display:flex;align-items:center}.tornado-bar__negative{background:#00d4ff4d;border-radius:2px 0 0 2px}.tornado-bar__positive{background:#00d4ff99;border-radius:0 2px 2px 0}.risk-heatmap-section{overflow:visible!important;height:auto!important;min-height:auto!important;flex-shrink:0}.risk-no-issues{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#288c5026;border:1px solid rgba(40,140,80,.3);border-radius:var(--radius-md);color:#4ade80}.risk-no-issues__icon{font-size:var(--font-size-lg);font-weight:700}.risk-no-issues__text{font-size:var(--font-size-sm)}.risk-heatmap-section .risk-heatmap__container{padding:var(--spacing-sm);overflow:visible;min-height:auto}.risk-heatmap-section .risk-grid{height:auto;min-height:auto}.risk-heatmap-section .risk-grid__scroll-wrapper{max-height:none;overflow:visible;border-bottom:none;padding-bottom:var(--spacing-sm);margin-bottom:0}.risk-heatmap-section .risk-grid__body{max-height:none;overflow:visible}.risk-heatmap-section .risk-grid__legend-wrapper{margin-top:var(--spacing-md);padding-top:var(--spacing-sm)}.dashboard-page .dashboard-page__table-section{flex-shrink:0;margin-bottom:var(--spacing-md)}.dashboard-page .dashboard-page__table-container{max-height:none;overflow:visible}.dashboard-page .dashboard-page__table{width:100%}.risk-grid__custom-tooltip{position:fixed;z-index:10000;pointer-events:none;max-width:320px;min-width:280px}.risk-grid__tooltip-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:0 4px 16px #00000080,0 0 0 1px #ffffff0d inset;color:var(--color-text-primary);font-size:var(--font-size-sm);line-height:1.5;font-family:var(--font-family)}.risk-grid__tooltip-title{font-weight:700;font-size:var(--font-size-md);color:var(--color-accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs);text-align:left}.risk-grid__tooltip-header{font-weight:500;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);text-align:left;letter-spacing:.2px}.risk-grid__tooltip-separator{height:1px;background:var(--color-border);margin:var(--spacing-sm) 0;opacity:.6}.risk-grid__tooltip-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs);gap:var(--spacing-md);min-height:20px}.risk-grid__tooltip-row:last-of-type{margin-bottom:0}.risk-grid__tooltip-key{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-align:left;flex-shrink:0;font-weight:400}.risk-grid__tooltip-value{font-size:var(--font-size-sm);font-weight:600;text-align:right;flex-shrink:0;white-space:nowrap}.risk-grid__tooltip-section-header{font-weight:600;font-size:var(--font-size-xs);color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.5px;margin-top:var(--spacing-xs);margin-bottom:var(--spacing-xs);text-align:left}.risk-grid__tooltip-factor{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs);padding-left:0;line-height:1.5;text-align:left;font-weight:400}.risk-grid__tooltip-factor:last-child{margin-bottom:0}.conc-chart__legend{display:flex;gap:var(--spacing-md);align-items:center}.conc-chart__legend-item{display:flex;align-items:center;gap:6px;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.conc-chart__legend-line{width:20px;height:3px;border-radius:1px}.conc-chart__legend-line--local{background:var(--color-accent)}.conc-chart__legend-line--cumulative{background:var(--color-success);background:repeating-linear-gradient(90deg,var(--color-success) 0px,var(--color-success) 6px,transparent 6px,transparent 10px)}.conc-chart__legend-line--optimum{background:var(--color-warning);background:repeating-linear-gradient(90deg,var(--color-warning) 0px,var(--color-warning) 6px,transparent 6px,transparent 10px)}.conc-chart__legend-line--danger{background:var(--color-error);background:repeating-linear-gradient(90deg,var(--color-error) 0px,var(--color-error) 6px,transparent 6px,transparent 10px)}.conc-value--danger{color:var(--color-error);font-weight:600}.conc-value--warning{color:var(--color-warning);font-weight:600}.conc-recommendations{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.conc-recommendations__item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#00d4ff0d;border:1px solid rgba(0,212,255,.15);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text-primary)}.conc-recommendations__bullet{color:var(--color-accent);font-weight:600;flex-shrink:0}.conc-recommendations__text{flex:1}@media (max-width: 768px){.conc-chart__legend{flex-wrap:wrap;gap:var(--spacing-sm)}.conc-chart__legend-item{font-size:10px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 100%);padding:var(--spacing-lg)}.auth-container{width:100%;max-width:400px;display:flex;flex-direction:column;gap:var(--spacing-lg)}.auth-header{text-align:center;margin-bottom:var(--spacing-md)}.auth-logo{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--color-accent);color:var(--color-text-primary);font-size:1.5rem;font-weight:700;border-radius:var(--border-radius-lg);margin-bottom:var(--spacing-sm)}.auth-title{font-size:1.5rem;font-weight:600;color:var(--color-text-primary);margin:0}.auth-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--spacing-xl)}.auth-card__title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0;text-align:center}.auth-card__subtitle{font-size:.875rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-lg) 0;text-align:center}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);font-size:.875rem;text-align:center}.auth-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.auth-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.auth-input{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);color:var(--color-text-primary);font-size:1rem;transition:border-color .15s ease,box-shadow .15s ease}.auth-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f633}.auth-input::placeholder{color:var(--color-text-muted)}.auth-input:disabled{opacity:.6;cursor:not-allowed}.auth-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-accent);color:#fff;border:none;border-radius:var(--border-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .15s ease,transform .1s ease;margin-top:var(--spacing-sm)}.auth-button:hover:not(:disabled){background:var(--color-accent-hover)}.auth-button:active:not(:disabled){transform:scale(.98)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.auth-footer p{margin:0;font-size:.875rem;color:var(--color-text-secondary)}.auth-link{color:var(--color-accent);text-decoration:none;font-weight:500;transition:color .15s ease}.auth-link:hover{color:var(--color-accent-hover);text-decoration:underline}.auth-skip{text-align:center}.auth-skip-link{font-size:.875rem;color:var(--color-text-muted);text-decoration:none;transition:color .15s ease}.auth-skip-link:hover{color:var(--color-text-secondary);text-decoration:underline}:root{--color-bg-primary: #0a0a0a;--color-bg-secondary: #141414;--color-bg-panel: #1a1a1a;--color-bg-input: #1e1e1e;--color-bg-hover: #252525;--color-text-primary: #f5f5f5;--color-text-secondary: #d4d4d4;--color-text-muted: #737373;--color-border: #2a2a2a;--color-border-light: #3d3d3d;--color-accent: #00d4ff;--color-accent-hover: #33dfff;--color-hover: #00ff88;--color-selected: #00d4ff;--color-error: #ff4757;--color-warning: #ffa502;--color-success: #2ed573;--color-drillpipe: #ff6b35;--color-drillpipe-tj: #ff8c42;--color-hwdp: #e84855;--color-hwdp-tj: #f25c54;--color-dc: #4ecdc4;--color-dc-tj: #6ee7de;--color-bit: #95e1d3;--sidebar-width: 150px;--topnav-height: 48px;--statusbar-height: 32px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .25s ease;--font-family: "Segoe UI", system-ui, -apple-system, sans-serif;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-primary);overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit;font-size:inherit}ul,ol{list-style:none}img{max-width:100%;display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}::selection{background-color:var(--color-accent);color:var(--color-bg-primary)}
