@import"https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=IBM+Plex+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600;700&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:IBM Plex Sans,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.right-1{right:.25rem}.top-0{top:0}.top-1{top:.25rem}.z-40{z-index:40}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.table-row{display:table-row}.grid{display:grid}.hidden{display:none}.h-10{height:2.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-5{height:1.25rem}.h-64{height:16rem}.h-8{height:2rem}.h-screen{height:100vh}.w-2{width:.5rem}.w-5{width:1.25rem}.w-8{width:2rem}.w-auto{width:auto}.w-full{width:100%}.max-w-7xl{max-width:80rem}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1;border-color:rgb(229 231 235 / var(--tw-divide-opacity, 1))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:6px}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:8px}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-l-4{border-left-width:4px}.border-t{border-top-width:1px}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-l-orion-green{--tw-border-opacity: 1;border-left-color:rgb(5 150 105 / var(--tw-border-opacity, 1))}.border-l-orion-primary{--tw-border-opacity: 1;border-left-color:rgb(10 22 40 / var(--tw-border-opacity, 1))}.border-l-orion-secondary{--tw-border-opacity: 1;border-left-color:rgb(5 150 105 / var(--tw-border-opacity, 1))}.border-l-orion-warning{--tw-border-opacity: 1;border-left-color:rgb(255 149 0 / var(--tw-border-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-orion-danger{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))}.bg-orion-secondary{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-orion-primary\/10{--tw-gradient-from: rgb(10 22 40 / .1) var(--tw-gradient-from-position);--tw-gradient-to: rgb(10 22 40 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-orion-secondary\/10{--tw-gradient-from: rgb(5 150 105 / .1) var(--tw-gradient-from-position);--tw-gradient-to: rgb(5 150 105 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-orion-secondary\/10{--tw-gradient-to: rgb(5 150 105 / .1) var(--tw-gradient-to-position)}.to-orion-warning\/10{--tw-gradient-to: rgb(255 149 0 / .1) var(--tw-gradient-to-position)}.object-contain{-o-object-fit:contain;object-fit:contain}.p-2{padding:.5rem}.p-6{padding:1.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pt-8{padding-top:2rem}.text-2xl{font-size:1.5rem;line-height:1.4;letter-spacing:-.02em}.text-3xl{font-size:1.875rem;line-height:1.3;letter-spacing:-.02em}.text-lg{font-size:1.125rem;line-height:1.6}.text-sm{font-size:.875rem;line-height:1.6;letter-spacing:.01em}.text-xl{font-size:1.25rem;line-height:1.5;letter-spacing:-.01em}.text-xs{font-size:.75rem;line-height:1.5;letter-spacing:.02em}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.placeholder-gray-500::-moz-placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity, 1))}.placeholder-gray-500::placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity, 1))}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px rgba(0, 0, 0, .3);--tw-shadow-colored: 0 1px 2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--font-display: "Archivo", system-ui, sans-serif;--font-body: "IBM Plex Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--oilserv-gold: #D4AF37;--oilserv-gold-light: #E5C158;--oilserv-gold-dark: #B8941F;--oilserv-black: #1A1A1A;--oilserv-offwhite: #FAFAF8;--oilserv-offwhite-glass: rgba(250, 250, 248, .85);--pipeline-green: #059669;--pipeline-green-glow: rgba(5, 150, 105, .25);--crude-oil: #D97706;--crude-oil-glow: rgba(217, 119, 6, .25);--emergency-red: #DC2626;--emergency-red-glow: rgba(220, 38, 38, .25);--tech-cyan: #0EA5E9;--steel-900: #1A1A1A;--steel-800: #2D2D2D;--steel-700: #404040;--steel-600: #5A5A5A;--steel-500: #737373;--steel-400: #A3A3A3;--steel-300: #D4D4D4;--steel-200: #E5E5E5;--steel-100: #F5F5F5;--bg-primary: #FEFEFE;--bg-secondary: #FAFAFA;--bg-card: var(--oilserv-offwhite-glass);--bg-elevated: rgba(255, 255, 255, .95);--text-primary: #1A1A1A;--text-secondary: #5A5A5A;--text-tertiary: #A3A3A3;--text-inverse: #FFFFFF;--border-color: rgba(26, 26, 26, .12);--border-highlight: rgba(212, 175, 55, .4);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 .5px 1.5px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1), 0 2px 6px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-lg: 0 20px 40px rgba(0, 0, 0, .12), 0 8px 16px rgba(0, 0, 0, .08), 0 4px 8px rgba(0, 0, 0, .04);--shadow-glow-gold: 0 0 30px rgba(212, 175, 55, .3), 0 0 15px rgba(212, 175, 55, .2);--shadow-inner-glow: inset 0 1px 2px rgba(255, 255, 255, .5), inset 0 -1px 1px rgba(0, 0, 0, .03);--grid-size: 24px;--grid-color: rgba(212, 175, 55, .05);--ease-mechanical: cubic-bezier(.4, 0, .2, 1);--ease-entrance: cubic-bezier(0, 0, .2, 1);--ease-exit: cubic-bezier(.4, 0, 1, 1);--duration-instant: .1s;--duration-fast: .2s;--duration-normal: .3s;--duration-slow: .5s;--z-base: 0;--z-elevated: 10;--z-dropdown: 100;--z-sticky: 200;--z-modal: 1000;--z-toast: 2000;font-family:var(--font-body);line-height:1.6;font-weight:400;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;background-image:radial-gradient(ellipse at top left,rgba(212,175,55,.03) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(212,175,55,.02) 0%,transparent 50%),linear-gradient(var(--grid-color) 1px,transparent 1px),linear-gradient(90deg,var(--grid-color) 1px,transparent 1px);background-size:100% 100%,100% 100%,var(--grid-size) var(--grid-size),var(--grid-size) var(--grid-size);background-position:0 0,0 0,0 0,0 0;pointer-events:none;z-index:0;opacity:.6}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;width:100%}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-primary);position:relative;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.015'/%3E%3C/svg%3E")}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;margin:0;letter-spacing:-.02em;color:var(--text-primary)}h1{font-size:clamp(2rem,4vw,3.5rem);font-weight:800;letter-spacing:-.03em}h2{font-size:clamp(1.5rem,3vw,2.25rem);font-weight:700}h3{font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:600}h4{font-size:1.25rem;font-weight:600}p{margin:.75em 0;color:var(--text-secondary)}a{color:var(--oilserv-gold-dark);text-decoration:none;font-weight:500;transition:color var(--duration-fast) var(--ease-mechanical);position:relative}a:hover{color:var(--oilserv-gold)}a:focus-visible{outline:2px solid var(--oilserv-gold);outline-offset:4px;border-radius:2px}button{border-radius:6px;border:1px solid transparent;padding:.75em 1.5em;font-size:.875rem;font-weight:600;font-family:var(--font-body);letter-spacing:.02em;text-transform:uppercase;background-color:var(--oilserv-gold);color:var(--oilserv-black);cursor:pointer;transition:all var(--duration-fast) var(--ease-mechanical);position:relative;overflow:hidden}button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left var(--duration-normal) var(--ease-mechanical)}button:hover{background-color:var(--oilserv-gold-light);box-shadow:var(--shadow-glow-gold);transform:translateY(-1px)}button:hover:before{left:100%}button:active{transform:translateY(0)}button:focus-visible{outline:2px solid var(--oilserv-gold);outline-offset:4px}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button:disabled:hover{background-color:var(--oilserv-gold);box-shadow:none}input,select,textarea{font-family:var(--font-body);font-size:.875rem;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-card);color:var(--text-primary);transition:all var(--duration-fast) var(--ease-mechanical)}input:hover,select:hover,textarea:hover{border-color:var(--border-highlight)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--oilserv-gold);box-shadow:0 0 0 3px #d4af3726}code,pre{font-family:var(--font-mono);font-size:.875em;background:var(--steel-100);padding:.2em .4em;border-radius:4px;color:var(--oilserv-black)}pre{padding:1rem;overflow-x:auto;border:1px solid var(--border-color)}table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:.875rem}th{text-align:left;padding:.75rem 1rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:2px solid var(--border-highlight);background:var(--bg-elevated)}td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);color:var(--text-primary)}tr:hover{background:#0ea5e90d}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--steel-600);border-radius:6px;border:2px solid var(--bg-secondary)}::-webkit-scrollbar-thumb:hover{background:var(--steel-500)}::selection{background:var(--oilserv-gold);color:var(--oilserv-black)}::-moz-selection{background:var(--oilserv-gold);color:var(--oilserv-black)}.text-mono{font-family:var(--font-mono)}.text-display{font-family:var(--font-display)}.gradient-mesh{background:radial-gradient(at 0% 0%,rgba(212,175,55,.08) 0%,transparent 50%),radial-gradient(at 100% 100%,rgba(212,175,55,.06) 0%,transparent 50%)}.glass-morphism{background:var(--oilserv-offwhite-glass);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1px solid rgba(212,175,55,.15);box-shadow:0 8px 32px #0000000f,0 4px 16px #0000000a,0 2px 8px #00000005,inset 0 1px #fffc,inset 0 -1px #d4af370d}@keyframes slideInRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #d4af374d}50%{box-shadow:0 0 30px #d4af3780}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.animate-fade-in-up{animation:fadeInUp var(--duration-normal) var(--ease-entrance) both}.animate-slide-in-right{animation:slideInRight var(--duration-normal) var(--ease-entrance) both}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.delay-500{animation-delay:.5s}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.skip-link{position:absolute;top:-40px;left:0;background:var(--oilserv-gold);color:var(--oilserv-black);padding:8px 16px;text-decoration:none;font-weight:600;z-index:var(--z-toast)}.skip-link:focus{top:0}*:focus-visible{outline:2px solid var(--oilserv-gold);outline-offset:4px}@media print{body{background:#fff;color:#000}body:before{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.hover\:text-gray-600:hover{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.hover\:text-gray-900:hover{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.focus\:border-transparent:focus{border-color:transparent}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-orion-primary:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(10 22 40 / var(--tw-ring-opacity, 1))}@media(min-width:640px){.sm\:inline{display:inline}.sm\:flex-row{flex-direction:row}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media(min-width:768px){.md\:block{display:block}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1024px){.lg\:hidden{display:none}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:px-8{padding-left:2rem;padding-right:2rem}}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:all .15s cubic-bezier(.4,0,.2,1)}.status-dot--top-right{position:absolute;top:1rem;right:1rem;box-shadow:0 0 0 2px var(--bg-card)}.status-dot--inline{position:relative;margin-right:.5rem;vertical-align:middle}.status-dot--good{background:var(--pipeline-green, #059669)}.status-dot--warning{background:var(--crude-oil, #D97706)}.status-dot--critical{background:var(--emergency-red, #DC2626)}.status-dot--info{background:var(--tech-cyan, #0EA5E9)}.status-dot--animated.status-dot--critical{animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.kpi-card:hover .status-dot{box-shadow:0 0 0 3px var(--bg-card)}.status-dot--critical{box-shadow:0 0 0 2px var(--bg-card),0 0 8px #dc26264d}@media(prefers-reduced-motion:reduce){.status-dot--animated{animation:none!important}.status-dot{transition:none!important}}.kpi-card{position:relative;padding:1.2rem;border-radius:10px;overflow:hidden;transition:all .15s cubic-bezier(.4,0,.2,1);cursor:default;-moz-user-select:none;user-select:none;-webkit-user-select:none;isolation:isolate}.kpi-card__backdrop{position:absolute;inset:0;background:linear-gradient(135deg,var(--oilserv-gold) 0%,var(--oilserv-gold-light) 25%,#F0DB7D 50%,var(--oilserv-gold-light) 75%,var(--oilserv-gold) 100%);border:2px solid var(--oilserv-gold-dark);border-left:6px solid var(--oilserv-gold-dark);border-radius:12px;z-index:0;transition:all var(--duration-normal) var(--ease-mechanical);box-shadow:var(--shadow-md),inset 0 1px #ffffff59,inset 0 -1px #00000040,inset 2px 2px 4px #ffffff26}.kpi-card__border-glow{position:absolute;inset:-3px;background:linear-gradient(135deg,transparent 0%,rgba(229,193,88,.6) 50%,transparent 100%);border-radius:14px;z-index:-1;opacity:0;transition:opacity var(--duration-normal) var(--ease-mechanical)}.kpi-card__content{position:relative;z-index:1;display:flex;flex-direction:column;gap:1rem}.kpi-card__header{display:flex;align-items:center;gap:.75rem;position:relative}.kpi-card__icon{flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;background:var(--oilserv-black);border-radius:6px;color:var(--oilserv-gold-light);font-size:1rem;box-shadow:var(--shadow-sm),inset 0 -1px #ffffff1a}.kpi-card__title{font-family:var(--font-display);font-size:.8125rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--oilserv-black);margin:0;line-height:1.4;opacity:.65;text-shadow:0 .5px 1px rgba(0,0,0,.08);flex:1}.kpi-card__drill-indicator{margin-left:auto;font-size:1.25rem;color:var(--oilserv-black);opacity:0;transition:all var(--duration-fast) var(--ease-mechanical);font-weight:700}.kpi-card--clickable:hover .kpi-card__drill-indicator{opacity:.6;transform:translate(2px)}.kpi-card__value-section{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}.kpi-card__value-container{display:flex;align-items:baseline;gap:.5rem}.kpi-card__currency-icon{color:var(--oilserv-gold);opacity:.7;flex-shrink:0;transition:opacity .15s cubic-bezier(.4,0,.2,1)}.kpi-card__value{font-family:var(--font-display);font-size:2.125rem;font-weight:900;line-height:1;letter-spacing:-.03em;color:var(--oilserv-black);text-shadow:0 1px 2px rgba(0,0,0,.15),0 .5px 1px rgba(0,0,0,.1),0 2px 4px rgba(0,0,0,.05);background:linear-gradient(180deg,var(--oilserv-black) 0%,rgba(26,26,26,.9) 100%);-webkit-background-clip:text;background-clip:text}.kpi-card__unit{font-family:var(--font-mono);font-size:1rem;font-weight:600;color:var(--oilserv-black);opacity:.7;text-transform:uppercase;letter-spacing:.03em}.kpi-card__trend{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;border-radius:6px;font-family:var(--font-mono);font-size:.8125rem;font-weight:600;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all .15s cubic-bezier(.4,0,.2,1)}.kpi-card__trend--up{background:#05966926;color:var(--pipeline-green);border:1px solid rgba(5,150,105,.3)}.kpi-card__trend--down{background:#dc262626;color:var(--emergency-red);border:1px solid rgba(220,38,38,.3)}.kpi-card__trend--neutral{background:#64748b26;color:var(--steel-400);border:1px solid rgba(100,116,139,.3)}.kpi-card__trend-icon{font-size:.625rem;line-height:1}.kpi-card__trend-value{line-height:1}.kpi-card__subtitle{font-size:.8125rem;color:var(--oilserv-black);opacity:.7;margin:0;line-height:1.5}.kpi-card__status-bar{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--oilserv-black);opacity:.6;transition:all var(--duration-fast) var(--ease-mechanical)}.kpi-card--good .kpi-card__backdrop{border-left-color:var(--pipeline-green)}.kpi-card--good .kpi-card__status-bar{background:linear-gradient(90deg,var(--pipeline-green) 0%,rgba(5,150,105,.9) 50%,var(--pipeline-green) 100%);opacity:.9;box-shadow:0 -1px 8px var(--pipeline-green-glow),0 -1px 4px #05966926}.kpi-card--warning .kpi-card__backdrop{border-left-color:var(--crude-oil)}.kpi-card--warning .kpi-card__status-bar{background:linear-gradient(90deg,var(--crude-oil) 0%,rgba(217,119,6,.9) 50%,var(--crude-oil) 100%);opacity:.9;box-shadow:0 -1px 8px var(--crude-oil-glow),0 -1px 4px #d9770626}.kpi-card--critical .kpi-card__backdrop{border-left-color:var(--emergency-red)}.kpi-card--critical .kpi-card__status-bar{background:linear-gradient(90deg,var(--emergency-red) 0%,rgba(220,38,38,.9) 50%,var(--emergency-red) 100%);opacity:.9;box-shadow:0 -1px 8px var(--emergency-red-glow),0 -1px 4px #dc262626;animation:status-pulse 2s ease-in-out infinite}.kpi-card--info .kpi-card__backdrop{border-left-color:var(--oilserv-gold-dark)}.kpi-card--info .kpi-card__status-bar{background:var(--oilserv-black);opacity:.6}.kpi-card--clickable{cursor:pointer}.kpi-card--clickable:hover{transform:translateY(-4px);transition-duration:.1s}.kpi-card--clickable:hover .kpi-card__backdrop{background:linear-gradient(135deg,var(--oilserv-gold-light) 0%,#F5D76E 50%,var(--oilserv-gold-light) 100%);border-color:var(--oilserv-gold);box-shadow:var(--shadow-lg),var(--shadow-glow-gold)}.kpi-card--clickable:hover .kpi-card__border-glow{opacity:1}.kpi-card--clickable:hover .kpi-card__status-bar{opacity:1;height:5px}.kpi-card--clickable:active{transform:translateY(-2px)}.kpi-card--clickable:focus-visible{outline:2px solid var(--oilserv-black);outline-offset:4px}.kpi-card--clickable:focus-visible .kpi-card__border-glow{opacity:1}@media(max-width:640px){.kpi-card{padding:1.25rem}.kpi-card__value{font-size:1.875rem}.kpi-card__value-section{flex-direction:column;align-items:flex-start;gap:.75rem}}@keyframes status-pulse{0%,to{opacity:.9;box-shadow:0 -1px 8px var(--emergency-red-glow),0 -1px 4px #dc262626}50%{opacity:1;box-shadow:0 -1px 12px var(--emergency-red-glow),0 -1px 6px #dc262640}}.kpi-card--good .kpi-card__icon{color:var(--pipeline-green);background:var(--oilserv-black);box-shadow:var(--shadow-sm),inset 0 -1px #ffffff1a,0 0 10px #0596691a}.kpi-card--warning .kpi-card__icon{color:var(--crude-oil);background:var(--oilserv-black);box-shadow:var(--shadow-sm),inset 0 -1px #ffffff1a,0 0 10px #d977061a}.kpi-card--critical .kpi-card__icon{color:var(--emergency-red);background:var(--oilserv-black);box-shadow:var(--shadow-sm),inset 0 -1px #ffffff1a,0 0 10px #dc262626}.kpi-card--info .kpi-card__icon{color:var(--oilserv-gold-light);background:var(--oilserv-black);box-shadow:var(--shadow-sm),inset 0 -1px #ffffff1a,0 0 8px #d4af3714}.kpi-card--critical-alert .kpi-card__backdrop{border:2px solid #dc2626;border-left:6px solid #dc2626;box-shadow:var(--shadow-md),0 0 12px #dc26264d,inset 0 1px #ffffff59,inset 0 -1px #00000040;background:linear-gradient(135deg,rgba(220,38,38,.03) 0%,var(--oilserv-gold-light) 25%,#F0DB7D 50%,var(--oilserv-gold-light) 75%,rgba(220,38,38,.03) 100%)}.kpi-card--critical-alert .kpi-card__value{color:#dc2626;font-weight:900;font-size:2.25rem;text-shadow:0 1px 2px rgba(220,38,38,.25),0 .5px 1px rgba(220,38,38,.15)}.kpi-card--critical-alert .status-dot{width:16px;height:16px;animation:pulse-critical-dot 2s ease-in-out infinite}@keyframes pulse-critical-dot{0%,to{opacity:1;transform:scale(1);box-shadow:0 0 0 2px var(--bg-card),0 0 8px #dc262666}50%{opacity:.7;transform:scale(1.15);box-shadow:0 0 0 2px var(--bg-card),0 0 12px #dc262699}}.kpi-card--critical-alert.kpi-card--clickable:hover .kpi-card__backdrop{border-color:#dc2626;box-shadow:var(--shadow-lg),0 0 16px #dc262666}@media(prefers-reduced-motion:reduce){.kpi-card,.kpi-card__backdrop,.kpi-card__border-glow,.kpi-card__status-bar{transition-duration:.01ms!important}.kpi-card__value{animation:none!important}.kpi-card--clickable:hover{transform:none}.kpi-card--critical .kpi-card__status-bar,.kpi-card--critical-alert .status-dot{animation:none!important}}@media print{.kpi-card__backdrop{background:#fff;border:1px solid #ccc}.kpi-card__value{-webkit-text-fill-color:black;color:#000}.kpi-card__border-glow,.kpi-card__status-bar{display:none}}.progress-breakdown{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a}.breakdown-header{margin-bottom:24px}.breakdown-title{margin:0;font-size:18px;font-weight:700;color:#1f2937}.phases-list{display:flex;flex-direction:column;gap:20px}.phase-progress{display:flex;flex-direction:column;gap:8px}.phase-header{display:flex;justify-content:space-between;align-items:center;padding:0 4px}.phase-name{font-size:14px;font-weight:600;color:#374151}.phase-percentage{font-size:14px;font-weight:700;color:#1f2937;min-width:45px;text-align:right}.progress-bar-container{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;position:relative;background-image:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.progress-bar-fill.color-green{background-color:#10b981}.progress-bar-fill.color-amber{background-color:#f59e0b}.progress-bar-fill.color-red{background-color:#ef4444}@media(max-width:768px){.progress-breakdown{padding:16px}.phases-list{gap:16px}.breakdown-title{font-size:16px}.phase-name{font-size:13px}}.progress-breakdown-v2{background:linear-gradient(135deg,#0f172af2,#1e293bf2);border:1px solid rgba(148,163,184,.1);border-radius:16px;padding:28px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 4px 24px #0000001f,0 0 0 1px #ffffff0d inset,0 8px 48px #00000014;position:relative;overflow:hidden;animation:fadeInUp .6s cubic-bezier(.16,1,.3,1)}.progress-breakdown-v2:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(14,165,233,.6) 20%,rgba(5,150,105,.6) 50%,rgba(255,149,0,.6) 80%,transparent 100%);animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{opacity:.5}50%{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.breakdown-header{margin-bottom:24px;border-bottom:1px solid rgba(148,163,184,.1);padding-bottom:20px}.header-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.breakdown-title{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif;font-size:22px;font-weight:700;letter-spacing:-.02em;color:#f8fafc;margin:0;text-shadow:0 2px 8px rgba(0,0,0,.3)}.header-badges{display:flex;gap:8px;align-items:center}.data-source-badge{font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:#0ea5e9;background:#0ea5e91a;border:1px solid rgba(14,165,233,.3);padding:4px 10px;border-radius:6px;cursor:help;transition:all .2s ease}.data-source-badge:hover{background:#0ea5e933;border-color:#0ea5e980;transform:translateY(-1px)}.total-tasks-badge{font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:500;color:#94a3b8;background:#94a3b814;border:1px solid rgba(148,163,184,.15);padding:4px 10px;border-radius:6px}.weighted-progress-summary{display:flex;align-items:baseline;gap:10px;margin-top:12px}.summary-label{font-family:IBM Plex Mono,monospace;font-size:12px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.summary-value{font-family:IBM Plex Mono,monospace;font-size:20px;font-weight:700;color:#059669;text-shadow:0 0 20px rgba(5,150,105,.4)}.phases-grid{display:flex;flex-direction:column;gap:20px}.phase-progress-item{background:#1e293b66;border:1px solid rgba(148,163,184,.1);border-radius:12px;padding:18px;transition:all .3s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;animation:slideInLeft .5s cubic-bezier(.16,1,.3,1) backwards}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.phase-progress-item:hover{background:#1e293b99;border-color:#94a3b833;transform:translate(4px);box-shadow:-4px 0 16px #00000026,0 4px 12px #0000001a}.phase-progress-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:currentColor;opacity:0;transition:opacity .3s ease}.phase-progress-item:hover:before{opacity:1}.phase-progress-item[data-phase=engineering]:before{background:#0ea5e9}.phase-progress-item[data-phase=procurement]:before{background:#ff9500}.phase-progress-item[data-phase=construction]:before{background:#059669}.phase-progress-item[data-phase=commissioning]:before{background:#8b5cf6}.phase-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.phase-name-section{display:flex;align-items:center;gap:10px;flex:1}.phase-status-indicator{font-size:14px;line-height:1;filter:drop-shadow(0 0 8px currentColor);animation:pulse 2s ease-in-out infinite}.phase-name{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,sans-serif;font-size:16px;font-weight:600;letter-spacing:-.01em;color:#f1f5f9;margin:0}.phase-meta{display:flex;gap:8px;align-items:center;margin-left:auto;margin-right:16px}.task-count-badge,.phase-weight-badge{font-family:IBM Plex Mono,monospace;font-size:10px;font-weight:500;padding:3px 8px;border-radius:4px;letter-spacing:.02em}.task-count-badge{color:#cbd5e1;background:#cbd5e114;border:1px solid rgba(203,213,225,.15)}.phase-weight-badge{color:#94a3b8;background:#94a3b814;border:1px solid rgba(148,163,184,.15)}.phase-progress-value{display:flex;align-items:baseline;gap:2px;font-family:IBM Plex Mono,monospace;font-weight:700}.progress-number{font-size:24px;color:#f8fafc;text-shadow:0 2px 12px rgba(248,250,252,.2)}.progress-unit{font-size:14px;color:#94a3b8;font-weight:500}.progress-bar-container{position:relative;height:32px;margin-bottom:10px}.progress-bar-track{position:relative;width:100%;height:100%;background:#0f172a99;border-radius:8px;overflow:hidden;border:1px solid rgba(148,163,184,.1);box-shadow:0 2px 8px #0003 inset,0 1px 2px #ffffff0d}.progress-bar-fill{position:absolute;left:0;top:0;height:100%;border-radius:8px;transition:width 1.2s cubic-bezier(.16,1,.3,1);box-shadow:0 0 20px currentColor,0 4px 16px #0000004d;position:relative;overflow:hidden}.progress-shine{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shine 2s ease-in-out infinite}@keyframes shine{0%{left:-100%}to{left:200%}}.phase-weight-marker{position:absolute;top:-4px;width:2px;height:calc(100% + 8px);background:#fff6;pointer-events:none;z-index:10;box-shadow:0 0 8px #fff9}.progress-gradient-overlay{position:absolute;top:0;left:0;right:0;height:40%;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 100%);pointer-events:none;border-radius:8px 8px 0 0}.micro-indicators{display:flex;justify-content:space-between;padding:0 2px}.indicator-dot{width:4px;height:4px;border-radius:50%;background:#64748b;transition:all .4s ease}.breakdown-footer{margin-top:20px;padding-top:16px;border-top:1px solid rgba(148,163,184,.1)}.legend{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.legend-item{display:flex;align-items:center;gap:6px;font-family:IBM Plex Mono,monospace;font-size:10px;color:#94a3b8;letter-spacing:.02em}.legend-symbol{color:#64748b;font-size:12px}.loading-state .breakdown-subtitle{font-family:IBM Plex Mono,monospace;font-size:12px;color:#64748b;margin:8px 0 0}.loading-skeleton{display:flex;flex-direction:column;gap:16px;margin-top:20px}.skeleton-bar{height:80px;background:linear-gradient(90deg,#1e293b66,#33415566,#1e293b66);background-size:200% 100%;border-radius:12px;animation:loading 1.5s ease-in-out infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{min-height:200px;display:flex;flex-direction:column;justify-content:center;align-items:center;opacity:.6}.empty-state .breakdown-subtitle{font-family:IBM Plex Mono,monospace;font-size:13px;color:#64748b;margin:0}@media(max-width:768px){.progress-breakdown-v2{padding:20px}.header-title-row{flex-direction:column;align-items:flex-start;gap:12px}.phase-header-row{flex-direction:column;gap:12px}.phase-meta{margin-left:0;margin-right:0}.progress-number{font-size:20px}.legend{gap:12px}}.quick-links{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a}.links-header{margin-bottom:20px}.links-title{margin:0;font-size:18px;font-weight:700;color:#1f2937}.links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.quick-link-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:2px solid #e5e7eb;border-radius:8px;text-decoration:none;color:#1f2937;font-size:13px;font-weight:600;text-align:center;transition:all .3s ease;cursor:pointer;min-height:70px}.quick-link-button:hover{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6;color:#1e40af;box-shadow:0 4px 12px #3b82f633;transform:translateY(-2px)}.quick-link-button:active{transform:translateY(0)}.link-icon{font-size:24px;line-height:1}.link-label{display:block;word-break:break-word}.quick-link-button.evm:hover{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6}.quick-link-button.engineering:hover{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#22c55e}.quick-link-button.procurement:hover{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}@media(max-width:768px){.quick-links{padding:16px}.links-grid{grid-template-columns:repeat(2,1fr);gap:10px}.quick-link-button{padding:12px 8px;min-height:60px;font-size:12px}.link-icon{font-size:20px}}@media(max-width:480px){.links-grid{grid-template-columns:1fr}}.breadcrumb{padding:12px 0;margin-bottom:20px;border-bottom:1px solid #e5e7eb}.breadcrumb-list{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:0}.breadcrumb-item{display:flex;align-items:center;gap:8px}.breadcrumb-link{color:#3b82f6;text-decoration:none;font-size:14px;font-weight:500;padding:4px 0;transition:color .2s ease}.breadcrumb-link:hover{color:#1e40af;text-decoration:underline}.breadcrumb-current{color:#6b7280;font-size:14px;font-weight:500;padding:4px 0}.breadcrumb-separator{color:#d1d5db;margin:0 4px;font-size:12px}@media(max-width:640px){.breadcrumb-list{flex-wrap:wrap}.breadcrumb-link,.breadcrumb-current{font-size:13px}}.sidebar{position:fixed;left:0;top:0;height:100vh;width:280px;background:linear-gradient(180deg,#1a2332fa,#0f172afa);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid rgba(212,175,55,.15);box-shadow:4px 0 24px #0000004d;display:flex;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1000;overflow:hidden}.sidebar--collapsed{width:80px}.sidebar-header{padding:1.5rem 1rem;border-bottom:1px solid rgba(212,175,55,.1);display:flex;align-items:center;justify-content:space-between;min-height:80px}.sidebar-logo-container{display:flex;align-items:center;gap:.75rem;cursor:pointer;flex:1}.sidebar-logo{width:40px;height:40px;-o-object-fit:contain;object-fit:contain;transition:transform .2s ease}.sidebar-logo:hover{transform:scale(1.05)}.sidebar-title{display:flex;flex-direction:column;gap:.125rem}.sidebar-title-main{font-family:var(--font-display);font-size:1.25rem;font-weight:800;color:var(--oilserv-gold);letter-spacing:.05em;line-height:1}.sidebar-title-sub{font-family:var(--font-mono);font-size:.625rem;font-weight:600;color:#d4af3799;letter-spacing:.1em;text-transform:uppercase}.sidebar-toggle{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#d4af371a;border:1px solid rgba(212,175,55,.2);border-radius:6px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.sidebar-toggle:hover{background:#d4af3733;border-color:#d4af3766;transform:translate(2px)}.toggle-icon{font-family:var(--font-mono);font-size:1rem;font-weight:700;color:var(--oilserv-gold)}.sidebar-project-selector{padding:1rem;border-bottom:1px solid rgba(212,175,55,.1);background:linear-gradient(135deg,#d4af370d,#d4af3705)}.project-selector-label{display:block;font-family:var(--font-mono);font-size:.625rem;font-weight:700;color:#d4af3799;letter-spacing:.1em;margin-bottom:.5rem;text-transform:uppercase}.project-selector-dropdown{width:100%;padding:.625rem .75rem;background:#0f172a99;border:1px solid rgba(212,175,55,.2);border-radius:6px;font-family:var(--font-mono);font-size:.875rem;font-weight:700;color:var(--oilserv-gold);cursor:pointer;transition:all .2s ease;margin-bottom:.5rem}.project-selector-dropdown:hover{border-color:#d4af3766;background:#0f172acc}.project-selector-dropdown:focus{outline:none;border-color:var(--oilserv-gold);box-shadow:0 0 0 3px #d4af371a}.project-selector-name{font-family:var(--font-body);font-size:.75rem;color:#f8fafc99;line-height:1.4}.sidebar-nav{flex:1;overflow-y:auto;padding:1rem 0}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#d4af3733;border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#d4af3766}.nav-section{margin-bottom:1.5rem}.nav-section:last-child{margin-bottom:0}.nav-section-label{padding:0 1rem;margin-bottom:.5rem;font-family:var(--font-mono);font-size:.625rem;font-weight:700;color:#d4af3780;letter-spacing:.1em;text-transform:uppercase}.nav-items{display:flex;flex-direction:column;gap:.25rem;padding:0 .75rem}.nav-item{position:relative;display:flex;align-items:center;gap:.75rem;padding:.75rem .875rem;background:transparent;border:1px solid transparent;border-radius:8px;font-family:var(--font-body);font-size:.875rem;font-weight:500;color:#f8fafcb3;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.nav-item:hover:not(.nav-item--disabled){background:#d4af3714;border-color:#d4af3733;color:#f8fafcf2;transform:translate(2px)}.nav-item--active{background:linear-gradient(135deg,#d4af3726,#d4af3714);border-color:#d4af3766;color:#fff}.nav-item--active .nav-item-icon{color:var(--oilserv-gold)}.nav-item--disabled{opacity:.4;cursor:not-allowed}.nav-item-icon{font-family:var(--font-mono);font-size:.75rem;font-weight:700;color:#d4af37b3;letter-spacing:-.02em;min-width:40px;text-align:center;transition:color .2s ease}.sidebar--collapsed .nav-item-icon{min-width:auto}.nav-item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item-indicator{position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--oilserv-gold);border-radius:2px 0 0 2px;box-shadow:0 0 8px #d4af3799}.sidebar-footer{padding:1rem .75rem;border-top:1px solid rgba(212,175,55,.1)}.sidebar-user-info{padding:.875rem;margin-bottom:.75rem;background:#d4af370d;border:1px solid rgba(212,175,55,.15);border-radius:8px}.user-info-name{font-family:var(--font-body);font-size:.875rem;font-weight:600;color:#f8fafcf2;margin-bottom:.25rem}.user-info-role{font-family:var(--font-mono);font-size:.6875rem;font-weight:700;color:#d4af37b3;letter-spacing:.05em}.nav-item--footer{justify-content:flex-start}.nav-item--logout:hover{background:#dc26261a;border-color:#dc26264d;color:#fca5a5}.nav-item--logout:hover .nav-item-icon{color:#fca5a5}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999}.sidebar--collapsed .sidebar-header{padding:1.5rem .5rem;justify-content:center}.sidebar--collapsed .sidebar-logo-container{justify-content:center}.sidebar--collapsed .sidebar-toggle{position:absolute;right:-16px;top:24px}.sidebar--collapsed .nav-items{padding:0 .5rem}.sidebar--collapsed .nav-item{justify-content:center;padding:.75rem}.sidebar--collapsed .nav-item-indicator{right:0}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar:not(.sidebar--collapsed){transform:translate(0)}.sidebar-overlay{display:block}}@media(max-width:768px){.sidebar{width:260px}}@media(prefers-reduced-motion:reduce){.sidebar,.nav-item,.sidebar-toggle,.sidebar-logo{transition:none}}.app-layout{display:flex;min-height:100vh;background:var(--bg-primary, #0f1729);position:relative}.app-main{flex:1;margin-left:280px;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.app-main--expanded{margin-left:80px}@media(max-width:1024px){.app-main,.app-main--expanded{margin-left:0}}.app-main>*{width:100%;max-width:100%}.command-center-loading{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172af2,#1e293bf2);z-index:9999;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading-container{display:flex;flex-direction:column;align-items:center;padding:3rem 4rem;min-width:400px;text-align:center}.spinner-container{margin-bottom:2rem}.industrial-spinner{position:relative;width:120px;height:120px}.spinner-ring{position:absolute;top:0;left:0;width:100%;height:100%;border:3px solid transparent;border-top-color:#3b82f6;border-radius:50%;animation:spin 1.5s linear infinite}.spinner-ring:nth-child(2){width:90%;height:90%;top:5%;left:5%;border-top-color:#60a5fa;animation-duration:2s;animation-direction:reverse}.spinner-ring:nth-child(3){width:80%;height:80%;top:10%;left:10%;border-top-color:#93c5fd;animation-duration:2.5s}.spinner-core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;background:linear-gradient(135deg,#3b82f6,#60a5fa);border-radius:50%;box-shadow:0 0 20px #3b82f680;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.7;transform:translate(-50%,-50%) scale(1.1)}}.loading-messages{width:100%}.loading-title{font-size:1.5rem;font-weight:700;color:#f8fafc;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.loading-subtitle{font-size:.875rem;color:#cbd5e1;margin-bottom:1.5rem;font-weight:400}.progress-bar-container{width:100%;margin-bottom:1.5rem}.progress-bar-track{width:100%;height:4px;background:#94a3b833;border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa,#3b82f6);background-size:200% 100%;animation:progress 2s ease-in-out infinite;border-radius:2px}@keyframes progress{0%{background-position:-200% 0}to{background-position:200% 0}}.status-indicators{display:flex;align-items:center;justify-content:center;gap:.5rem}.status-dot{width:8px;height:8px;border-radius:50%;background:#10b981;box-shadow:0 0 10px #10b98180}.status-dot.pulse{animation:statusPulse 2s ease-in-out infinite}@keyframes statusPulse{0%,to{opacity:1;box-shadow:0 0 10px #10b98180}50%{opacity:.6;box-shadow:0 0 20px #10b981cc}}.status-text{font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-weight:600}@media(max-width:640px){.loading-container{padding:2rem 1.5rem;min-width:300px}.industrial-spinner{width:80px;height:80px}.spinner-core{width:30px;height:30px}.loading-title{font-size:1.25rem}.loading-subtitle{font-size:.75rem}}.metrics-table-container{background:var(--oilserv-offwhite-glass, rgba(255, 255, 255, .95));backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:2px solid rgba(212,175,55,.2);border-radius:16px;padding:1.5rem;box-shadow:0 10px 40px #00000014,inset 0 1px #fffc,inset 0 -1px #d4af3714;position:relative;overflow:hidden}.metrics-table-container:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--oilserv-gold, #D4AF37) 0%,#F5E6B8 50%,var(--oilserv-gold, #D4AF37) 100%);opacity:.9}.metrics-table__header{margin-bottom:1.5rem}.metrics-table__header-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:.75rem}.metrics-table__title{font-family:var(--font-display, "Geist", system-ui, sans-serif);font-size:1.5rem;font-weight:700;color:var(--oilserv-gold-dark, #B8860B);margin:0;letter-spacing:-.02em}.metrics-table__subtitle{font-size:.875rem;color:var(--text-secondary, #64748b);margin:0}.metrics-table__badges{display:flex;gap:.5rem;flex-wrap:wrap}.data-source-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#0ea5e91a;border:1px solid rgba(14,165,233,.3);border-radius:20px;font-size:.75rem;font-weight:600;color:#0284c7;text-transform:uppercase;letter-spacing:.05em}.data-source-badge--sap{background:#d4af371a;border-color:#d4af3766;color:var(--oilserv-gold-dark, #B8860B)}.metrics-table__contract-value{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#d4af3714;border-radius:10px;border:1px solid rgba(212,175,55,.2)}.contract-label{font-size:.875rem;font-weight:600;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.05em}.contract-amount{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:1.25rem;font-weight:700;color:var(--oilserv-gold-dark, #B8860B)}.metrics-table__wrapper{overflow-x:auto;border-radius:12px;border:1px solid rgba(0,0,0,.08)}.metrics-table{width:100%;border-collapse:collapse;font-size:.875rem}.metrics-table__th{padding:.875rem 1rem;text-align:center;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary, #64748b);background:#f8fafce6;border-bottom:2px solid rgba(0,0,0,.08);white-space:nowrap}.metrics-table__th--group{background:#0ea5e914;color:#0284c7;border-bottom:1px solid rgba(14,165,233,.2)}.metrics-table__th--cost{background:#d4af371a;color:var(--oilserv-gold-dark, #B8860B);border-bottom-color:#d4af374d}.metrics-table__th--billing{background:#05966914;color:#059669;border-bottom-color:#05966933}.metrics-table__th--sub{font-size:.6875rem;padding:.625rem .75rem;background:#f8fafc80}.metrics-table__row{transition:background-color .15s ease}.metrics-table__row:hover{background:#d4af370a}.metrics-table__row[data-phase=overall]{background:#64748b0d;font-weight:600}.metrics-table__row[data-phase=overall]:hover{background:#64748b14}.metrics-table__cell{padding:1rem;text-align:center;border-bottom:1px solid rgba(0,0,0,.05);font-family:var(--font-mono, "JetBrains Mono", monospace)}.metrics-table__cell--phase{text-align:left;font-family:var(--font-display, "Geist", system-ui, sans-serif);font-weight:600;color:var(--text-primary, #1e293b);display:flex;align-items:center;gap:.75rem}.phase-indicator{width:10px;height:10px;border-radius:3px;flex-shrink:0}.metrics-table__cell--number{font-size:.8125rem;color:var(--text-primary, #1e293b)}.metrics-table__cell--actual{font-weight:600;color:var(--text-primary, #1e293b)}.metrics-table__cell--variance{font-weight:700}.metrics-table__cell--balance{font-weight:600;color:#059669}.metrics-table__legend{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:1.25rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.06)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-secondary, #64748b)}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-text{font-weight:500}.metrics-table--loading{min-height:300px}.metrics-table__skeleton{display:flex;flex-direction:column;gap:.75rem;padding:1rem}.skeleton-row{height:48px;background:linear-gradient(90deg,#0000000a 25%,#00000014,#0000000a 75%);background-size:200% 100%;border-radius:8px;animation:skeleton-shimmer 1.5s ease-in-out infinite}@media(max-width:768px){.metrics-table-container{padding:1rem;border-radius:12px}.metrics-table__header-row{flex-direction:column;align-items:flex-start}.metrics-table__title{font-size:1.25rem}.metrics-table__th,.metrics-table__cell{padding:.625rem .5rem;font-size:.75rem}.contract-amount{font-size:1rem}}.realtime-indicator{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:12px;font-size:.6875rem;font-weight:600;color:#059669;text-transform:uppercase;letter-spacing:.05em}.realtime-dot{width:6px;height:6px;border-radius:50%;background:#10b981;animation:pulse-realtime 2s ease-in-out infinite}@keyframes pulse-realtime{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.hse-admin-form{max-width:900px;margin:0 auto;padding:2rem;background:#fffffff2;border-radius:16px;border:1px solid var(--border-color, #e5e7eb);box-shadow:0 4px 24px #00000014}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color, #e5e7eb)}.form-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1f2937);margin:0;font-family:var(--font-display, "Inter", sans-serif)}.status-indicator{padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.05em}.form-error{padding:1rem;margin-bottom:1.5rem;background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:8px;color:#dc2626;font-weight:500}.form-success{padding:1rem;margin-bottom:1.5rem;background:#0596691a;border:1px solid rgba(5,150,105,.3);border-radius:8px;color:#059669;font-weight:500}.form-section{margin-bottom:1.5rem;padding:1.5rem;background:#f8fafc99;border-radius:12px;border:1px solid var(--border-color, #e5e7eb)}.form-section.collapsible{padding:0}.form-section.collapsible .section-header{padding:1rem 1.5rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background-color .2s ease}.form-section.collapsible .section-header:hover{background:#00000005}.form-section.collapsible .section-content{padding:0 1.5rem 1.5rem}.form-section h3{font-size:1rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0 0 1rem}.form-section.collapsible h3{margin:0}.toggle-icon{font-size:1.25rem;font-weight:700;color:var(--text-secondary, #6b7280)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-row:last-child{margin-bottom:0}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary, #6b7280)}.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;font-size:.9375rem;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;background:#fff;color:var(--text-primary, #1f2937);transition:border-color .2s ease,box-shadow .2s ease;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--oilserv-gold, #c5a54a);box-shadow:0 0 0 3px #c5a54a1a}.form-group input.readonly{background:#f8fafccc;color:var(--text-secondary, #6b7280);cursor:not-allowed}.form-group input[type=number]{font-family:JetBrains Mono,monospace}.form-group textarea{resize:vertical;min-height:80px}.form-group select{cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color, #e5e7eb)}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background:linear-gradient(135deg,var(--oilserv-gold, #c5a54a) 0%,var(--oilserv-gold-dark, #a68a3a) 100%);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--oilserv-gold-dark, #a68a3a) 0%,#8a7230 100%);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--text-secondary, #6b7280);border:1px solid var(--border-color, #e5e7eb)}.btn-secondary:hover{background:#00000005;border-color:var(--text-secondary, #6b7280)}@media(max-width:768px){.hse-admin-form{padding:1rem;border-radius:12px}.form-header{flex-direction:column;gap:1rem;align-items:flex-start}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;text-align:center}}.portfolio-table-container{background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;border:2px solid rgba(212,175,55,.2);box-shadow:0 8px 32px #00000014,inset 0 1px #ffffffe6;overflow:hidden}.portfolio-table__wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.portfolio-table{width:100%;border-collapse:collapse;font-size:1rem}.portfolio-table__header-row .portfolio-table__th{background:linear-gradient(135deg,#d4af37,#b8941f);color:#1a1a1a;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.08em;padding:1rem .75rem;text-align:center;border-bottom:2px solid rgba(212,175,55,.3);white-space:nowrap;cursor:pointer;transition:background .2s ease}.portfolio-table__header-row .portfolio-table__th:hover{background:linear-gradient(135deg,#e5c04a,#c9a530)}.portfolio-table__th--expand{width:50px;cursor:default!important}.portfolio-table__th--status{width:80px;text-align:center!important}.portfolio-table__th--project{text-align:left!important;min-width:200px}.portfolio-table__th--action{width:60px;cursor:default!important}.portfolio-table__th--group{border-left:2px solid rgba(255,255,255,.3);font-size:.875rem}.portfolio-table__th--cost{background:linear-gradient(135deg,#c9a530,#a67c1a)!important}.portfolio-table__th--health{background:linear-gradient(135deg,#b8860b,#8b6914)!important}.portfolio-table__subheader-row .portfolio-table__th{background:#d4af3726;color:#5c4a1a;font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.06em;padding:.75rem;text-align:center;border-bottom:1px solid rgba(212,175,55,.2);cursor:pointer;transition:background .2s ease}.portfolio-table__subheader-row .portfolio-table__th:hover{background:#d4af3740}.portfolio-table__th--spacer{background:#d4af3726!important;border-bottom:1px solid rgba(212,175,55,.2);cursor:default!important}.portfolio-table__th--sub{min-width:80px}.th-content{display:inline-flex;align-items:center;gap:.375rem}.sort-indicator{font-size:.6875rem;opacity:.8}.portfolio-table__row{cursor:pointer;transition:all .15s ease;border-bottom:1px solid rgba(212,175,55,.1)}.portfolio-table__row:hover{background:#d4af3714!important}.portfolio-table__row--expanded{background:#d4af370d!important;border-bottom:none}.portfolio-table__row--red{background:#dc262608}.portfolio-table__row--red:hover{background:#dc262614!important}.portfolio-table__row--workpackage{background:#d4af3708;cursor:default;border-bottom:1px solid rgba(212,175,55,.08)}.portfolio-table__row--workpackage:last-child{border-bottom:2px solid rgba(212,175,55,.15)}.portfolio-table__row--workpackage:hover{background:#d4af370f!important}.portfolio-table__cell--workpackage-name{font-weight:500;color:#64748b;font-size:.9375rem;padding-left:1rem!important}.portfolio-table__cell--workpackage{color:#64748b;font-size:.9375rem!important}.workpackage-indent{color:#94a3b8;font-family:monospace;font-size:.875rem}.portfolio-table__cell{padding:1rem .75rem;vertical-align:middle;font-size:1rem}.portfolio-table__cell--expand{text-align:center;width:50px}.portfolio-table__cell--status{text-align:center}.portfolio-table__cell--project{text-align:left}.portfolio-table__cell--number{text-align:right;font-family:JetBrains Mono,SF Mono,Monaco,monospace;font-size:1rem;font-weight:500}.portfolio-table__cell--actual{font-weight:600;color:#1a1a1a}.portfolio-table__cell--variance{font-weight:700}.portfolio-table__cell--health{font-weight:700;font-size:1.0625rem}.portfolio-table__cell--action{text-align:center;width:60px}.expand-toggle{background:none;border:none;padding:.25rem;cursor:pointer;color:#64748b;border-radius:4px;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.expand-toggle:hover{background:#d4af3733;color:#d4af37}.navigate-btn{background:#d4af371a;border:1px solid rgba(212,175,55,.3);padding:.5rem;cursor:pointer;color:#b8860b;border-radius:6px;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.navigate-btn:hover{background:#d4af3740;color:#8b6914;transform:scale(1.05)}.variance-indicator{display:inline-flex;align-items:center;gap:.25rem;font-weight:700}.variance-arrow{font-size:1.125rem;line-height:1}.variance-arrow--up{color:#059669}.variance-arrow--down{color:#dc2626}.variance-arrow--neutral{color:#6b7280}.status-indicator-wrapper{display:flex;justify-content:center;align-items:center}.status-dot{width:16px;height:16px;border-radius:50%;display:inline-block;box-shadow:0 2px 4px #0003}.status-dot--pulse{animation:status-pulse 2s ease-in-out infinite}@keyframes status-pulse{0%,to{transform:scale(1);box-shadow:0 0 #dc2626b3}50%{transform:scale(1.1);box-shadow:0 0 20px 8px #dc262600}}.project-info{display:flex;flex-direction:column;gap:.25rem}.project-name{font-weight:600;color:#1a1a1a;font-size:1.0625rem}.project-code{font-family:JetBrains Mono,SF Mono,monospace;font-size:.8125rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.portfolio-table__empty{text-align:center;padding:3rem 2rem;color:#64748b;font-size:1rem}.portfolio-table--loading{min-height:300px;display:flex;align-items:center;justify-content:center}.portfolio-table__skeleton{width:100%;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.skeleton-row{height:56px;background:linear-gradient(90deg,#d4af371a,#d4af3733,#d4af371a);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:8px}.portfolio-mobile-view{display:none;flex-direction:column;gap:1rem;padding:1rem}.portfolio-card{background:#fffffffa;border-radius:12px;border:1px solid rgba(212,175,55,.2);box-shadow:0 4px 12px #0000000f;overflow:hidden}.portfolio-card--red{border-left:4px solid #dc2626}.portfolio-card--amber{border-left:4px solid #f59e0b}.portfolio-card--green{border-left:4px solid #059669}.portfolio-card__header{display:flex;align-items:center;gap:.75rem;padding:1rem;cursor:pointer;background:#d4af370d;border-bottom:1px solid rgba(212,175,55,.1)}.portfolio-card__status{flex-shrink:0}.portfolio-card__title{flex:1;min-width:0}.portfolio-card__title h3{margin:0;font-size:1.125rem;font-weight:600;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portfolio-card__toggle{flex-shrink:0;color:#64748b}.portfolio-card__metrics{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.metric-group{display:flex;flex-direction:column;gap:.25rem}.metric-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:600}.metric-row{display:flex;flex-wrap:wrap;gap:1rem;font-size:1rem;font-weight:500}.metric-value{font-size:1.125rem;font-weight:600;color:#1a1a1a;font-family:JetBrains Mono,monospace}.portfolio-card__workpackages{padding:.75rem 1rem;background:#d4af370d;border-top:1px solid rgba(212,175,55,.1)}.portfolio-card__workpackages h4{margin:0 0 .5rem;font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.workpackage-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(212,175,55,.08)}.workpackage-row:last-child{border-bottom:none}.workpackage-name{font-weight:500;color:#374151}.workpackage-progress{font-family:JetBrains Mono,monospace;font-weight:500}.portfolio-card__action{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;background:linear-gradient(135deg,#d4af37,#b8941f);color:#1a1a1a;font-weight:600;font-size:1rem;border:none;cursor:pointer;transition:all .2s ease}.portfolio-card__action:hover{background:linear-gradient(135deg,#e5c04a,#c9a530)}@media(min-width:1440px){.portfolio-table{font-size:1.0625rem}.portfolio-table__cell{padding:1.125rem 1rem}.portfolio-table__cell--number{font-size:1.0625rem}.portfolio-table__cell--health,.project-name{font-size:1.125rem}.status-dot{width:18px;height:18px}}@media(max-width:1279px){.portfolio-table{font-size:.9375rem}.portfolio-table__cell{padding:.875rem .625rem}.portfolio-table__cell--number{font-size:.9375rem}.portfolio-table__cell--health,.project-name{font-size:1rem}}@media(max-width:1023px){.portfolio-table-container{border-radius:12px}.portfolio-table{font-size:.875rem}.portfolio-table__header-row .portfolio-table__th{padding:.875rem .5rem;font-size:.75rem}.portfolio-table__subheader-row .portfolio-table__th{padding:.625rem .5rem;font-size:.6875rem}.portfolio-table__cell{padding:.75rem .5rem;font-size:.875rem}.portfolio-table__cell--number{font-size:.875rem}.portfolio-table__cell--health,.project-name{font-size:.9375rem}.project-code{font-size:.6875rem}.variance-arrow{font-size:.9375rem}.status-dot{width:14px;height:14px}}@media(max-width:767px){.portfolio-table__wrapper{display:none}.portfolio-mobile-view{display:flex}.portfolio-table-container{background:transparent;border:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}}@media print{.portfolio-table-container{background:#fff;border:1px solid #ccc;box-shadow:none}.portfolio-table__header-row .portfolio-table__th{background:#d4af37!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.status-dot--pulse{animation:none}.navigate-btn,.expand-toggle{display:none}.portfolio-mobile-view{display:none!important}.portfolio-table__wrapper{display:block!important}}.kpi-strip{display:flex;gap:1rem;padding:1rem;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:12px;border:2px solid rgba(212,175,55,.15);box-shadow:0 4px 16px #0000000f;overflow-x:auto}.kpi-strip__item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:#fffc;border-radius:10px;border:1px solid rgba(212,175,55,.1);min-width:140px;flex:1;transition:all .2s ease}.kpi-strip__item:hover{border-color:#d4af374d;box-shadow:0 2px 8px #d4af371a}.kpi-strip__item--critical{background:#dc26260d;border-color:#dc262633}.kpi-strip__item--critical:hover{background:#dc262614;border-color:#dc26264d}.kpi-strip__icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#d4af37;color:#fff;flex-shrink:0}.kpi-strip__icon--budget{background:linear-gradient(135deg,#d4af37,#b8941f)}.kpi-strip__icon--projects{background:linear-gradient(135deg,#0ea5e9,#0284c7)}.kpi-strip__icon--critical{background:linear-gradient(135deg,#dc2626,#b91c1c)}.kpi-strip__content{display:flex;flex-direction:column;gap:.125rem}.kpi-strip__value{font-family:JetBrains Mono,SF Mono,monospace;font-size:1.125rem;font-weight:700;color:#1a1a1a;line-height:1.2}.kpi-strip__value--critical{color:#dc2626}.kpi-strip__label{font-size:.6875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.kpi-strip--loading{min-height:80px}.kpi-strip__item--skeleton{background:#d4af370d}.skeleton-pulse{width:100%;height:100%;background:linear-gradient(90deg,#d4af371a,#d4af3733,#d4af371a);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:6px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:1024px){.kpi-strip{gap:.75rem;padding:.75rem}.kpi-strip__item{padding:.625rem 1rem;min-width:120px}.kpi-strip__icon{width:36px;height:36px}.kpi-strip__value{font-size:1rem}}@media(max-width:768px){.kpi-strip{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.kpi-strip__item{min-width:110px;flex-shrink:0}.kpi-strip__icon{width:32px;height:32px}.kpi-strip__icon svg{width:16px;height:16px}.kpi-strip__value{font-size:.9375rem}.kpi-strip__label{font-size:.625rem}}.battery-indicator{display:inline-flex;align-items:center;gap:.5rem}.battery-indicator__svg{display:block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.battery-indicator__body{fill:#ffffff4d;stroke:var(--oilserv-black);stroke-opacity:.4}.battery-indicator__terminal{fill:var(--oilserv-black);fill-opacity:.4;stroke:none}.battery-indicator__segment{stroke:var(--oilserv-black);stroke-opacity:.2}.battery-indicator__fill--good{fill:var(--pipeline-green);filter:drop-shadow(0 0 4px rgba(5,150,105,.3));animation:battery-pulse-good 3s ease-in-out infinite}.battery-indicator__fill--warning{fill:var(--crude-oil);filter:drop-shadow(0 0 4px rgba(217,119,6,.3));animation:battery-pulse-warning 2.5s ease-in-out infinite}.battery-indicator__fill--critical{fill:var(--emergency-red);filter:drop-shadow(0 0 6px rgba(220,38,38,.4));animation:battery-pulse-critical 2s ease-in-out infinite}.battery-indicator__label{font-family:var(--font-mono);font-size:.875rem;font-weight:700;letter-spacing:.02em}.battery-indicator__label--good{color:var(--pipeline-green)}.battery-indicator__label--warning{color:var(--crude-oil)}.battery-indicator__label--critical{color:var(--emergency-red)}.battery-indicator--sm .battery-indicator__label{font-size:.75rem}.battery-indicator--lg .battery-indicator__label{font-size:1rem}@keyframes battery-pulse-good{0%,to{opacity:1}50%{opacity:.85}}@keyframes battery-pulse-warning{0%,to{opacity:1}50%{opacity:.8}}@keyframes battery-pulse-critical{0%,to{opacity:1;filter:drop-shadow(0 0 6px rgba(220,38,38,.4))}50%{opacity:.75;filter:drop-shadow(0 0 8px rgba(220,38,38,.6))}}@media(prefers-reduced-motion:reduce){.battery-indicator__fill--good,.battery-indicator__fill--warning,.battery-indicator__fill--critical{animation:none!important}}@media print{.battery-indicator__svg{filter:none}.battery-indicator__fill--good,.battery-indicator__fill--warning,.battery-indicator__fill--critical{filter:none;animation:none}}.radial-gauge{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:2px solid rgba(212,175,55,.15);border-radius:16px;box-shadow:var(--shadow-md),inset 0 1px #fffc,inset 0 -1px #d4af370f;transition:all var(--duration-normal) var(--ease-mechanical)}.radial-gauge:hover{border-color:#d4af374d;box-shadow:var(--shadow-lg),inset 0 1px #ffffffe6,inset 0 -1px #d4af371a}.radial-gauge__svg{display:block}.radial-gauge__track{fill:none;stroke:#00000014}.radial-gauge__progress{fill:none;stroke-linecap:round;transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.radial-gauge__center-glow{fill:#ffffff80}.radial-gauge__value-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;text-align:center;padding-bottom:.5rem}.radial-gauge__value{font-family:var(--font-display);font-weight:800;line-height:1.1;letter-spacing:-.03em;color:var(--text-primary)}.radial-gauge__label{font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-top:.25rem}.radial-gauge__subtitle{font-family:var(--font-body);font-size:.75rem;color:var(--text-tertiary);margin-top:.125rem}.radial-gauge--good .radial-gauge__value{color:var(--pipeline-green)}.radial-gauge--warning .radial-gauge__value{color:var(--natural-gas-amber)}.radial-gauge--critical .radial-gauge__value{color:var(--emergency-red)}.radial-gauge--critical{border-color:#dc26264d;box-shadow:var(--shadow-md),0 0 20px #dc262626,inset 0 1px #fffc}.radial-gauge--info .radial-gauge__value{color:var(--tech-cyan)}.radial-gauge--sm{min-width:150px;min-height:170px}.radial-gauge--md{min-width:190px;min-height:210px}.radial-gauge--lg{min-width:230px;min-height:260px}@media(max-width:640px){.radial-gauge--lg{min-width:180px;min-height:200px}.radial-gauge--lg .radial-gauge__svg{width:140px;height:140px}}@keyframes gauge-fill{0%{stroke-dashoffset:var(--circumference)}}.radial-gauge__progress{animation:gauge-fill 1s cubic-bezier(.4,0,.2,1) forwards}@media(prefers-reduced-motion:reduce){.radial-gauge__progress{transition-duration:.01ms!important;animation-duration:.01ms!important}}.cost-category-bar{padding:1.5rem;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:2px solid rgba(212,175,55,.15);border-radius:16px;box-shadow:var(--shadow-md),inset 0 1px #fffc,inset 0 -1px #d4af370f}.cost-category-bar__title{font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem}.cost-category-bar__title:before{content:"";width:4px;height:20px;background:linear-gradient(180deg,var(--oilserv-gold) 0%,var(--oilserv-gold-dark) 100%);border-radius:2px}.cost-category-bar--horizontal .cost-category-bar__items{display:flex;flex-direction:column;gap:1rem}.cost-category-bar__item{display:flex;flex-direction:column;gap:.5rem}.cost-category-bar__item-header{display:flex;justify-content:space-between;align-items:center}.cost-category-bar__item-name{display:flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:var(--text-primary)}.item-icon{font-size:1rem}.gl-prefix{font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--text-tertiary);background:#0000000a;padding:.125rem .5rem;border-radius:4px}.cost-category-bar__item-values{display:flex;align-items:center;gap:1rem}.item-amount{font-family:var(--font-mono);font-size:.9375rem;font-weight:700;color:var(--text-primary)}.item-percent{font-family:var(--font-mono);font-size:.8125rem;font-weight:600;color:var(--text-secondary);background:#d4af371a;padding:.125rem .5rem;border-radius:4px}.cost-category-bar__progress-container{width:100%}.cost-category-bar__progress-track{width:100%;height:12px;background:#0000000f;border-radius:6px;overflow:hidden;box-shadow:inset 0 1px 2px #00000014}.cost-category-bar__progress-fill{height:100%;border-radius:6px;transition:width .8s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #00000026}.cost-category-bar__total{display:flex;align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:2px solid var(--border-color)}.total-label{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text-primary);flex:1}.total-value{font-family:var(--font-mono);font-size:1.25rem;font-weight:800;color:var(--oilserv-gold-dark)}.total-percent{font-family:var(--font-mono);font-size:.875rem;font-weight:600;color:var(--text-secondary);background:#d4af371a;padding:.25rem .75rem;border-radius:6px}.cost-category-bar--stacked .cost-category-bar__stacked-container{position:relative;margin-bottom:1.5rem}.cost-category-bar__stacked-bar{display:flex;height:32px;border-radius:8px;overflow:hidden;box-shadow:inset 0 1px 3px #0000001a}.cost-category-bar__stacked-segment{height:100%;min-width:2px;transition:width .8s cubic-bezier(.4,0,.2,1),opacity .2s}.cost-category-bar__stacked-segment:hover{opacity:.85}.cost-category-bar__budget-marker{position:absolute;top:-8px;transform:translate(-50%)}.budget-marker-label{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--text-secondary);background:#ffffffe6;padding:.25rem .5rem;border-radius:4px;box-shadow:var(--shadow-sm)}.cost-category-bar__legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.cost-category-bar__legend-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#ffffff80;border-radius:6px;transition:background var(--duration-fast)}.cost-category-bar__legend-item:hover{background:#fffc}.cost-category-bar__legend-color{width:12px;height:12px;border-radius:3px;flex-shrink:0}.cost-category-bar__legend-name{flex:1;font-family:var(--font-body);font-size:.8125rem;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:.25rem}.legend-icon{font-size:.875rem}.cost-category-bar__legend-value{font-family:var(--font-mono);font-size:.8125rem;font-weight:700;color:var(--text-primary)}.cost-category-bar__legend-percent{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--text-secondary);background:#0000000a;padding:.125rem .375rem;border-radius:3px}@media(max-width:640px){.cost-category-bar{padding:1rem}.cost-category-bar__item-header{flex-direction:column;align-items:flex-start;gap:.25rem}.cost-category-bar__item-values{width:100%;justify-content:space-between}.cost-category-bar__total{flex-direction:column;align-items:flex-start;gap:.5rem}.cost-category-bar__legend{grid-template-columns:1fr}}@keyframes bar-fill{0%{width:0}}.cost-category-bar__progress-fill,.cost-category-bar__stacked-segment{animation:bar-fill .8s cubic-bezier(.4,0,.2,1) forwards}@media(prefers-reduced-motion:reduce){.cost-category-bar__progress-fill,.cost-category-bar__stacked-segment{transition-duration:.01ms!important;animation-duration:.01ms!important}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);position:relative;overflow:hidden;padding:2rem}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(212,175,55,.05) 0%,transparent 50%);animation:rotate 30s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-container{position:relative;z-index:1;width:100%;max-width:480px}.login-card{background:linear-gradient(135deg,#1a2332f2,#0f172af2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(212,175,55,.2);border-radius:16px;padding:3rem 2.5rem;box-shadow:0 20px 60px #00000080,0 0 40px #d4af371a}.login-header{text-align:center;margin-bottom:2.5rem}.login-logo{width:80px;height:80px;-o-object-fit:contain;object-fit:contain;margin-bottom:1.5rem;filter:drop-shadow(0 0 20px rgba(212,175,55,.3))}.login-title{font-family:var(--font-display);font-size:2.5rem;font-weight:800;color:var(--oilserv-gold);letter-spacing:.1em;margin:0 0 .5rem;text-shadow:0 0 20px rgba(212,175,55,.4)}.login-subtitle{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:#d4af37b3;letter-spacing:.15em;text-transform:uppercase;margin:0}.login-form{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-family:var(--font-mono);font-size:.6875rem;font-weight:700;color:#d4af37cc;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.5rem}.form-input{width:100%;padding:.875rem 1rem;background:#0f172a99;border:1px solid rgba(212,175,55,.2);border-radius:8px;font-family:var(--font-body);font-size:.9375rem;color:#fff;transition:all .2s ease}.form-input::-moz-placeholder{color:#94a3b880}.form-input::placeholder{color:#94a3b880}.form-input:focus{outline:none;border-color:var(--oilserv-gold);background:#0f172acc;box-shadow:0 0 0 3px #d4af371a}.form-input:disabled{opacity:.6;cursor:not-allowed}.login-error{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:8px;color:#fca5a5;font-size:.875rem;margin-bottom:1.5rem}.error-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#dc262633;border-radius:50%;font-weight:700;font-size:.75rem;flex-shrink:0}.login-button{width:100%;padding:1rem;background:linear-gradient(135deg,var(--oilserv-gold) 0%,rgba(212,175,55,.9) 100%);border:none;border-radius:8px;font-family:var(--font-display);font-size:.9375rem;font-weight:700;color:#0f172a;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #d4af374d;display:flex;align-items:center;justify-content:center;gap:.75rem}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #d4af3766}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:16px;height:16px;border:2px solid #0f172a;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.access-note{padding:1.25rem 1.5rem;background:#d4af370d;border:1px solid rgba(212,175,55,.15);border-radius:12px;margin-bottom:2rem;text-align:center}.access-note-text{font-family:var(--font-body);font-size:.875rem;color:#f8fafcb3;line-height:1.6}.access-email{color:var(--oilserv-gold);text-decoration:none;font-weight:600;transition:all .2s ease;border-bottom:1px solid rgba(212,175,55,.3)}.access-email:hover{color:#d4af37;border-bottom-color:var(--oilserv-gold)}.login-footer{text-align:center;padding-top:1.5rem;border-top:1px solid rgba(212,175,55,.1)}.login-footer p{font-family:var(--font-mono);font-size:.6875rem;color:#94a3b899;margin:.25rem 0;letter-spacing:.05em}@media(max-width:640px){.login-page{padding:1rem}.login-card{padding:2rem 1.5rem}.login-logo{width:60px;height:60px}.login-title{font-size:2rem}}@media(prefers-reduced-motion:reduce){.login-page:before,.login-spinner{animation:none}.login-button{transition:none}}.portfolio-table-page{min-height:100vh;padding:2rem 1.5rem;max-width:1800px;margin:0 auto;background:#fafafa}.portfolio-header{padding:2rem;border-radius:16px;margin-bottom:1.5rem;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid rgba(212,175,55,.2);box-shadow:0 8px 32px #0000000f;position:relative;overflow:hidden}.portfolio-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#d4af37,#e5c04a,#d4af37)}.header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:1rem}.header-title-section{display:flex;align-items:center;gap:1.5rem}.header-logo{height:56px;width:auto;-o-object-fit:contain;object-fit:contain}.page-title{margin:0;font-family:var(--font-display, "Inter", sans-serif);font-size:clamp(1.5rem,4vw,2.25rem);font-weight:800;color:#b8941f;letter-spacing:-.02em;line-height:1.2}.page-subtitle{margin:.25rem 0 0;font-size:.9375rem;color:#64748b;font-weight:500}.header-actions{display:flex;align-items:center;gap:.75rem}.view-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#d4af371a;border:1px solid rgba(212,175,55,.3);border-radius:8px;color:#b8941f;font-size:.8125rem;font-weight:600;text-decoration:none;transition:all .2s ease}.view-toggle-btn:hover{background:#d4af3733;border-color:#d4af3780}.refresh-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#fffc;border:1px solid rgba(212,175,55,.2);border-radius:8px;color:#64748b;cursor:pointer;transition:all .2s ease}.refresh-btn:hover{background:#d4af371a;color:#b8941f;border-color:#d4af374d}.refresh-btn--loading{pointer-events:none;opacity:.7}.refresh-btn .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.view-indicator{display:flex;gap:.5rem}.view-indicator__item{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;color:#64748b;text-decoration:none;transition:all .15s ease}.view-indicator__item:hover{background:#d4af371a;color:#b8941f}.view-indicator__item--active{background:#d4af3726;color:#b8941f}.error-banner{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#dc26260d;border:1px solid rgba(220,38,38,.2);border-radius:10px;margin-bottom:1.5rem}.error-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#dc2626;color:#fff;border-radius:50%;font-weight:700;font-size:.875rem}.error-message{flex:1;color:#991b1b;font-size:.875rem}.error-retry-btn{padding:.5rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:6px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .2s ease}.error-retry-btn:hover{background:#b91c1c}.kpi-section{margin-bottom:1.5rem}.data-source-bar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;background:#fffffff2;border-radius:10px;border:1px solid rgba(212,175,55,.1);margin-bottom:1.5rem}.data-source-indicator{display:flex;align-items:center;gap:.625rem}.pulse-dot{width:8px;height:8px;background:#059669;border-radius:50%;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 #05966980}50%{box-shadow:0 0 8px 4px #05966900}}.live-label{font-size:.6875rem;font-weight:700;color:#059669;text-transform:uppercase;letter-spacing:.1em}.source-info{font-size:.75rem;color:#64748b}.last-updated{font-size:.75rem;color:#94a3b8}.table-section{margin-bottom:2rem}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-title{margin:0;font-size:1.125rem;font-weight:700;color:#1a1a1a}.project-count{font-size:.8125rem;color:#64748b}.legend-section{padding:1.25rem 1.5rem;background:#fffffff2;border-radius:12px;border:1px solid rgba(212,175,55,.1)}.legend-title{margin:0 0 .75rem;font-size:.8125rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.legend-items{display:flex;gap:2rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#374151}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot--red{background:#dc2626}.legend-dot--amber{background:#f59e0b}.legend-dot--green{background:#059669}@media(max-width:1024px){.portfolio-table-page{padding:1.5rem 1rem}.portfolio-header{padding:1.5rem}.header-content{flex-direction:column;gap:1.25rem}.header-actions{width:100%;justify-content:flex-start}}@media(max-width:768px){.portfolio-table-page{padding:1rem .75rem}.portfolio-header{padding:1.25rem;border-radius:12px}.header-title-section{flex-direction:column;align-items:flex-start;gap:1rem}.header-logo{height:44px}.page-title{font-size:1.375rem}.page-subtitle{font-size:.8125rem}.data-source-bar,.table-header{flex-direction:column;align-items:flex-start;gap:.5rem}.legend-items{flex-direction:column;gap:.75rem}}@media print{.portfolio-table-page{padding:0;background:#fff}.portfolio-header,.error-banner,.data-source-bar{display:none}.kpi-section{page-break-after:avoid}.table-section{page-break-inside:avoid}}.portfolio-overview{min-height:100vh;padding:2rem 1.5rem;max-width:1800px;margin:0 auto;position:relative;z-index:var(--z-base)}.command-title{margin:0 0 .75rem;font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;color:var(--oilserv-gold-dark);text-shadow:0 2px 4px rgba(212,175,55,.25),0 1px 2px rgba(212,175,55,.15),0 4px 8px rgba(212,175,55,.1);background:linear-gradient(180deg,var(--oilserv-gold-dark) 0%,#A67C1A 100%);-webkit-background-clip:text;background-clip:text}.command-select{padding:.75rem 3rem .75rem 1rem;font-size:.875rem;font-family:var(--font-body);font-weight:500;background:#ffffffb3;border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-mechanical);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23B8941F' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;box-shadow:inset 0 1px 2px #0000000a}.results-badge{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#ffffffb3;border-radius:8px;border-left:4px solid var(--oilserv-gold);box-shadow:0 2px 6px #0000000a,inset 0 1px #ffffff80,-2px 0 8px #d4af3714}.badge-value{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--oilserv-gold-dark);line-height:1;text-shadow:0 1px 2px rgba(212,175,55,.2),0 .5px 1px rgba(212,175,55,.15);background:linear-gradient(180deg,var(--oilserv-gold-dark) 0%,#A67C1A 100%);-webkit-background-clip:text;background-clip:text;letter-spacing:-.02em}.badge-label{font-family:var(--font-mono);font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.portfolio-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-bottom:3rem}.project-command-card{display:flex;flex-direction:column;gap:1.5rem;padding:2rem;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:2px solid rgba(212,175,55,.2);border-radius:16px;box-shadow:var(--shadow-lg),inset 0 1px #fffc,inset 0 -1px #d4af3714;transition:all var(--duration-normal) var(--ease-mechanical);position:relative;overflow:hidden}.project-command-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--oilserv-gold) 0%,var(--oilserv-gold-light) 50%,var(--oilserv-gold) 100%);opacity:.8;transition:opacity var(--duration-fast)}.project-command-card:hover:before{opacity:1}.project-header-section{display:flex;flex-direction:column;gap:.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.project-title-main{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2;letter-spacing:-.02em;text-shadow:0 1px 2px rgba(0,0,0,.06)}.project-code-badge{font-family:var(--font-mono);font-size:.875rem;font-weight:600;color:var(--tech-cyan);margin:0;text-transform:uppercase;letter-spacing:.06em;text-shadow:0 .5px 1px rgba(14,165,233,.2)}.kpi-metrics-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}.kpi-metrics-grid>*{min-height:160px;max-height:160px;display:flex;flex-direction:column}.kpi-metrics-grid .kpi-card{height:100%;display:flex;flex-direction:column}.kpi-metrics-grid .kpi-card__content{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-height:0}.empty-command{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:3rem 2rem;border-radius:16px;text-align:center;box-shadow:var(--shadow-md)}.empty-icon-large{font-size:4rem;color:var(--natural-gas-amber);margin-bottom:1.5rem;opacity:.6}@media(min-width:768px){.kpi-metrics-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.kpi-metrics-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1440px){.portfolio-overview{padding:3rem 2rem}.kpi-metrics-grid{gap:1.5rem}}@media(max-width:640px){.portfolio-overview{padding:1.5rem 1rem}.command-header{padding:2rem 1.5rem;margin-bottom:1.5rem}.command-title{font-size:1.75rem}.command-subtitle{font-size:.875rem}.control-panel{padding:1.25rem;gap:1rem}.control-grid{grid-template-columns:1fr}.results-badge{padding:.875rem 1.25rem}.badge-value{font-size:1.5rem}.badge-label{font-size:.75rem}.project-command-card{padding:1.5rem;gap:1.25rem}.project-title-main{font-size:1.5rem}.project-code-badge{font-size:.8125rem}.kpi-metrics-grid{grid-template-columns:1fr;gap:1rem}.empty-command{padding:2rem 1.5rem;min-height:300px}.empty-icon-large{font-size:3rem;margin-bottom:1rem}.empty-title{font-size:1.5rem}.empty-message{font-size:.9375rem}}@media print{.portfolio-overview{background:#fff;padding:0}.command-header,.control-panel{display:none}.project-command-card{page-break-inside:avoid;background:#fff;border:1px solid #ccc;box-shadow:none}.project-command-card:before{display:none}}@keyframes pulse-health{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}@keyframes pulse-health-critical{0%,to{transform:scale(1);opacity:1;box-shadow:0 0 #7f1d1db3}50%{transform:scale(1.08);opacity:.95;box-shadow:0 0 40px 20px #7f1d1d00}}.project-card-tooltip{position:relative}.project-card-tooltip:after{content:attr(data-tooltip);position:absolute;bottom:-60px;left:50%;transform:translate(-50%) translateY(10px);padding:.75rem 1rem;background:#000000f2;color:#fff;font-size:.75rem;line-height:1.5;white-space:pre-line;border-radius:8px;box-shadow:0 4px 16px #0000004d;opacity:0;pointer-events:none;transition:all .2s ease;z-index:1000;min-width:200px;text-align:center}.project-card-tooltip:hover:after{opacity:1;transform:translate(-50%) translateY(0)}@media(prefers-reduced-motion:reduce){.command-search,.command-select,.command-button,.project-command-card,.loading-spinner{transition-duration:.01ms!important;animation-duration:.01ms!important}.command-button:hover{transform:none}}.dashboard-page{min-height:100vh;padding:2rem 1.5rem;max-width:1800px;margin:0 auto;position:relative;z-index:var(--z-base)}.command-header{padding:3rem 2rem;border-radius:16px;margin-bottom:2rem;position:relative;overflow:hidden;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:2px solid rgba(212,175,55,.2);box-shadow:var(--shadow-lg),inset 0 1px #fffc,inset 0 -1px #d4af3714}.command-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--oilserv-gold) 0%,var(--oilserv-gold-light) 50%,var(--oilserv-gold) 100%);opacity:.9}.header-content{position:relative;z-index:1}.header-logo-title{display:flex;align-items:center;gap:1.5rem;margin-bottom:.5rem}.header-logo{height:60px;width:auto;-o-object-fit:contain;object-fit:contain}.command-title{margin:0;font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;color:var(--oilserv-gold-dark);text-shadow:0 2px 4px rgba(212,175,55,.25),0 1px 2px rgba(212,175,55,.15),0 4px 8px rgba(212,175,55,.1);background:linear-gradient(180deg,var(--oilserv-gold-dark) 0%,#A67C1A 100%);-webkit-background-clip:text;background-clip:text}.command-subtitle{margin:0;font-size:1rem;color:var(--text-primary);opacity:.75;font-weight:500;letter-spacing:.025em;text-shadow:0 .5px 1px rgba(0,0,0,.06)}.dashboard-content{display:flex;flex-direction:column;gap:2rem}.dashboard-section{display:flex;flex-direction:column;gap:1.5rem;padding:2rem;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:2px solid rgba(212,175,55,.2);border-radius:16px;box-shadow:var(--shadow-lg),inset 0 1px #fffc,inset 0 -1px #d4af3714;transition:all var(--duration-normal) var(--ease-mechanical);position:relative;overflow:hidden}.dashboard-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--oilserv-gold) 0%,var(--oilserv-gold-light) 50%,var(--oilserv-gold) 100%);opacity:.8;transition:opacity var(--duration-fast)}.dashboard-section:hover:before{opacity:1}.section-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.section-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2;letter-spacing:-.02em;text-shadow:0 1px 2px rgba(0,0,0,.06)}.section-badge{font-family:var(--font-mono);font-size:.875rem;font-weight:600;color:var(--tech-cyan);text-transform:uppercase;letter-spacing:.06em;text-shadow:0 .5px 1px rgba(14,165,233,.2)}.kpi-grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.25rem}.kpi-grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.kpi-grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}.control-panel{padding:1.5rem;border-radius:12px;margin-bottom:2rem;display:flex;flex-direction:column;gap:1.25rem;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:2px solid rgba(212,175,55,.15);box-shadow:var(--shadow-md),inset 0 1px #fffc,inset 0 -1px #d4af370f}.search-container{position:relative;width:100%}.command-search{width:100%;padding:.875rem 1.25rem;font-size:.9375rem;font-family:var(--font-body);background:#ffffffb3;border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);transition:all var(--duration-fast) var(--ease-mechanical);box-shadow:inset 0 1px 2px #0000000a}.command-search::-moz-placeholder{color:var(--text-tertiary)}.command-search::placeholder{color:var(--text-tertiary)}.command-search:hover{border-color:var(--border-highlight)}.command-search:focus{outline:none;border-color:var(--oilserv-gold);box-shadow:0 0 0 3px #d4af3726,0 0 0 1px #d4af374d,inset 0 1px 2px #00000005;background:#fffffff2}.control-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--oilserv-gold-dark);text-transform:uppercase;letter-spacing:.08em;text-shadow:0 .5px 1px rgba(212,175,55,.15)}.command-select{padding:.75rem 3rem .75rem 1rem;font-size:.875rem;font-family:var(--font-body);font-weight:500;background:#ffffffb3;border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-mechanical);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23B8941F' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;box-shadow:inset 0 1px 2px #0000000a}.command-select:hover{border-color:var(--border-highlight);background-color:#ffffffe6}.command-select:focus{outline:none;border-color:var(--oilserv-gold);box-shadow:0 0 0 3px #d4af3726,0 0 0 1px #d4af374d,inset 0 1px 2px #00000005}.command-button{padding:.875rem 2rem;font-family:var(--font-body);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--tech-cyan);color:var(--petroleum-deep);border:none;border-radius:8px;cursor:pointer;transition:all var(--duration-fast) var(--ease-mechanical);box-shadow:0 4px 12px #0ea5e94d}.command-button:hover{background:var(--natural-gas-amber);box-shadow:0 6px 16px #ff950066;transform:translateY(-2px)}.command-button:active{transform:translateY(0)}.command-button:focus-visible{outline:2px solid var(--tech-cyan);outline-offset:4px}.command-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1.5rem;padding:3rem;border-radius:16px;box-shadow:var(--shadow-md)}.loading-spinner{width:64px;height:64px;border:4px solid var(--border-color);border-top-color:var(--oilserv-gold);border-radius:50%;animation:spinner-rotate .8s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.loading-text{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em;margin:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:3rem 2rem;border-radius:16px;text-align:center;box-shadow:var(--shadow-md)}.empty-icon{font-size:4rem;color:var(--natural-gas-amber);margin-bottom:1.5rem;opacity:.6}.empty-title{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem}.empty-message{font-size:1rem;color:var(--text-secondary);margin:0 0 2rem;max-width:500px;line-height:1.6}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .875rem;border-radius:6px;font-family:var(--font-mono);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.status-badge-good{background:#0596691a;color:var(--pipeline-green);border:1px solid rgba(5,150,105,.2)}.status-badge-warning{background:#ff95001a;color:var(--natural-gas-amber);border:1px solid rgba(255,149,0,.2)}.status-badge-critical{background:#dc26261a;color:var(--emergency-red);border:1px solid rgba(220,38,38,.2)}.status-badge-info{background:#0ea5e91a;color:var(--tech-cyan);border:1px solid rgba(14,165,233,.2)}@media(min-width:768px){.kpi-grid,.kpi-grid-2,.kpi-grid-3,.kpi-grid-4{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.kpi-grid,.kpi-grid-3{grid-template-columns:repeat(3,1fr)}.kpi-grid-4{grid-template-columns:repeat(4,1fr)}}@media(min-width:1440px){.dashboard-page{padding:3rem 2rem}.kpi-grid,.kpi-grid-2,.kpi-grid-3,.kpi-grid-4{gap:1.5rem}}@media(max-width:640px){.dashboard-page{padding:1.5rem 1rem}.command-header{padding:2rem 1.5rem;margin-bottom:1.5rem}.header-logo{height:48px}.command-title{font-size:1.75rem}.command-subtitle{font-size:.875rem}.dashboard-section{padding:1.5rem;gap:1.25rem}.section-title{font-size:1.25rem}.kpi-grid,.kpi-grid-2,.kpi-grid-3,.kpi-grid-4{grid-template-columns:1fr;gap:1rem}.control-grid{grid-template-columns:1fr}}.command-search:focus-visible,.command-select:focus-visible,.command-button:focus-visible{outline:2px solid var(--tech-cyan);outline-offset:4px}@media print{.dashboard-page{background:#fff;padding:0}.command-header,.control-panel{display:none}.dashboard-section{page-break-inside:avoid;background:#fff;border:1px solid #ccc;box-shadow:none}.dashboard-section:before{display:none}}@media(prefers-reduced-motion:reduce){.command-search,.command-select,.command-button,.dashboard-section,.loading-spinner{transition-duration:.01ms!important;animation-duration:.01ms!important}.command-button:hover{transform:none}}.project-dashboard{padding:2rem;min-height:100vh;max-width:1600px;margin:0 auto;position:relative}.project-dashboard.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.loading-spinner{width:64px;height:64px;border:4px solid var(--steel-700);border-top-color:var(--tech-cyan);border-radius:50%;animation:spin .8s linear infinite}.project-dashboard.loading p{font-family:var(--font-display);font-size:.875rem;font-weight:600;color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase}.dashboard-header{margin-bottom:2.5rem;position:relative}.header-content{display:flex;flex-direction:column;gap:1rem}.header-badge{display:inline-flex;align-items:center;gap:.625rem;padding:.5rem 1rem;background:#0ea5e91a;border:1px solid rgba(14,165,233,.3);border-radius:6px;width:-moz-fit-content;width:fit-content;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.badge-dot{width:8px;height:8px;background:var(--tech-cyan);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.badge-text{font-family:var(--font-mono);font-size:.75rem;font-weight:700;color:var(--tech-cyan);letter-spacing:.1em;text-transform:uppercase}.dashboard-title{margin:0;font-family:var(--font-display);font-size:2.5rem;font-weight:900;line-height:1.2;letter-spacing:-.02em;color:var(--text-primary);background:linear-gradient(135deg,var(--text-primary) 0%,rgba(14,165,233,.8) 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.dashboard-subtitle{margin:0;font-family:var(--font-body);font-size:1rem;font-weight:400;color:var(--text-tertiary);letter-spacing:.01em;max-width:600px}.command-center-grid{margin-bottom:3rem}.kpi-command-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.budget-analytics{margin-bottom:3rem}.analytics-card{position:relative;padding:2rem;background:#1a233299;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(148,163,184,.1);border-radius:12px;overflow:hidden;transition:all var(--duration-normal) var(--ease-mechanical)}.analytics-card:before{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,transparent 0%,rgba(14,165,233,.1) 50%,transparent 100%);border-radius:14px;z-index:-1;opacity:0;transition:opacity var(--duration-normal) var(--ease-mechanical)}.analytics-card:hover:before{opacity:1}.analytics-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem;padding-bottom:1rem;border-bottom:1px solid rgba(148,163,184,.1)}.analytics-title{margin:0;font-family:var(--font-display);font-size:1.25rem;font-weight:700;letter-spacing:-.01em;color:var(--text-primary)}.analytics-badge{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:#0ea5e914;border:1px solid rgba(14,165,233,.2);border-radius:8px}.badge-label{font-family:var(--font-mono);font-size:.6875rem;font-weight:600;color:var(--text-tertiary);letter-spacing:.05em;text-transform:uppercase}.badge-value{font-family:var(--font-display);font-size:1rem;font-weight:800;color:var(--text-primary)}.badge-value.positive{color:var(--pipeline-green)}.badge-value.negative{color:var(--emergency-red)}.analytics-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:0;align-items:center}.metric-item{display:flex;flex-direction:column;gap:.5rem;padding:0 1.5rem}.metric-divider{width:1px;height:60px;background:linear-gradient(to bottom,transparent 0%,rgba(148,163,184,.2) 50%,transparent 100%)}.metric-label{font-family:var(--font-body);font-size:.8125rem;font-weight:500;color:var(--text-tertiary);letter-spacing:.01em}.metric-value{font-family:var(--font-display);font-size:1.5rem;font-weight:800;line-height:1;letter-spacing:-.02em;color:var(--text-primary)}.metric-value.success{color:var(--pipeline-green)}.metric-value.warning{color:var(--natural-gas-amber)}.metric-unit{font-family:var(--font-mono);font-size:.6875rem;font-weight:600;color:var(--text-tertiary);letter-spacing:.05em;text-transform:uppercase}.timeline-section{margin-top:3rem}.timeline-card{position:relative;padding:2rem;background:#1a233299;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(148,163,184,.1);border-radius:12px;overflow:hidden}.timeline-title{margin:0 0 1.75rem;font-family:var(--font-display);font-size:1.25rem;font-weight:700;letter-spacing:-.01em;color:var(--text-primary);padding-bottom:1rem;border-bottom:1px solid rgba(148,163,184,.1)}.timeline-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:center}.timeline-item{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#0ea5e90d;border:1px solid rgba(14,165,233,.15);border-radius:8px;transition:all var(--duration-fast) var(--ease-mechanical)}.timeline-item:hover{background:#0ea5e914;border-color:#0ea5e940;transform:translateY(-2px)}.timeline-icon{flex-shrink:0;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:8px;color:var(--tech-cyan);font-size:1rem;font-weight:700;box-shadow:var(--shadow-sm)}.timeline-content{display:flex;flex-direction:column;gap:.375rem;flex:1}.timeline-label{font-family:var(--font-mono);font-size:.6875rem;font-weight:600;color:var(--text-tertiary);letter-spacing:.05em;text-transform:uppercase}.timeline-value{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.timeline-divider{width:1px;height:80px;background:linear-gradient(to bottom,transparent 0%,rgba(14,165,233,.3) 50%,transparent 100%)}@media(max-width:1024px){.project-dashboard{padding:1.5rem}.dashboard-title{font-size:2rem}.kpi-command-grid{grid-template-columns:repeat(2,1fr)}.analytics-grid{grid-template-columns:1fr;gap:1.5rem}.metric-divider{display:none}.metric-item{padding:0}.timeline-grid{grid-template-columns:1fr;gap:1rem}.timeline-divider{display:none}}@media(max-width:640px){.project-dashboard{padding:1rem}.dashboard-header{margin-bottom:2rem}.dashboard-title{font-size:1.75rem}.dashboard-subtitle{font-size:.875rem}.kpi-command-grid{grid-template-columns:1fr;gap:1rem}.command-center-grid,.budget-analytics,.timeline-section{margin-bottom:2rem}.analytics-card,.timeline-card{padding:1.25rem}.analytics-header{flex-direction:column;align-items:flex-start;gap:1rem}.analytics-title,.timeline-title{font-size:1.125rem}.metric-value{font-size:1.25rem}.timeline-item{padding:1rem}.timeline-icon{width:2rem;height:2rem;font-size:.875rem}}@media(prefers-reduced-motion:reduce){.loading-spinner,.analytics-card,.timeline-item{animation:none!important;transition:none!important}.badge-dot{animation:none}.analytics-card:hover,.timeline-item:hover{transform:none}}@media print{.project-dashboard{background:#fff;padding:1rem}.analytics-card,.timeline-card{background:#fff;border:1px solid #ccc}.dashboard-title,.analytics-title,.timeline-title,.metric-value,.timeline-value{-webkit-text-fill-color:black;color:#000}.header-badge,.analytics-badge{border:1px solid #ccc}}:root{--font-display: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace;--status-excellent: #10B981;--status-good: #3B82F6;--status-warning: #F59E0B;--status-critical: #EF4444;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748B;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a}.s-curve-chart{background:#fff;border-radius:20px;overflow:visible;box-shadow:0 1px 3px #0000000a,0 20px 60px #00000014}.scurve-status-banner{padding:2rem 2.5rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.scurve-status-banner--under-budget{background:linear-gradient(135deg,#10b981,#059669)}.scurve-status-banner--on-budget{background:linear-gradient(135deg,#3b82f6,#2563eb)}.scurve-status-banner--over-budget{background:linear-gradient(135deg,#f59e0b,#d97706)}.scurve-status-banner--critical{background:linear-gradient(135deg,#ef4444,#dc2626);animation:criticalPulse 2s ease-in-out infinite}.scurve-status-main{display:flex;align-items:center;gap:1rem}.scurve-status-icon{font-size:2.5rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.scurve-status-label{font-family:var(--font-display);font-size:1.75rem;font-weight:800;color:#fff;letter-spacing:.03em;text-shadow:0 2px 4px rgba(0,0,0,.15)}.scurve-status-metrics{display:flex;align-items:center;gap:1.5rem}.scurve-metric-block{display:flex;flex-direction:column;align-items:center;gap:.25rem}.scurve-metric-value{font-family:var(--font-mono);font-size:2rem;font-weight:700;color:#fff;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.15)}.scurve-metric-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;color:#ffffffd9;letter-spacing:.1em;text-transform:uppercase}.scurve-variance-block{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem 1.5rem;background:#fff3;border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.25);position:relative}.scurve-variance-value{font-family:var(--font-mono);font-size:2.25rem;font-weight:800;color:#fff;line-height:1;text-shadow:0 2px 8px rgba(0,0,0,.2)}.scurve-variance-label{font-family:var(--font-display);font-size:.75rem;font-weight:700;color:#ffffffe6;letter-spacing:.15em;text-transform:uppercase}.scurve-metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;padding:2rem 2.5rem;background:var(--slate-50);border-bottom:1px solid var(--slate-200)}.scurve-metric-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#fff;border-radius:14px;border:1px solid var(--slate-200);transition:all .25s ease}.scurve-metric-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014;border-color:var(--slate-300)}.scurve-metric-card--pv .metric-icon{color:#3b82f6;background:#3b82f61a}.scurve-metric-card--ev .metric-icon{color:#10b981;background:#10b9811a}.scurve-metric-card--ac .metric-icon{color:#ef4444;background:#ef44441a}.metric-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--slate-100);flex-shrink:0}.metric-content{display:flex;flex-direction:column;gap:.25rem}.metric-amount{font-family:var(--font-mono);font-size:1.625rem;font-weight:700;color:var(--slate-900);line-height:1.1}.metric-name{font-family:var(--font-display);font-size:.9375rem;font-weight:500;color:var(--slate-500)}.scurve-chart-body{padding:2rem 2.5rem;background:#fff;display:block;width:100%}.scurve-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.scurve-chart-title{font-family:var(--font-display);font-size:1.375rem;font-weight:700;color:var(--slate-900);margin:0;display:flex;align-items:center;gap:.75rem}.scurve-chart-legend{display:flex;gap:2rem}.scurve-legend-item{display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-size:1rem;font-weight:500;color:var(--slate-600)}.scurve-legend-line{width:32px;height:4px;border-radius:2px}.scurve-legend-line--pv{background:#3b82f6}.scurve-legend-line--ev{background:#10b981}.scurve-legend-line--ac{background:#ef4444}.scurve-chart-wrapper{background:var(--slate-50);border-radius:16px;padding:1.5rem 1rem 1rem .5rem;border:1px solid var(--slate-200);width:100%;height:420px;min-height:420px;display:block;position:relative}.s-curve-legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-top:2rem;padding:1.5rem 2rem;background:var(--slate-50);border-top:2px solid var(--slate-200);border-radius:0 0 20px 20px}.legend-item{display:flex;align-items:center;gap:.875rem;font-family:var(--font-display);font-size:1rem;font-weight:500;color:var(--slate-700)}.legend-color{width:28px;height:5px;border-radius:3px;flex-shrink:0}.legend-text{line-height:1.4}.performance-indices-chart{background:#fff;border-radius:20px;overflow:visible;box-shadow:0 1px 3px #0000000a,0 20px 60px #00000014}.perf-status-banner{padding:2rem 2.5rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.perf-status-banner--excellent{background:linear-gradient(135deg,#10b981,#059669)}.perf-status-banner--good{background:linear-gradient(135deg,#3b82f6,#2563eb)}.perf-status-banner--warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.perf-status-banner--critical{background:linear-gradient(135deg,#ef4444,#dc2626);animation:criticalPulse 2s ease-in-out infinite}.perf-status-main{display:flex;align-items:center;gap:1rem}.perf-status-icon{font-size:2.5rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.perf-status-label{font-family:var(--font-display);font-size:1.75rem;font-weight:800;color:#fff;letter-spacing:.03em;text-shadow:0 2px 4px rgba(0,0,0,.15)}.perf-status-metrics{display:flex;align-items:center;gap:1.5rem}.perf-index-block{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:1rem 1.5rem;background:#fff3;border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.25)}.perf-index-value{font-family:var(--font-mono);font-size:2.25rem;font-weight:800;color:#fff;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.15)}.perf-index-label{font-family:var(--font-display);font-size:.8125rem;font-weight:700;color:#ffffffe6;letter-spacing:.1em;text-transform:uppercase}.perf-insight-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;padding:2rem 2.5rem;background:var(--slate-50);border-bottom:1px solid var(--slate-200)}.perf-insight-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem 1.75rem;background:#fff;border-radius:16px;border:2px solid var(--slate-200);transition:all .25s ease}.perf-insight-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.perf-insight-card--cpi{border-left-color:#f59e0b;border-left-width:4px}.perf-insight-card--spi{border-left-color:#8b5cf6;border-left-width:4px}.perf-insight-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.perf-insight-card--cpi .perf-insight-icon{color:#f59e0b;background:#f59e0b1a}.perf-insight-card--spi .perf-insight-icon{color:#8b5cf6;background:#8b5cf61a}.perf-insight-content{display:flex;flex-direction:column;gap:.25rem}.perf-insight-value{font-family:var(--font-mono);font-size:2rem;font-weight:800;color:var(--slate-900);line-height:1}.perf-insight-name{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--slate-600);margin-bottom:.25rem}.perf-insight-desc{font-family:var(--font-display);font-size:.875rem;font-weight:500;color:var(--slate-500)}.perf-chart-body{padding:2rem 2.5rem;background:#fff;display:block;width:100%}.perf-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.perf-chart-title{font-family:var(--font-display);font-size:1.375rem;font-weight:700;color:var(--slate-900);margin:0;display:flex;align-items:center;gap:.75rem}.perf-chart-legend{display:flex;gap:2rem}.perf-legend-item{display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-size:1rem;font-weight:500;color:var(--slate-600)}.perf-legend-dot{width:14px;height:14px;border-radius:4px}.perf-legend-dot--cpi{background:#f59e0b}.perf-legend-dot--spi{background:#8b5cf6}.perf-legend-dot--baseline{background:var(--slate-400)}.perf-chart-wrapper{background:var(--slate-50);border-radius:16px;padding:1.5rem 1rem 1rem .5rem;border:1px solid var(--slate-200);width:100%;height:420px;min-height:420px;display:block;position:relative}.performance-indices-legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-top:2rem;padding:1.5rem 2rem;background:var(--slate-50);border-top:2px solid var(--slate-200)}.performance-indices-legend .legend-item{display:flex;align-items:flex-start;gap:.875rem;font-family:var(--font-display);font-size:1rem;font-weight:500;color:var(--slate-700)}.performance-indices-legend .legend-item.baseline{grid-column:1 / -1;padding-top:1rem;margin-top:.5rem;border-top:1px solid var(--slate-200)}.performance-interpretation{margin-top:2rem;padding:1.5rem 2rem;background:linear-gradient(135deg,#3b82f60f,#3b82f605);border-left:4px solid #3B82F6;border-radius:0 12px 12px 0}.performance-interpretation p{margin:0 0 1rem;font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--slate-800)}.performance-interpretation p:last-of-type{margin-bottom:0}.performance-interpretation ul{margin:1rem 0 0;padding-left:1.5rem;list-style:none}.performance-interpretation li{position:relative;margin-bottom:.625rem;padding-left:.5rem;font-family:var(--font-display);font-size:.9375rem;color:var(--slate-700);line-height:1.5}.performance-interpretation li:before{content:"";position:absolute;left:-1rem;top:.625rem;width:6px;height:6px;border-radius:50%;background:#3b82f6}.performance-interpretation li:last-child{margin-bottom:0}.tooltip{background:var(--slate-900);border-radius:12px;padding:1rem 1.25rem;min-width:180px;box-shadow:0 12px 40px #0000004d;z-index:1000}.tooltip-label{font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:#fff;margin:0 0 .75rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.15)}.tooltip p{margin:.5rem 0;font-family:var(--font-mono);font-size:.9375rem;font-weight:500}@media(max-width:1200px){.scurve-metrics-grid{grid-template-columns:repeat(3,1fr)}.perf-insight-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.scurve-status-banner,.perf-status-banner{flex-direction:column;text-align:center;padding:1.75rem 1.5rem}.scurve-status-main,.perf-status-main{flex-direction:column;gap:.5rem}.scurve-status-label,.perf-status-label{font-size:1.5rem}.scurve-status-metrics,.perf-status-metrics{flex-wrap:wrap;justify-content:center}.scurve-metric-value,.perf-index-value{font-size:1.75rem}.scurve-variance-value{font-size:1.875rem}.scurve-metrics-grid{grid-template-columns:repeat(2,1fr);padding:1.5rem}.perf-insight-grid{grid-template-columns:1fr;padding:1.5rem}.scurve-chart-body,.perf-chart-body{padding:1.5rem}}@media(max-width:600px){.scurve-metrics-grid{grid-template-columns:1fr;gap:1rem}.scurve-metric-card,.perf-insight-card{padding:1.25rem}.metric-amount{font-size:1.375rem}.perf-insight-value{font-size:1.625rem}.scurve-chart-header,.perf-chart-header{flex-direction:column;align-items:flex-start}.scurve-chart-legend,.perf-chart-legend{flex-direction:column;gap:.75rem}.s-curve-legend,.performance-indices-legend{grid-template-columns:1fr}.performance-indices-legend .legend-item.baseline{grid-column:1}}.variance-analysis-table{padding:0}.variance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:40px}@media(max-width:1200px){.variance-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.variance-grid{grid-template-columns:1fr}}.variance-section{border:2px solid #e5e7eb;border-radius:16px;overflow:hidden;background:#fff;transition:all .3s ease}.variance-section:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000001f}.variance-title{margin:0;padding:16px 24px;background:#f8fafc;font-size:18px;font-weight:700;color:#1e293b;border-bottom:2px solid #e2e8f0;letter-spacing:.5px;display:flex;align-items:center;gap:8px}.variance-title svg{stroke:#3b82f6;flex-shrink:0}.variance-content{padding:0}.variance-box{padding:24px;border-radius:0;border-left:6px solid #d1d5db;background:#fff}.variance-box.status-good{border-left-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.variance-box.status-warning{border-left-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.variance-box.status-critical{border-left-color:#ef4444;background:linear-gradient(135deg,#fef2f2,#fee2e2)}.variance-gauge{display:flex;flex-direction:column;align-items:center;margin-bottom:20px}.variance-metric{display:flex;flex-direction:column;align-items:center;margin-bottom:16px;text-align:center}.variance-label{font-weight:600;color:#64748b;font-size:14px;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.variance-value{font-size:2.5rem;font-weight:800;color:#1e293b;font-family:JetBrains Mono,SF Mono,monospace;line-height:1}.variance-percent{font-size:2rem;font-weight:700;margin-top:8px}.variance-box.status-good .variance-value,.variance-box.status-good .variance-percent{color:#059669}.variance-box.status-warning .variance-value,.variance-box.status-warning .variance-percent{color:#d97706}.variance-box.status-critical .variance-value,.variance-box.status-critical .variance-percent{color:#dc2626}.variance-progress-container{width:100%;margin:20px 0}.variance-progress-bar{height:12px;background:#0000001a;border-radius:6px;overflow:hidden;position:relative}.variance-progress-fill{height:100%;border-radius:6px;transition:width .5s ease}.status-good .variance-progress-fill{background:linear-gradient(90deg,#10b981,#34d399)}.status-warning .variance-progress-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.status-critical .variance-progress-fill{background:linear-gradient(90deg,#ef4444,#f87171)}.variance-progress-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:13px;color:#64748b}.variance-interpretation{margin-top:16px;padding-top:16px;border-top:2px solid rgba(0,0,0,.06)}.variance-interpretation p{margin:0;font-size:15px;color:#475569;line-height:1.6;font-weight:500}.variance-table-container{margin-bottom:40px;border:2px solid #e2e8f0;border-radius:16px;overflow:hidden;box-shadow:0 4px 16px #0000000a}.variance-table{width:100%;border-collapse:collapse;background:#fff}.variance-table thead{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:3px solid #e2e8f0}.variance-table th{padding:20px 24px;text-align:left;font-weight:700;font-size:16px;color:#1e293b;text-transform:uppercase;letter-spacing:.5px}.variance-table td{padding:20px 24px;border-bottom:1px solid #e2e8f0;font-size:16px;color:#334155;font-weight:500;line-height:1.5}.variance-table tbody tr{transition:background .2s ease}.variance-table tbody tr:hover{background:#f8fafc}.variance-table tbody tr:last-child td{border-bottom:none}.variance-table td.status-good{background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#059669;font-weight:700;font-size:18px}.variance-table td.status-warning{background:linear-gradient(135deg,#fffbeb,#fef3c7);color:#d97706;font-weight:700;font-size:18px}.variance-table td.status-critical{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;font-weight:700;font-size:18px}.variance-table td.code{font-family:JetBrains Mono,SF Mono,monospace;font-weight:700;color:#0f172a;font-size:17px;background:#f8fafc}.variance-table td.formula{font-family:JetBrains Mono,SF Mono,monospace;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#2563eb;font-weight:700;font-size:16px}.variance-summary{padding:28px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;border-left:6px solid #3b82f6;box-shadow:0 4px 16px #0000000a}.variance-summary h3{margin:0 0 20px;font-size:20px;font-weight:700;color:#1e293b;letter-spacing:.5px}.variance-notes{margin:0;padding-left:24px;list-style:none}.variance-notes li{position:relative;margin-bottom:16px;color:#475569;font-size:16px;line-height:1.6;padding-left:12px}.variance-notes li:before{content:"";position:absolute;left:-20px;top:10px;width:8px;height:8px;border-radius:50%;background:#3b82f6}.variance-notes li:last-child{margin-bottom:0}.variance-notes strong{color:#1e293b;font-weight:700}@media(max-width:768px){.variance-table th,.variance-table td{padding:16px;font-size:14px}.variance-table td.status-good,.variance-table td.status-warning,.variance-table td.status-critical{font-size:15px}.variance-value{font-size:2rem}.variance-percent{font-size:1.5rem}}.evm-metrics-section{margin-bottom:2rem}.evm-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.evm-status-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.25rem;margin-top:2rem}.evm-status-card{position:relative;padding:1.25rem;background:linear-gradient(135deg,#fffffffa,#f8f8f8f2);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(0,0,0,.08);border-left:4px solid var(--oilserv-gold-dark);border-radius:10px;box-shadow:0 2px 8px #0000000a,0 1px 3px #0000000f;transition:all var(--duration-normal) var(--ease-mechanical)}.evm-status-card:before{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,transparent 0%,rgba(212,175,55,.08) 50%,transparent 100%);border-radius:12px;z-index:-1;opacity:0;transition:opacity var(--duration-normal) var(--ease-mechanical)}.evm-status-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014,0 2px 6px #0000001a;border-color:#0000001f}.evm-status-card:hover:before{opacity:1}.evm-status-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--oilserv-black);opacity:.6;margin-bottom:.75rem}.evm-status-value{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--oilserv-black);margin-bottom:.5rem;line-height:1.5}.evm-status-value--good{color:var(--pipeline-green)}.evm-status-value--warning{color:var(--natural-gas-amber)}.evm-status-value--critical{color:var(--emergency-red)}.evm-status-metric{font-size:.875rem;color:var(--oilserv-black);opacity:.7;display:flex;align-items:center;gap:.5rem}.evm-status-mono{font-family:var(--font-mono);font-weight:600;font-size:.9375rem;letter-spacing:.02em}.evm-status-variance--good{color:var(--pipeline-green)}.evm-status-variance--warning{color:var(--natural-gas-amber)}.evm-status-variance--critical{color:var(--emergency-red)}.evm-status-card--good{border-left:4px solid var(--pipeline-green);box-shadow:0 2px 8px #05966914,0 1px 3px #0000000f}.evm-status-card--good:before{background:linear-gradient(135deg,transparent 0%,rgba(5,150,105,.06) 50%,transparent 100%)}.evm-status-card--warning{border-left:4px solid var(--crude-oil);box-shadow:0 2px 8px #d9770614,0 1px 3px #0000000f}.evm-status-card--warning:before{background:linear-gradient(135deg,transparent 0%,rgba(217,119,6,.06) 50%,transparent 100%)}.evm-status-card--critical{border-left:4px solid var(--emergency-red);box-shadow:0 2px 8px #dc26261f,0 1px 3px #0000000f}.evm-status-card--critical:before{background:linear-gradient(135deg,transparent 0%,rgba(220,38,38,.06) 50%,transparent 100%)}.evm-metrics-section:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(14,165,233,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(14,165,233,.03) 1px,transparent 1px);background-size:20px 20px;pointer-events:none;z-index:-1;opacity:.5}@media(max-width:1024px){.evm-metrics-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}}@media(max-width:768px){.evm-metrics-grid,.evm-status-summary{grid-template-columns:1fr;gap:1rem}.evm-status-card{padding:1rem}.evm-status-value{font-size:.9375rem}}@media(prefers-reduced-motion:reduce){.evm-status-card,.evm-status-card:before{transition-duration:.01ms!important}.evm-status-card:hover{transform:none}}@media print{.evm-status-card{background:#fff;border:1px solid #ccc;box-shadow:none;page-break-inside:avoid}.evm-status-card:before{display:none}.evm-metrics-section:before{display:none}}.formula-reference{padding:0}.formula-section{margin-bottom:16px;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:all .2s ease}.formula-section.expanded{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.section-header{padding:16px;background:#f3f4f6;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all .2s ease}.formula-section.expanded .section-header{background:#eff6ff;border-bottom-color:#3b82f6}.section-header:hover{background:#ececf1}.section-header h3{margin:0;font-size:16px;font-weight:600;color:#1f2937}.toggle-icon{font-size:20px;color:#6b7280;font-weight:300}.formula-section.expanded .toggle-icon{color:#3b82f6}.section-content{padding:20px;background:#fff;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.formula-list{display:flex;flex-direction:column;gap:16px}.formula-item{margin:0}.formula-box{padding:16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;border-left:4px solid #d1d5db;transition:all .2s ease}.formula-box:hover{background:#f3f4f6;border-color:#d1d5db}.formula-box.formula-highlight{background:#eff6ff;border-color:#3b82f6;border-left-color:#3b82f6}.formula-box.formula-highlight:hover{background:#dbeafe}.formula-name{font-size:16px;font-weight:700;color:#1f2937;margin-bottom:8px}.formula-box.formula-highlight .formula-name{color:#1e40af}.formula-expression{font-family:Courier New,monospace;font-size:16px;font-weight:600;color:#3b82f6;padding:12px;background:#fff;border-radius:4px;margin:12px 0;text-align:center;border:1px solid #e5e7eb}.formula-description{font-size:14px;color:#374151;margin-bottom:8px;line-height:1.5}.formula-example{font-size:13px;color:#6b7280;margin-bottom:8px;padding:8px 12px;background:#fff;border-left:3px solid #f59e0b;border-radius:4px;font-style:italic}.formula-interpretation{font-size:13px;color:#374151;margin-bottom:8px;padding:8px 12px;background:#fff;border-left:3px solid #10b981;border-radius:4px;line-height:1.6}.formula-note{font-size:12px;color:#6b7280;padding:8px 12px;background:#f9fafb;border-radius:4px;font-style:italic;margin-top:8px}.color-coding-guide{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.color-item{display:flex;gap:12px;align-items:flex-start}.color-swatch{width:40px;height:40px;border-radius:4px;flex-shrink:0;border:2px solid #e5e7eb}.color-swatch.green{background:#dcfce7;border-color:#10b981}.color-swatch.amber{background:#fef3c7;border-color:#f59e0b}.color-swatch.red{background:#fee2e2;border-color:#ef4444}.color-info{flex:1}.color-label{font-weight:600;color:#1f2937;font-size:14px;margin-bottom:4px}.color-values{font-size:12px;color:#6b7280;line-height:1.5;font-family:Courier New,monospace}.how-to-read-content{padding:0}.how-to-read-content ol{margin:0;padding-left:20px}.how-to-read-content li{margin-bottom:12px;color:#374151;line-height:1.6;font-size:14px}.how-to-read-content li:last-child{margin-bottom:0}.how-to-read-content strong{color:#1f2937;font-weight:600}.formula-disclaimer{margin-top:20px;padding:16px;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:6px;font-size:13px;color:#78350f;line-height:1.5}.formula-disclaimer p{margin:0}@media(max-width:768px){.section-content{padding:16px}.formula-box{padding:12px}.formula-expression{font-size:14px;padding:10px}.color-coding-guide{grid-template-columns:1fr}.section-header h3{font-size:14px}}.evm-performance{padding:2rem;min-height:100vh;max-width:1600px;margin:0 auto;position:relative}.evm-performance:before{content:"";position:fixed;inset:0;background-image:linear-gradient(rgba(14,165,233,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(14,165,233,.02) 1px,transparent 1px);background-size:24px 24px;pointer-events:none;z-index:-1}.evm-performance.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1.5rem}.loading-spinner{width:60px;height:60px;border:4px solid rgba(148,163,184,.2);border-top-color:var(--tech-cyan);border-radius:50%;animation:spin .8s linear infinite}.evm-performance.error{display:flex;flex-direction:column;gap:1.5rem}.error-container{background:#1a233299;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(220,38,38,.3);border-radius:12px;padding:2.5rem;box-shadow:var(--shadow-xl);text-align:center}.error-container h1{color:var(--emergency-red);margin-top:0;font-family:var(--font-display);font-size:1.75rem;font-weight:800}.error-container p{color:var(--text-secondary);font-size:1rem;line-height:1.6}.error-container button{margin-top:1.5rem;padding:.75rem 1.5rem;background:var(--tech-cyan);color:#fff;border:none;border-radius:8px;cursor:pointer;font-family:var(--font-display);font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;transition:all var(--duration-fast) var(--ease-mechanical);box-shadow:var(--shadow-md)}.error-container button:hover{background:#0284c7;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.evm-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(148,163,184,.15)}.evm-header__title{margin:0 0 .5rem;font-family:var(--font-display);font-size:2.25rem;font-weight:900;letter-spacing:-.02em;color:var(--text-primary);background:linear-gradient(135deg,var(--text-primary) 0%,rgba(248,250,252,.8) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.evm-header__subtitle{margin:0;font-family:var(--font-mono);font-size:.875rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.evm-section{margin-bottom:2rem;padding:2rem;border-radius:12px;transition:all var(--duration-normal) var(--ease-mechanical)}.evm-section--glass{position:relative;background:#1a233299;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(148,163,184,.1);box-shadow:var(--shadow-lg)}.evm-section--glass:before{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,rgba(14,165,233,.1) 0%,transparent 50%,rgba(5,150,105,.1) 100%);border-radius:14px;z-index:-1;opacity:0;transition:opacity var(--duration-normal) var(--ease-mechanical)}.evm-section--glass:hover:before{opacity:1}.section-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(148,163,184,.1)}.section-header__icon{flex-shrink:0;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:#0ea5e91a;border-radius:10px;font-size:1.5rem;box-shadow:var(--shadow-sm)}.section-header__content{flex:1}.section-header__title{margin:0 0 .5rem;font-family:var(--font-display);font-size:1.5rem;font-weight:800;letter-spacing:-.01em;color:var(--text-primary)}.section-header__description{margin:0;font-size:.875rem;line-height:1.6;color:var(--text-tertiary)}.chart-container{padding:1.5rem;border-radius:10px;transition:all var(--duration-normal) var(--ease-mechanical)}.chart-container--glass{background:#0f172a66;border:1px solid rgba(148,163,184,.08);box-shadow:var(--shadow-sm)}.chart-container--glass:hover{background:#0f172a80;border-color:#94a3b826}@media(max-width:1024px){.evm-performance{padding:1.5rem}.evm-header__title{font-size:1.875rem}.section-header__title{font-size:1.25rem}}@media(max-width:768px){.evm-performance{padding:1rem}.evm-header{margin-bottom:2rem}.evm-header__title{font-size:1.625rem}.evm-header__subtitle{font-size:.75rem}.evm-section{padding:1.5rem;margin-bottom:1.5rem}.section-header{flex-direction:column;gap:.75rem}.section-header__icon{width:2.5rem;height:2.5rem;font-size:1.25rem}.section-header__title{font-size:1.125rem}.chart-container{padding:1rem}}@media(max-width:480px){.evm-performance{padding:.75rem}.evm-header__title{font-size:1.375rem}.evm-section{padding:1rem}.section-header__title{font-size:1rem}}@media(prefers-reduced-motion:reduce){.evm-section,.evm-section--glass:before,.chart-container,.error-container button{transition-duration:.01ms!important}.evm-section--glass:hover:before,.error-container button:hover{transform:none}.loading-spinner{animation:none!important;border-top-color:var(--tech-cyan);opacity:.7}}@media print{.evm-performance:before{display:none}.evm-section--glass{background:#fff;border:1px solid #ccc;box-shadow:none;page-break-inside:avoid}.evm-section--glass:before{display:none}.chart-container--glass{background:#fff;border:1px solid #ccc}.section-header__icon{filter:grayscale(100%)}.evm-header__title{-webkit-text-fill-color:black;color:#000}}.error-container button:focus-visible{outline:2px solid var(--tech-cyan);outline-offset:4px}.variance-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.variance-summary-card{padding:1.5rem;background:linear-gradient(135deg,#fffffffa,#f8f8f8f2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(0,0,0,.08);border-left:4px solid var(--oilserv-gold-dark);border-radius:10px;box-shadow:0 2px 8px #0000000a,0 1px 3px #0000000f;transition:all var(--duration-normal) var(--ease-mechanical)}.variance-summary-card--good{border-left-color:var(--pipeline-green)}.variance-summary-card--warning{border-left-color:var(--crude-oil)}.variance-summary-card--critical{border-left-color:var(--emergency-red)}.variance-summary-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--oilserv-black);opacity:.6;margin-bottom:.75rem}.variance-summary-value{font-family:var(--font-display);font-size:2rem;font-weight:900;color:var(--oilserv-black);line-height:1;margin-bottom:.5rem}.variance-summary-percent{font-family:var(--font-mono);font-size:.875rem;font-weight:600;color:var(--oilserv-black);opacity:.7}.cost-comparison-table{background:linear-gradient(135deg,#f8f8f8f2,#f2f2f2fa);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000a;overflow-x:auto}.variance-table{width:100%;border-collapse:separate;border-spacing:0}.variance-table__header{font-family:var(--font-display);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--oilserv-black);opacity:.7;text-align:left;padding:1rem;border-bottom:2px solid rgba(0,0,0,.1)}.variance-table__header--number{text-align:right}.variance-table__header--status{text-align:center}.variance-table__row{transition:background-color var(--duration-fast) var(--ease-mechanical)}.variance-table__row:hover{background-color:#d4af370d}.variance-table__row--total{border-top:2px solid rgba(0,0,0,.1)}.variance-table__row--total:hover{background-color:#d4af371a}.variance-table__cell{padding:1rem;font-size:.9375rem;color:var(--oilserv-black);border-bottom:1px solid rgba(0,0,0,.05)}.variance-table__cell--category{font-weight:600;display:flex;align-items:center;gap:.75rem}.variance-table__cell--number{font-family:var(--font-mono);text-align:right;font-weight:600}.variance-table__cell--status{text-align:center}.category-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.category-indicator--good{background-color:var(--pipeline-green);box-shadow:0 0 6px #05966966}.category-indicator--warning{background-color:var(--crude-oil);box-shadow:0 0 6px #d9770666}.category-indicator--critical{background-color:var(--emergency-red);box-shadow:0 0 6px #dc262666}.variance-table__cell--good{color:var(--pipeline-green)}.variance-table__cell--warning{color:var(--crude-oil)}.variance-table__cell--critical{color:var(--emergency-red)}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.status-badge--good{background-color:#05966926;color:var(--pipeline-green);border:1px solid rgba(5,150,105,.3)}.status-badge--warning{background-color:#d9770626;color:var(--crude-oil);border:1px solid rgba(217,119,6,.3)}.status-badge--critical{background-color:#dc262626;color:var(--emergency-red);border:1px solid rgba(220,38,38,.3)}@media(max-width:768px){.variance-summary-cards{grid-template-columns:1fr}.cost-comparison-table{padding:1rem}.variance-table__header,.variance-table__cell{padding:.75rem .5rem;font-size:.8125rem}.variance-summary-value{font-size:1.5rem}}@media print{.variance-summary-card,.cost-comparison-table{background:#fff;border:1px solid #ccc;box-shadow:none}.variance-table__row:hover{background-color:transparent}}.engineering-progress{max-width:1600px;margin:0 auto;padding:2rem;background-color:var(--petroleum-deep);min-height:100vh;position:relative}.engineering-progress:before{content:"";position:fixed;inset:0;background-image:linear-gradient(rgba(14,165,233,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(14,165,233,.03) 1px,transparent 1px);background-size:24px 24px;pointer-events:none;z-index:0}.engineering-progress.loading,.engineering-progress.error{display:flex;align-items:center;justify-content:center;min-height:400px;flex-direction:column;gap:1.5rem;position:relative;z-index:1}.loading-spinner{width:60px;height:60px;border:4px solid rgba(148,163,184,.2);border-top-color:var(--tech-cyan);border-right-color:var(--pipeline-green);border-radius:50%;animation:spin 1s cubic-bezier(.4,0,.2,1) infinite;box-shadow:0 0 20px #0ea5e94d}.engineering-progress.loading p{font-family:var(--font-mono);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;font-size:.875rem}.error-message{background:#1a2332cc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-left:4px solid var(--emergency-red);padding:2rem;border-radius:12px;text-align:center;max-width:500px;border:1px solid var(--border-color);box-shadow:var(--shadow-lg)}.error-message h3{margin:0 0 .75rem;font-family:var(--font-display);color:var(--text-primary);font-size:1.25rem;font-weight:700;text-transform:uppercase}.error-message p{margin:0 0 1.5rem;color:var(--text-tertiary);font-size:.875rem;font-family:var(--font-mono)}.error-message button{background:linear-gradient(135deg,var(--emergency-red),rgba(220,38,38,.8));color:var(--text-primary);border:none;padding:.625rem 1.5rem;border-radius:8px;cursor:pointer;font-family:var(--font-display);font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;transition:all var(--duration-normal) var(--ease-mechanical);box-shadow:var(--shadow-md)}.error-message button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color);position:relative;z-index:1}.page-header h1{margin:0;font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.page-header p{margin:.5rem 0 0;font-size:.875rem;color:var(--text-tertiary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}.btn-primary,.btn-secondary{padding:.625rem 1.25rem;border-radius:8px;border:none;font-size:.875rem;font-weight:600;font-family:var(--font-display);cursor:pointer;transition:all var(--duration-normal) var(--ease-mechanical);text-transform:uppercase;letter-spacing:.05em}.btn-primary{background:linear-gradient(135deg,var(--tech-cyan),var(--pipeline-green));color:var(--text-primary);box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-card);border-color:var(--border-highlight)}.kpi-section{margin-bottom:2rem;position:relative;z-index:1}.section-title{margin:0 0 1.25rem;font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.75rem}.section-title:before{content:"";width:4px;height:1.5rem;background:linear-gradient(180deg,var(--tech-cyan),var(--pipeline-green));border-radius:2px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.status-breakdown-section{margin-bottom:2rem;position:relative;z-index:1}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.breakdown-card{position:relative;background:linear-gradient(135deg,#fffffffa,#f8f8f8f2);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem;border:1px solid rgba(0,0,0,.08);text-align:center;transition:all var(--duration-normal) var(--ease-mechanical);overflow:hidden;box-shadow:0 2px 8px #0000000a}.breakdown-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--tech-cyan);opacity:.6}.breakdown-card--ifc:before{background:var(--pipeline-green)}.breakdown-card--ifa:before{background:var(--natural-gas-amber)}.breakdown-card--ifr:before{background:var(--tech-cyan)}.breakdown-card--idc:before,.breakdown-card--dev:before{background:var(--steel-400)}.breakdown-card:hover{transform:translateY(-4px);border-color:#0000001f;box-shadow:0 8px 24px #0000001f}.breakdown-icon{font-size:2rem;margin-bottom:.75rem}.breakdown-label{font-family:var(--font-display);font-size:.875rem;font-weight:700;color:var(--oilserv-black);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.25rem}.breakdown-description{font-size:.75rem;color:#0009;margin-bottom:1rem;font-family:var(--font-mono)}.breakdown-value{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--oilserv-black);margin-bottom:.5rem;letter-spacing:-.02em}.breakdown-percent{font-family:var(--font-mono);font-size:1rem;font-weight:600;color:#000000b3;margin-bottom:.75rem}.breakdown-progress{width:100%;height:6px;background:#94a3b81a;border-radius:3px;overflow:hidden}.breakdown-progress-bar{height:100%;transition:width var(--duration-slow) var(--ease-mechanical);background:var(--tech-cyan)}.breakdown-progress-bar--green{background:linear-gradient(90deg,var(--pipeline-green),rgba(5,150,105,.6))}.breakdown-progress-bar--amber{background:linear-gradient(90deg,var(--natural-gas-amber),rgba(255,149,0,.6))}.breakdown-progress-bar--cyan{background:linear-gradient(90deg,var(--tech-cyan),rgba(14,165,233,.6))}.breakdown-progress-bar--steel{background:linear-gradient(90deg,var(--steel-400),rgba(148,163,184,.6))}.charts-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem;position:relative;z-index:1}.chart-container{background:#1a233299;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);box-shadow:var(--shadow-md);transition:all var(--duration-normal) var(--ease-mechanical)}.chart-container:hover{border-color:var(--border-highlight);box-shadow:var(--shadow-lg)}.chart-container h3{margin:0 0 1.25rem;font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.document-register-section{background:#1a233299;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);box-shadow:var(--shadow-md);position:relative;z-index:1}.filter-bar{display:flex;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.filter-group select,.filter-group input{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;font-family:var(--font-mono);background:var(--bg-elevated);color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-mechanical)}.filter-group select:hover,.filter-group input:hover{border-color:var(--border-highlight);background:var(--bg-card)}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--tech-cyan);box-shadow:0 0 0 3px #0ea5e933}.filter-group.search{margin-left:auto}.filter-group input{min-width:200px}.table-container{overflow-x:auto;margin-bottom:1.25rem;border:1px solid rgba(0,0,0,.08);border-radius:8px;background:linear-gradient(135deg,#fffffffa,#fcfcfcf2);box-shadow:0 2px 8px #0000000a}.document-table{width:100%;border-collapse:collapse;font-size:.875rem}.document-table thead{background:linear-gradient(135deg,#f5f5f5fa,#f0f0f0f2);border-bottom:2px solid rgba(0,0,0,.08)}.document-table th{padding:.75rem 1rem;text-align:left;font-family:var(--font-display);font-weight:700;color:var(--oilserv-black);white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.document-table tbody tr{border-bottom:1px solid rgba(0,0,0,.05);transition:all var(--duration-fast) var(--ease-mechanical)}.document-table tbody tr:hover{background-color:#d4af3714;border-color:#d4af3733}.document-table td{padding:.75rem 1rem;color:#000000bf;font-family:var(--font-mono);font-size:.8125rem}.doc-id a{color:#0284c7;text-decoration:none;font-weight:600;transition:color var(--duration-fast)}.doc-id a:hover{color:#0369a1;text-decoration:underline}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-family:var(--font-mono);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border:1px solid;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.status-ifc{background:#0596691f;color:#047857;border-color:#0596694d}.status-ifa{background:#f59e0b1f;color:#d97706;border-color:#f59e0b4d}.status-ifr{background:#0ea5e91f;color:#0284c7;border-color:#0ea5e94d}.status-idc,.status-dev{background:#64748b1f;color:#475569;border-color:#64748b4d}.progress-bar{display:inline-block;width:100px;height:8px;background:#00000014;border-radius:4px;overflow:hidden;margin-right:.5rem;vertical-align:middle;border:1px solid rgba(0,0,0,.08)}.progress-fill{height:100%;background:linear-gradient(90deg,#059669,#0284c7);transition:width var(--duration-slow) var(--ease-mechanical);box-shadow:0 0 4px #0596694d}.no-data{text-align:center;padding:2.5rem 1rem!important;color:#00000080;font-style:italic;font-family:var(--font-mono)}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border-color)}.page-info{font-family:var(--font-mono);font-size:.8125rem;color:#0009;font-weight:600}.pagination-controls{display:flex;gap:.5rem}.btn-pagination{padding:.375rem .75rem;border:1px solid rgba(0,0,0,.12);background:#ffffffe6;border-radius:6px;cursor:pointer;font-family:var(--font-mono);font-size:.8125rem;font-weight:600;color:#000000b3;transition:all var(--duration-fast) var(--ease-mechanical)}.btn-pagination:hover:not(:disabled){border-color:#d4af3766;color:var(--oilserv-black);background:#d4af3714;transform:translateY(-1px)}.btn-pagination.active{background:linear-gradient(135deg,var(--oilserv-gold),var(--oilserv-gold-dark));color:#fff;border-color:transparent;box-shadow:0 2px 4px #0000001a}.btn-pagination:disabled{opacity:.4;cursor:not-allowed}@media(max-width:1200px){.charts-section{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media(max-width:768px){.engineering-progress{padding:16px}.page-header{flex-direction:column;gap:16px}.page-header h1{font-size:24px}.header-actions{width:100%}.header-actions button{flex:1}.filter-bar{flex-direction:column;gap:12px}.filter-group.search{margin-left:0}.filter-group input{width:100%}.breakdown-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.charts-section,.kpi-grid{grid-template-columns:1fr}.pagination{flex-direction:column;gap:16px;align-items:flex-start}.pagination-controls{width:100%;justify-content:space-between}.table-container{font-size:12px}.document-table th,.document-table td{padding:8px}}@media(max-width:480px){.page-header h1{font-size:1.25rem}.breakdown-grid{grid-template-columns:1fr}.breakdown-card{padding:1rem}.breakdown-value{font-size:1.5rem}}@keyframes shimmer{0%{background-position:200% center}to{background-position:-200% center}}@media(prefers-reduced-motion:reduce){.engineering-progress *,.engineering-progress *:before,.engineering-progress *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media print{.engineering-progress:before{display:none}.header-actions,.filter-bar,.pagination{display:none}.chart-container,.breakdown-card,.document-register-section{background:#fff;border:1px solid #ccc}.section-title,.page-header h1,.breakdown-value,.document-table th{color:#000}.document-table td{color:#333}}.procurement-progress{padding:2rem;min-height:100vh;max-width:1600px;margin:0 auto;position:relative;z-index:1}.procurement-progress.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1.5rem}.loading-spinner{width:60px;height:60px;border:4px solid var(--steel-700);border-top-color:var(--tech-cyan);border-radius:50%;animation:spin .8s linear infinite}.procurement-progress.error{padding:2rem}.error-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:3rem;text-align:center;box-shadow:var(--shadow-lg)}.error-container h1{margin:0 0 1rem;color:var(--text-primary)}.error-container p{margin:0 0 2rem;color:var(--text-secondary)}.error-container button{padding:.75rem 1.5rem;background:var(--tech-cyan);color:#fff;border:none;border-radius:8px;font-family:var(--font-display);font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-mechanical);box-shadow:var(--shadow-md)}.error-container button:hover{background:#0284c7;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.procurement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.procurement-header h1{margin:0;color:var(--text-primary);font-family:var(--font-display);font-weight:800;letter-spacing:-.02em}.header-actions{display:flex;gap:.75rem}.btn-refresh,.btn-export{padding:.625rem 1.25rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:8px;font-family:var(--font-display);font-size:.875rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-mechanical);box-shadow:var(--shadow-sm)}.btn-refresh:hover,.btn-export:hover{background:var(--steel-700);border-color:var(--border-highlight);transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-section{margin-bottom:2.5rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.section-title{margin:0 0 1rem;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.section-description{margin:0 0 1.5rem;font-size:.9375rem;color:var(--text-tertiary);line-height:1.6}.pipeline-section{margin-bottom:2.5rem;padding:2rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-md)}.pipeline-flow{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;position:relative}.pipeline-stage-card{position:relative;display:flex;align-items:center;gap:.75rem}.pipeline-stage-content{flex:1;padding:1.25rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:10px;transition:all var(--duration-normal) var(--ease-mechanical);box-shadow:var(--shadow-sm)}.pipeline-stage-content:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-highlight)}.stage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.875rem}.stage-name{margin:0;font-family:var(--font-display);font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.stage-indicator{width:12px;height:12px;border-radius:50%;box-shadow:0 0 8px currentColor}.stage-metrics{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.75rem}.stage-count{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--text-primary);line-height:1}.stage-percentage{font-family:var(--font-mono);font-size:.875rem;font-weight:600;color:var(--text-tertiary)}.stage-progress-bar{width:100%;height:6px;background:var(--steel-800);border-radius:3px;overflow:hidden;position:relative}.stage-progress-fill{height:100%;border-radius:3px;transition:width var(--duration-slow) var(--ease-mechanical);box-shadow:0 0 8px currentColor}.pipeline-connector{display:flex;align-items:center;justify-content:center;color:var(--tech-cyan);font-size:1.5rem;font-weight:700;opacity:.5}.connector-arrow{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:.7}}.charts-section{margin-bottom:2.5rem}.chart-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:2rem;box-shadow:var(--shadow-md);transition:all var(--duration-normal) var(--ease-mechanical)}.chart-card:hover{box-shadow:var(--shadow-lg);border-color:var(--border-highlight)}.chart-card.full-width{width:100%}.chart-card h3{margin:0 0 .5rem;font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--text-primary)}.chart-description{margin:0 0 1.5rem;font-size:.875rem;color:var(--text-tertiary)}.chart-container{width:100%;min-height:350px}.package-register-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:2rem;box-shadow:var(--shadow-md)}.filter-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-family:var(--font-display);font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.filter-input,.filter-select{padding:.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:8px;font-family:var(--font-body);font-size:.875rem;color:var(--text-primary);transition:all var(--duration-fast) var(--ease-mechanical)}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--tech-cyan);box-shadow:0 0 0 3px #0ea5e926}.filter-input::-moz-placeholder{color:var(--text-tertiary)}.filter-input::placeholder{color:var(--text-tertiary)}.table-wrapper{overflow-x:auto;margin-bottom:1.5rem;border-radius:8px;border:1px solid var(--border-color)}.package-table{width:100%;border-collapse:collapse;font-size:.875rem}.package-table thead{background:var(--bg-elevated);border-bottom:2px solid var(--border-highlight)}.package-table th{padding:1rem;text-align:left;font-family:var(--font-display);font-weight:700;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.package-table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-mechanical)}.package-table .table-row:hover{background:var(--bg-elevated)}.package-table .table-row:hover td{color:var(--text-primary)}.mono-text{font-family:var(--font-mono);font-weight:600;color:var(--text-primary)}.vendor-name{color:var(--text-primary);font-weight:500}.discipline-badge{display:inline-block;padding:.25rem .625rem;background:var(--steel-800);border:1px solid var(--steel-700);border-radius:6px;font-family:var(--font-mono);font-size:.75rem;font-weight:700;color:var(--tech-cyan);text-transform:uppercase}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-family:var(--font-mono);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid}.status-awarded{background:#05966926;color:var(--pipeline-green);border-color:#0596694d}.status-transit{background:#0ea5e926;color:var(--tech-cyan);border-color:#0ea5e94d}.status-pending{background:#ff950026;color:var(--natural-gas-amber);border-color:#ff95004d}.status-default{background:#64748b26;color:var(--steel-400);border-color:#64748b4d}.progress-cell{display:flex;align-items:center;gap:.75rem}.progress-bar-mini{flex:1;min-width:80px;height:6px;background:var(--steel-800);border-radius:3px;overflow:hidden;position:relative}.progress-fill-mini{height:100%;border-radius:3px;transition:width var(--duration-slow) var(--ease-mechanical);box-shadow:0 0 6px currentColor}.progress-text-mini{font-family:var(--font-mono);font-size:.75rem;font-weight:700;color:var(--text-primary);min-width:42px;text-align:right}.empty-state{text-align:center;padding:3rem 1rem!important;color:var(--text-tertiary);font-style:italic;font-size:.9375rem}.pagination{display:flex;justify-content:space-between;align-items:center;padding-top:1.5rem;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:1rem}.pagination-info{margin:0;font-family:var(--font-mono);font-size:.8125rem;color:var(--text-tertiary)}.pagination-controls{display:flex;gap:.375rem}.btn-page{padding:.5rem .875rem;border:1px solid var(--border-color);background:var(--bg-elevated);border-radius:6px;font-family:var(--font-mono);font-size:.8125rem;font-weight:700;cursor:pointer;transition:all var(--duration-fast) var(--ease-mechanical);color:var(--text-primary)}.btn-page:hover:not(:disabled){background:var(--steel-700);border-color:var(--border-highlight);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-page.active{background:var(--tech-cyan);color:#fff;border-color:var(--tech-cyan);box-shadow:0 0 12px #0ea5e966}.btn-page:disabled{color:var(--steel-600);cursor:not-allowed;background:var(--steel-900);border-color:var(--steel-800);opacity:.5}@media(max-width:1024px){.procurement-progress{padding:1.5rem}.procurement-header{flex-direction:column;align-items:flex-start}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.pipeline-flow{grid-template-columns:repeat(2,1fr)}.pipeline-connector{display:none}}@media(max-width:768px){.procurement-progress{padding:1rem}.procurement-header{gap:1rem}.header-actions{width:100%;justify-content:flex-start}.kpi-grid,.pipeline-flow,.filter-section{grid-template-columns:1fr}.pagination{flex-direction:column;align-items:flex-start}.package-table{font-size:.8125rem}.package-table th,.package-table td{padding:.75rem}.chart-card,.pipeline-section,.package-register-section{padding:1.5rem}}@media(max-width:480px){.procurement-progress{padding:.75rem}.kpi-grid{gap:.875rem}.filter-section{gap:.75rem}.package-table{font-size:.75rem}.package-table th,.package-table td{padding:.625rem .5rem}.progress-cell{flex-direction:column;align-items:flex-start;gap:.375rem}.progress-bar-mini{width:100%}.pagination{gap:.75rem}.pagination-controls{gap:.25rem;flex-wrap:wrap}.btn-page{padding:.375rem .625rem;font-size:.75rem}.pipeline-section,.package-register-section,.chart-card{padding:1rem}}@media print{.procurement-progress{background:#fff}.btn-refresh,.btn-export,.filter-section,.pagination{display:none}.pipeline-stage-content,.chart-card,.package-register-section{border:1px solid #ccc;box-shadow:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.connector-arrow{animation:none}}.construction-progress{padding:2rem;min-height:100vh;position:relative;z-index:1}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:#1a2332b3;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(148,163,184,.1);border-radius:12px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.page-header:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--tech-cyan) 0%,var(--natural-gas-amber) 50%,var(--pipeline-green) 100%)}.page-header h1{font-family:var(--font-display);font-size:clamp(1.75rem,3vw,2.25rem);font-weight:800;color:var(--text-primary);margin:0 0 .5rem;letter-spacing:-.02em}.page-subtitle{font-size:.875rem;color:var(--text-tertiary);margin:0;text-transform:uppercase;letter-spacing:.05em;font-weight:500}.header-actions{display:flex;gap:12px}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background:#f9fafb}.kpi-section{margin-bottom:2rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));max-width:1400px;gap:1.5rem;animation:fadeInUp var(--duration-normal) var(--ease-entrance) both}.kpi-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border-left:4px solid #d1d5db;transition:all .3s}.kpi-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.kpi-card.status-good{border-left-color:#10b981}.kpi-card.status-warning{border-left-color:#f59e0b}.kpi-card.status-critical{border-left-color:#ef4444}.kpi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.kpi-header h3{font-size:14px;font-weight:600;color:#6b7280;margin:0}.kpi-icon{font-size:24px}.kpi-content{display:flex;flex-direction:column;gap:8px}.kpi-value{display:flex;align-items:baseline;gap:4px}.kpi-value .value{font-size:32px;font-weight:700;color:#111827}.kpi-value .unit{font-size:18px;color:#6b7280}.kpi-subtitle{font-size:12px;color:#9ca3af}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.section-header h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em}.section-subtitle{font-size:.8125rem;color:var(--text-tertiary);margin:.25rem 0 0}.section-header-inline{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header-inline h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.section-badge{padding:.5rem 1rem;background:#0ea5e926;color:var(--tech-cyan);border:1px solid rgba(14,165,233,.3);border-radius:6px;font-family:var(--font-mono);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.chart-section{padding:2rem;margin-bottom:2rem;border-radius:12px;animation:fadeInUp var(--duration-normal) var(--ease-entrance) both;animation-delay:.2s}.chart-section h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem}.gantt-section{padding:2rem;margin-bottom:2rem;border-radius:12px;animation:fadeInUp var(--duration-normal) var(--ease-entrance) both;animation-delay:.3s}.gantt-controls{display:flex;gap:1.5rem;align-items:center}.control-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);cursor:pointer;font-weight:500}.control-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--tech-cyan)}.gantt-legend{display:flex;gap:1.5rem;margin-bottom:1.5rem;padding:1rem;background:#1a233266;border-radius:8px;border:1px solid rgba(148,163,184,.1)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-secondary);font-family:var(--font-body)}.legend-color{width:16px;height:16px;border-radius:3px;border:1px solid rgba(148,163,184,.2)}.view-selector{display:flex;gap:4px;background:#f3f4f6;padding:4px;border-radius:8px}.view-selector button{padding:6px 16px;border:none;background:transparent;border-radius:6px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.view-selector button.active{background:#fff;color:#3b82f6;box-shadow:0 1px 2px #0000000d}.gantt-chart{border:1px solid rgba(148,163,184,.15);border-radius:8px;overflow:hidden;background:#1a23324d}.gantt-header{display:grid;grid-template-columns:350px 1fr;background:#1a233299;border-bottom:2px solid rgba(148,163,184,.2);font-weight:600;font-size:.8125rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.gantt-task-name,.gantt-timeline{padding:1rem}.gantt-task-name{border-right:1px solid rgba(148,163,184,.15)}.gantt-body{max-height:600px;overflow-y:auto}.gantt-row{display:grid;grid-template-columns:350px 1fr;border-bottom:1px solid rgba(148,163,184,.1);transition:all var(--duration-fast) var(--ease-mechanical)}.gantt-row:hover{background:#0ea5e90d}.gantt-row .gantt-task-name{padding:.75rem 1rem;font-size:.8125rem;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem;overflow:hidden;border-right:1px solid rgba(148,163,184,.15)}.task-name-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.critical-badge{padding:.25rem .5rem;border-radius:4px;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--petroleum-deep);white-space:nowrap;font-family:var(--font-mono)}.gantt-bar-container{padding:.75rem 1rem;display:flex;align-items:center;gap:1rem}.gantt-bar{position:relative;height:28px;border-radius:6px;overflow:hidden;transition:all var(--duration-fast) var(--ease-mechanical);cursor:pointer;border:1px solid rgba(0,0,0,.1)}.gantt-bar:hover{transform:scaleY(1.15);filter:brightness(1.1)}.gantt-progress{position:absolute;left:0;top:0;height:100%;opacity:.9;transition:width var(--duration-normal) var(--ease-mechanical)}.gantt-info{font-size:.75rem;color:var(--text-tertiary);white-space:nowrap;font-weight:600}.info-separator{margin:0 .25rem;color:var(--steel-500)}.wbs-section{padding:2rem;margin-bottom:2rem;border-radius:12px;animation:fadeInUp var(--duration-normal) var(--ease-entrance) both;animation-delay:.35s}.btn-clear-filter{padding:8px 16px;background:#fee2e2;color:#dc2626;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-clear-filter:hover{background:#fecaca}.wbs-tree{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.wbs-node{border-bottom:1px solid #e5e7eb}.wbs-node:last-child{border-bottom:none}.wbs-row{display:grid;grid-template-columns:40px 1fr 200px 100px 80px;align-items:center;padding:12px 16px;gap:12px;transition:background .2s}.wbs-row:hover{background:#f9fafb}.expand-btn{background:transparent;border:none;font-size:16px;cursor:pointer;color:#6b7280;padding:4px;transition:color .2s}.expand-btn:hover{color:#3b82f6}.wbs-info{display:flex;flex-direction:column;gap:4px}.wbs-code{font-size:14px;font-weight:600;color:#3b82f6}.wbs-name{font-size:13px;color:#6b7280}.wbs-progress{display:flex;align-items:center;gap:12px}.wbs-progress .progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.wbs-progress .progress-fill{height:100%;background:#10b981;transition:width .3s}.progress-text{font-size:13px;font-weight:600;color:#374151;min-width:45px}.wbs-tasks{font-size:13px;color:#6b7280;text-align:center}.btn-filter{padding:6px 12px;background:#eff6ff;color:#3b82f6;border:1px solid #bfdbfe;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.btn-filter:hover{background:#dbeafe;border-color:#93c5fd}.critical-path-section{padding:2rem;margin-bottom:2rem;border-radius:12px;animation:fadeInUp var(--duration-normal) var(--ease-entrance) both;animation-delay:.4s}.critical-path-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-item{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-radius:8px;transition:all var(--duration-fast) var(--ease-mechanical)}.summary-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.summary-icon{font-size:2rem;flex-shrink:0}.summary-content{display:flex;flex-direction:column;gap:.25rem}.summary-item .label{font-size:.75rem;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.summary-item .value{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1}.table-container{overflow-x:auto;border:1px solid #e5e7eb;border-radius:8px}.critical-path-table{width:100%;border-collapse:collapse}.critical-path-table thead{background:#f9fafb}.critical-path-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.critical-path-table td{padding:12px 16px;font-size:13px;color:#6b7280;border-bottom:1px solid #e5e7eb}.critical-path-table tbody tr:hover{background:#fef2f2}.progress-bar{height:20px;background:#e5e7eb;border-radius:4px;overflow:hidden;position:relative}.progress-fill{height:100%;background:#10b981;transition:width .3s}.progress-fill.critical{background:#ef4444}.float-zero{font-weight:700;color:#dc2626}.milestones-section{padding:2rem;margin-bottom:2rem;border-radius:12px;animation:fadeInUp var(--duration-normal) var(--ease-entrance) both;animation-delay:.5s}.milestones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.milestone-card{padding:1.5rem;border-radius:10px;transition:all var(--duration-fast) var(--ease-mechanical);position:relative;overflow:hidden}.milestone-card:before{content:"";position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle at top right,rgba(255,255,255,.05) 0%,transparent 70%);pointer-events:none}.milestone-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.milestone-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;position:relative;z-index:1}.milestone-icon{font-size:1.75rem;flex-shrink:0}.milestone-id{font-size:.75rem;font-weight:700;color:var(--text-tertiary);flex-shrink:0}.milestone-status-badge{margin-left:auto;padding:.25rem .625rem;border-radius:4px;font-size:.625rem;font-weight:700;letter-spacing:.05em;color:var(--petroleum-deep)}.milestone-content h3{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem;font-family:var(--font-display);position:relative;z-index:1}.milestone-dates{display:flex;flex-direction:column;gap:.625rem;position:relative;z-index:1}.date-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.date-row .label{color:var(--text-tertiary);font-weight:500}.date-row .value{font-weight:600}.date-row.variance{padding-top:.5rem;border-top:1px solid rgba(148,163,184,.15)}.construction-progress.loading,.construction-progress.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:20px}.loading-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{text-align:center;padding:32px;background:#fef2f2;border-radius:12px;border:1px solid #fecaca}.error-message h3{color:#dc2626;margin-bottom:12px}.error-message p{color:#6b7280;margin-bottom:20px}.error-message button{padding:10px 24px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.error-message button:hover{background:#dc2626}.no-data{text-align:center;padding:3rem;color:var(--text-tertiary);font-size:.875rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.no-data-icon{font-size:3rem;opacity:.5}@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.gantt-header,.gantt-row{grid-template-columns:250px 1fr}.wbs-row{grid-template-columns:30px 1fr 150px 80px 60px}}@media(max-width:768px){.construction-progress{padding:16px}.page-header{flex-direction:column;gap:16px}.header-actions{width:100%}.header-actions button{flex:1}.kpi-grid{grid-template-columns:1fr}.gantt-controls{flex-direction:column;align-items:flex-start;gap:12px}.gantt-header,.gantt-row{grid-template-columns:200px 1fr}.wbs-row{grid-template-columns:30px 1fr}.wbs-progress,.wbs-tasks,.btn-filter{display:none}.milestones-grid{grid-template-columns:1fr}.critical-path-summary{flex-direction:column;gap:16px}}.p6-scurve-v2{--font-display: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace;--status-ahead: #10B981;--status-ahead-bg: linear-gradient(135deg, #10B981 0%, #059669 100%);--status-ontrack: #3B82F6;--status-ontrack-bg: linear-gradient(135deg, #3B82F6 0%, #2563EB 100%);--status-behind: #F59E0B;--status-behind-bg: linear-gradient(135deg, #F59E0B 0%, #D97706 100%);--status-critical: #EF4444;--status-critical-bg: linear-gradient(135deg, #EF4444 0%, #DC2626 100%);--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748B;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 1px 3px #0000000a,0 20px 60px #00000014}.status-banner{padding:2rem 2.5rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.status-banner--ahead{background:var(--status-ahead-bg)}.status-banner--on-track{background:var(--status-ontrack-bg)}.status-banner--behind{background:var(--status-behind-bg)}.status-banner--critical{background:var(--status-critical-bg);animation:criticalPulse 2s ease-in-out infinite}@keyframes criticalPulse{0%,to{opacity:1}50%{opacity:.85}}.status-main{display:flex;align-items:center;gap:1rem}.status-icon{font-size:2.5rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.status-label{font-family:var(--font-display);font-size:1.75rem;font-weight:800;color:#fff;letter-spacing:.03em;text-shadow:0 2px 4px rgba(0,0,0,.15)}.status-metrics{display:flex;align-items:center;gap:1.5rem}.metric-block{display:flex;flex-direction:column;align-items:center;gap:.25rem}.metric-value{font-family:var(--font-mono);font-size:2.25rem;font-weight:700;color:#fff;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.15)}.metric-label{font-family:var(--font-display);font-size:.8125rem;font-weight:600;color:#ffffffd9;letter-spacing:.1em}.metric-divider{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:#fff9}.variance-block{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem 1.5rem;background:#fff3;border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.25)}.variance-sign{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;color:#fff;position:absolute;top:.75rem;left:.75rem}.variance-block{position:relative}.variance-value{font-family:var(--font-mono);font-size:2.5rem;font-weight:800;color:#fff;line-height:1;text-shadow:0 2px 8px rgba(0,0,0,.2)}.variance-label{font-family:var(--font-display);font-size:.75rem;font-weight:700;color:#ffffffe6;letter-spacing:.15em}.insight-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;padding:2rem 2.5rem;background:var(--slate-50);border-bottom:1px solid var(--slate-200)}.insight-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#fff;border-radius:14px;border:1px solid var(--slate-200);transition:all .25s ease}.insight-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014;border-color:var(--slate-300)}.insight-card--success .insight-icon{color:var(--status-ahead);background:#10b9811a}.insight-card--pending .insight-icon{color:var(--status-behind);background:#f59e0b1a}.insight-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--slate-100);color:var(--slate-600);flex-shrink:0}.insight-content{display:flex;flex-direction:column;gap:.25rem}.insight-value{font-family:var(--font-mono);font-size:1.75rem;font-weight:700;color:var(--slate-900);line-height:1.1}.insight-label{font-family:var(--font-display);font-size:.9375rem;font-weight:500;color:var(--slate-500)}.chart-container{padding:2rem 2.5rem 2.5rem;background:#fff;position:relative;z-index:1;overflow:visible;margin-bottom:1.5rem}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.chart-title{font-family:var(--font-display);font-size:1.375rem;font-weight:700;color:var(--slate-900);margin:0;display:flex;align-items:center;gap:.75rem}.data-source-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:9999px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 4px #10b9814d}.data-source-badge.loading{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d;animation:pulse 1.5s infinite}.data-source-badge.fallback{background:linear-gradient(135deg,#94a3b8,#64748b);box-shadow:0 2px 4px #64748b4d}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.chart-legend{display:flex;gap:2rem}.legend-item{display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-size:1rem;font-weight:500;color:var(--slate-600)}.legend-line{width:32px;height:4px;border-radius:2px}.legend-line--planned{background:var(--slate-400);background-image:repeating-linear-gradient(90deg,var(--slate-400),var(--slate-400) 8px,transparent 8px,transparent 12px)}.legend-line--actual{background:linear-gradient(90deg,#d4af37,#10b981)}.chart-body{background:var(--slate-50);border-radius:16px;padding:1.5rem 1rem 1.5rem .5rem;border:1px solid var(--slate-200);margin-bottom:0;overflow:visible;width:100%;height:400px}.scurve-tooltip{background:var(--slate-900);border-radius:12px;padding:1rem 1.25rem;min-width:180px;box-shadow:0 12px 40px #0000004d}.tooltip-header{font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:#fff;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.15)}.tooltip-row{display:flex;align-items:center;gap:.625rem;margin-bottom:.5rem}.tooltip-dot{width:10px;height:10px;border-radius:3px}.tooltip-dot--planned{background:var(--slate-400)}.tooltip-dot--actual{background:#d4af37}.tooltip-label{font-family:var(--font-display);font-size:.9375rem;color:#ffffffb3}.tooltip-value{font-family:var(--font-mono);font-size:1rem;font-weight:600;color:#fff;margin-left:auto}.tooltip-variance{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.15);font-family:var(--font-mono);font-size:1rem;font-weight:700;text-align:center}.tooltip-variance[data-positive=true]{color:var(--status-ahead)}.tooltip-variance[data-positive=false]{color:var(--status-critical)}.workpackage-section{padding:2.5rem;margin-top:3rem;background:var(--slate-50);border-top:2px solid var(--slate-200);position:relative;z-index:1;clear:both}.section-title{font-family:var(--font-display);font-size:1.375rem;font-weight:700;color:var(--slate-900);margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem}.section-title svg{color:var(--slate-500)}.workpackage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1.25rem}.wp-card{background:#fff;border-radius:16px;padding:1.5rem 1.75rem;border:2px solid var(--slate-200);transition:all .3s ease;animation:wpSlideIn .5s ease-out backwards}@keyframes wpSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.wp-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px #0000001a}.wp-card--excellent{border-left-color:var(--status-ahead);border-left-width:4px}.wp-card--good{border-left-color:#059669;border-left-width:4px}.wp-card--warning{border-left-color:var(--status-behind);border-left-width:4px}.wp-card--critical{border-left-color:var(--status-critical);border-left-width:4px}.wp-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.wp-title{font-family:var(--font-display);font-size:1.1875rem;font-weight:600;color:var(--slate-900);margin:0;line-height:1.3;text-transform:capitalize}.wp-badge{font-family:var(--font-mono);font-size:1.125rem;font-weight:700;color:#fff;padding:.5rem .875rem;border-radius:8px;flex-shrink:0;box-shadow:0 2px 8px #00000026}.wp-progress{margin-bottom:1rem}.wp-track{height:16px;background:var(--slate-200);border-radius:8px;overflow:hidden}.wp-fill{height:100%;border-radius:8px;transition:width .8s cubic-bezier(.25,.46,.45,.94);animation:wpFill 1s ease-out forwards}@keyframes wpFill{0%{width:0!important}}.wp-footer{display:flex;justify-content:space-between;align-items:center}.wp-stat{display:flex;align-items:baseline;gap:.25rem;font-family:var(--font-mono)}.wp-stat-value{font-size:1.25rem;font-weight:700;color:var(--slate-900)}.wp-stat-sep{font-size:1rem;color:var(--slate-400)}.wp-stat-total{font-size:1rem;font-weight:500;color:var(--slate-500)}.wp-stat-label{font-family:var(--font-display);font-size:.9375rem;color:var(--slate-500);margin-left:.375rem}.wp-code{font-family:var(--font-mono);font-size:.875rem;font-weight:500;color:var(--slate-500);background:var(--slate-100);padding:.375rem .75rem;border-radius:6px}@media(min-width:1400px){.chart-body{height:450px;min-height:450px}}@media(max-width:1200px){.insight-grid{grid-template-columns:repeat(2,1fr)}.chart-body{height:400px;min-height:400px}}@media(max-width:900px){.status-banner{flex-direction:column;text-align:center;padding:1.75rem 1.5rem}.status-main{flex-direction:column;gap:.5rem}.status-label{font-size:1.5rem}.status-metrics{flex-wrap:wrap;justify-content:center}.metric-value{font-size:1.75rem}.variance-value{font-size:2rem}.insight-grid{grid-template-columns:1fr 1fr;padding:1.5rem}.chart-container{padding:1.5rem;margin-bottom:1rem}.chart-body{height:350px;min-height:350px}.workpackage-section{padding:1.5rem;margin-top:1.5rem}.workpackage-grid{grid-template-columns:1fr}}@media(max-width:600px){.insight-grid{grid-template-columns:1fr;gap:1rem}.insight-card{padding:1rem 1.25rem}.insight-value{font-size:1.5rem}.chart-container{padding:1rem}.chart-header{flex-direction:column;align-items:flex-start}.chart-legend{flex-direction:column;gap:.75rem}.chart-body{height:280px;min-height:280px;padding:1rem .5rem}.workpackage-section{margin-top:1rem}.wp-card{padding:1.25rem}.wp-title{font-size:1.0625rem}.wp-badge{font-size:1rem;padding:.375rem .75rem}}.schedule-drilldown{min-height:100vh;padding:2rem 1.5rem;max-width:1800px;margin:0 auto;position:relative}.schedule-drilldown .command-header{padding:3rem 2rem;border-radius:16px;margin-bottom:2rem;position:relative;overflow:hidden;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:2px solid rgba(212,175,55,.2);box-shadow:var(--shadow-lg),inset 0 1px #fffc,inset 0 -1px #d4af3714}.schedule-drilldown .command-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--oilserv-gold) 0%,var(--oilserv-gold-light) 50%,var(--oilserv-gold) 100%);opacity:.9}.schedule-drilldown .header-logo-title{display:flex;align-items:center;gap:1.5rem;margin-bottom:.5rem}.schedule-drilldown .header-logo{height:60px;width:auto;-o-object-fit:contain;object-fit:contain}.schedule-drilldown .command-title{margin:0;font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.03em;color:var(--oilserv-gold-dark);text-shadow:0 2px 4px rgba(212,175,55,.25),0 1px 2px rgba(212,175,55,.15),0 4px 8px rgba(212,175,55,.1);background:linear-gradient(180deg,var(--oilserv-gold-dark) 0%,#A67C1A 100%);-webkit-background-clip:text;background-clip:text}.schedule-drilldown .command-subtitle{margin:0;font-size:1rem;color:var(--text-primary);opacity:.75;font-weight:500;letter-spacing:.025em;text-shadow:0 .5px 1px rgba(0,0,0,.06)}.schedule-drilldown .dashboard-section{background:var(--oilserv-offwhite-glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:2px solid rgba(212,175,55,.2);border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:var(--shadow-lg),inset 0 1px #fffc,inset 0 -1px #d4af3714}.schedule-drilldown .section-header{margin-bottom:1.5rem}.schedule-drilldown .section-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--oilserv-gold-dark);margin:0 0 .5rem;letter-spacing:-.02em}.schedule-drilldown .kpi-command-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.schedule-drilldown .wbs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.schedule-drilldown .wbs-card{padding:1.5rem;background:#ffffffb3;border:2px solid rgba(212,175,55,.2);border-radius:12px;position:relative;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000000f}.schedule-drilldown .wbs-card:hover{background:#ffffffe6;border-color:var(--oilserv-gold);transform:translateY(-4px);box-shadow:0 8px 24px #d4af3733}.schedule-drilldown .wbs-card--selected{background:#d4af3726!important;border-color:var(--oilserv-gold-dark)!important;box-shadow:0 0 20px #d4af3766!important}.schedule-drilldown .wbs-level-badge{position:absolute;top:.75rem;right:.75rem;padding:.25rem .75rem;font-family:var(--font-mono);font-size:.75rem;font-weight:700;background:#d4af3733;border:1px solid rgba(212,175,55,.5);color:var(--oilserv-gold-dark);border-radius:6px}.schedule-drilldown .wbs-name{margin:0 0 .5rem;font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary);line-height:1.4}.schedule-drilldown .wbs-id{margin:0;font-family:var(--font-mono);font-size:.8125rem;color:var(--tech-cyan);letter-spacing:.05em}.schedule-drilldown .section-header-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.schedule-drilldown .critical-filter-toggle{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:#d4af371a;border:2px solid rgba(212,175,55,.3);border-radius:8px;cursor:pointer;transition:all .2s ease}.schedule-drilldown .critical-filter-toggle:hover{background:#d4af3726;border-color:var(--oilserv-gold)}.schedule-drilldown .critical-filter-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--oilserv-gold)}.schedule-drilldown .toggle-label{font-family:var(--font-body);font-size:.875rem;font-weight:600;color:var(--oilserv-gold-dark);letter-spacing:.02em}.schedule-drilldown .tasks-table-container{overflow-x:auto;background:#ffffffb3;border:2px solid rgba(212,175,55,.2);border-radius:12px;margin-top:1.5rem}.schedule-drilldown .tasks-table{width:100%;border-collapse:collapse;font-family:var(--font-body)}.schedule-drilldown .tasks-table thead{background:#d4af371a;border-bottom:2px solid rgba(212,175,55,.3)}.schedule-drilldown .tasks-table th{padding:1rem;text-align:left;font-size:.75rem;font-weight:700;color:var(--oilserv-gold-dark);text-transform:uppercase;letter-spacing:.08em;border-right:1px solid rgba(212,175,55,.15)}.schedule-drilldown .tasks-table th:last-child{border-right:none}.schedule-drilldown .tasks-table tbody tr{border-bottom:1px solid rgba(212,175,55,.1);transition:background .2s ease}.schedule-drilldown .tasks-table tbody tr:hover{background:#d4af370d}.schedule-drilldown .task-row--critical{background:#dc26260d!important;border-left:4px solid var(--emergency-red)}.schedule-drilldown .task-row--critical:hover{background:#dc26261a!important}.schedule-drilldown .tasks-table td{padding:.875rem 1rem;font-size:.875rem;color:var(--text-primary);border-right:1px solid rgba(212,175,55,.08)}.schedule-drilldown .tasks-table td:last-child{border-right:none}.col-critical{width:40px;text-align:center}.critical-flag{color:#fb923c;font-size:1.125rem}.col-task-id{width:150px}.col-task-name{min-width:300px}.col-dates{width:130px}.col-progress{width:150px}.col-status{width:120px}.schedule-drilldown .progress-bar-container{position:relative;width:100%;height:24px;background:#d4af371a;border:1px solid rgba(212,175,55,.3);border-radius:6px;overflow:hidden}.schedule-drilldown .progress-bar-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--oilserv-gold) 0%,var(--oilserv-gold-light) 100%);transition:width .3s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.schedule-drilldown .status-badge{display:inline-block;padding:.25rem .75rem;font-size:.75rem;font-weight:700;border-radius:6px;border:1px solid;text-transform:uppercase;letter-spacing:.05em}.schedule-drilldown .status-badge.status-active,.schedule-drilldown .status-badge.status-in_progress{background:#05966926;border-color:#05966980;color:var(--pipeline-green)}.schedule-drilldown .status-badge.status-completed{background:#0ea5e926;border-color:#0ea5e980;color:var(--tech-cyan)}.schedule-drilldown .status-badge.status-pending{background:#ff950026;border-color:#ff950080;color:var(--natural-gas-amber)}.schedule-drilldown .table-footer-note{padding:1rem;text-align:center;font-size:.875rem;color:var(--text-secondary);font-style:italic;background:#d4af370d;border-top:1px solid rgba(212,175,55,.15)}.schedule-drilldown .command-button{padding:.875rem 2rem;font-family:var(--font-body);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--oilserv-gold);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #d4af374d}.schedule-drilldown .command-button:hover{background:var(--oilserv-gold-dark);box-shadow:0 6px 16px #d4af3766;transform:translateY(-2px)}@media(max-width:1024px){.schedule-drilldown .wbs-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.schedule-drilldown .kpi-command-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media(max-width:768px){.schedule-drilldown{padding:1.5rem 1rem}.schedule-drilldown .command-header{padding:2rem 1.5rem}.schedule-drilldown .header-logo-title{flex-direction:column;gap:1rem}.schedule-drilldown .command-title{font-size:1.75rem}.schedule-drilldown .section-header-row{flex-direction:column;align-items:stretch;gap:1rem}.schedule-drilldown .tasks-table-container{overflow-x:scroll}.schedule-drilldown .tasks-table{min-width:900px}.schedule-drilldown .wbs-grid,.schedule-drilldown .kpi-command-grid{grid-template-columns:1fr}}.critical-path-page{max-width:1600px;margin:0 auto;padding:1.5rem 2rem 3rem}.project-selector select{padding:.75rem 2rem .75rem 1rem;font-size:.9375rem;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;background:#fff;cursor:pointer;min-width:200px}.summary-card{background:#fffffff2;border-radius:12px;padding:1.5rem;text-align:center;border:2px solid var(--border-color, #e5e7eb);cursor:pointer;transition:all .2s ease}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.summary-card.active{border-color:var(--oilserv-gold, #c5a54a);box-shadow:0 0 0 3px #c5a54a26}.summary-card .card-value{font-size:2.5rem;font-weight:700;font-family:var(--font-display, "Inter", sans-serif);color:var(--text-primary, #1f2937)}.summary-card .card-label{font-size:.875rem;font-weight:600;color:var(--text-secondary, #6b7280);margin-top:.5rem}.summary-card .card-badge{font-size:.75rem;color:var(--text-secondary, #6b7280);margin-top:.25rem}.summary-card.critical{background:linear-gradient(135deg,#dc26260d,#dc262605);border-color:#dc26264d}.summary-card.critical .card-value{color:#dc2626}.summary-card.warning{background:linear-gradient(135deg,#f59e0b0d,#f59e0b05);border-color:#f59e0b4d}.summary-card.warning .card-value{color:#f59e0b}.summary-card.success{background:linear-gradient(135deg,#0596690d,#05966905);border-color:#0596694d}.summary-card.success .card-value{color:#059669}.tasks-section{background:#fffffff2;border-radius:16px;border:1px solid var(--border-color, #e5e7eb);overflow:hidden;margin-bottom:1.5rem}.task-count{font-size:.875rem;color:var(--text-secondary, #6b7280);background:#0000000d;padding:.25rem .75rem;border-radius:12px}.table-container{overflow-x:auto;max-height:600px;overflow-y:auto}.tasks-table{width:100%;border-collapse:collapse;font-size:.875rem}.tasks-table thead{position:sticky;top:0;background:#f8fafcfa;z-index:10}.tasks-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-secondary, #6b7280);border-bottom:1px solid var(--border-color, #e5e7eb);white-space:nowrap}.tasks-table td{padding:.75rem 1rem;border-bottom:1px solid rgba(229,231,235,.5);color:var(--text-primary, #1f2937)}.tasks-table tbody tr{transition:background-color .15s ease}.tasks-table tbody tr:hover{background:#00000005}.tasks-table tr.status-critical{background:#dc262608}.tasks-table tr.status-near-critical{background:#f59e0b08}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.02em}.task-code{font-family:JetBrains Mono,monospace;font-size:.8125rem;color:var(--text-secondary, #6b7280)}.task-name{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wbs{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.8125rem;color:var(--text-secondary, #6b7280)}.progress-cell{position:relative;width:100px;height:20px;background:#0000000d;border-radius:4px;overflow:hidden}.progress-bar{position:absolute;left:0;top:0;height:100%;border-radius:4px;transition:width .3s ease}.progress-value{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:600;color:var(--text-primary, #1f2937)}.float-value{font-family:JetBrains Mono,monospace;font-weight:600}.float-value.critical{color:#dc2626}.float-value.near-critical{color:#f59e0b}.float-value.on-track{color:#059669}.no-data{text-align:center;padding:2rem;color:var(--text-secondary, #6b7280);font-style:italic}.legend-section{background:#fffffff2;border-radius:12px;padding:1.5rem;border:1px solid var(--border-color, #e5e7eb)}.legend-section h3{font-size:1rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0 0 1rem}.legend-items{display:flex;flex-wrap:wrap;gap:1.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary, #6b7280)}.legend-color{width:16px;height:16px;border-radius:4px;flex-shrink:0}@media(max-width:1200px){.summary-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.critical-path-page{padding:1rem}.page-header .header-content{flex-direction:column;align-items:flex-start}.summary-cards{grid-template-columns:1fr 1fr}.legend-items{flex-direction:column;gap:.75rem}}.cashflow-page{max-width:1600px;margin:0 auto;padding:1.5rem 2rem 3rem}.page-header .header-content{display:flex;justify-content:space-between;align-items:center;gap:2rem}.header-controls{display:flex;align-items:center;gap:1rem}.control-group{display:flex;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;overflow:hidden}.control-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;background:#fff;border:none;cursor:pointer;transition:all .2s ease;color:var(--text-secondary, #6b7280)}.control-btn:not(:last-child){border-right:1px solid var(--border-color, #e5e7eb)}.control-btn:hover{background:#00000005}.control-btn.active{background:var(--oilserv-gold, #c5a54a);color:#fff}.project-selector{padding:.5rem 2rem .5rem 1rem;font-size:.875rem;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;background:#fff;cursor:pointer}.error-banner{padding:1rem 1.5rem;background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:12px;color:#dc2626;margin-bottom:1.5rem;font-weight:500}.summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.summary-card{background:#fffffff2;border-radius:12px;padding:1.5rem;border:2px solid var(--border-color, #e5e7eb);transition:all .2s ease}.summary-card .card-label{font-size:.875rem;font-weight:500;color:var(--text-secondary, #6b7280);margin-bottom:.5rem}.summary-card .card-value{font-size:1.75rem;font-weight:700;font-family:var(--font-display, "Inter", sans-serif);color:var(--text-primary, #1f2937)}.summary-card .card-badge{font-size:.75rem;color:var(--text-secondary, #6b7280);margin-top:.5rem}.summary-card.budget{background:linear-gradient(135deg,#d4af3714,#d4af3705);border-color:#d4af374d}.summary-card.budget .card-value{color:var(--oilserv-gold-dark, #a68a3a)}.summary-card.actuals{background:linear-gradient(135deg,#6366f114,#6366f105);border-color:#6366f14d}.summary-card.actuals .card-value{color:#6366f1}.summary-card.commitments{background:linear-gradient(135deg,#f59e0b14,#f59e0b05);border-color:#f59e0b4d}.summary-card.commitments .card-value{color:#f59e0b}.summary-card.remaining{background:linear-gradient(135deg,#05966914,#05966905);border-color:#0596694d}.summary-card.remaining .card-value{color:#059669}.data-source-indicator{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#10b98114;border:1px solid rgba(16,185,129,.2);border-radius:8px;margin-bottom:1.5rem;font-size:.75rem}.pulse-dot{width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.1)}}.live-label{font-weight:700;color:#059669}.source-info{color:#059669;opacity:.8}.chart-section{background:#fffffff2;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--border-color, #e5e7eb)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.chart-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0}.chart-legend{display:flex;gap:1.5rem}.chart-legend .legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary, #6b7280)}.chart-legend .legend-color{width:16px;height:16px;border-radius:4px}.chart-legend .legend-color.planned{background:var(--oilserv-gold, #c5a54a)}.chart-legend .legend-color.actual{background:#6366f1}.chart-container{position:relative;height:300px;padding-left:80px}.bar-chart{display:flex;align-items:flex-end;height:100%;gap:4px;padding-bottom:30px}.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.chart-bar-group.future{opacity:.5}.bars{flex:1;display:flex;align-items:flex-end;gap:2px;width:100%}.bar{flex:1;border-radius:2px 2px 0 0;transition:height .3s ease;min-width:8px}.bar.planned{background:var(--oilserv-gold, #c5a54a)}.bar.actual{background:#6366f1}.bar-label{font-size:.625rem;color:var(--text-secondary, #6b7280);margin-top:.5rem;writing-mode:vertical-lr;text-orientation:mixed;transform:rotate(180deg)}.y-axis{position:absolute;left:0;top:0;bottom:30px;width:70px;display:flex;flex-direction:column;justify-content:space-between;font-size:.75rem;color:var(--text-secondary, #6b7280);text-align:right;padding-right:10px}.table-section{background:#fffffff2;border-radius:16px;border:1px solid var(--border-color, #e5e7eb);overflow:hidden;margin-bottom:1.5rem}.table-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #e5e7eb);background:#f8fafc99}.table-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0}.period-count{font-size:.875rem;color:var(--text-secondary, #6b7280);background:#0000000d;padding:.25rem .75rem;border-radius:12px}.table-container{overflow-x:auto;max-height:400px;overflow-y:auto}.cashflow-table{width:100%;border-collapse:collapse;font-size:.875rem}.cashflow-table thead{position:sticky;top:0;background:#f8fafcfa;z-index:10}.cashflow-table th{padding:.75rem 1rem;text-align:right;font-weight:600;color:var(--text-secondary, #6b7280);border-bottom:1px solid var(--border-color, #e5e7eb)}.cashflow-table th:first-child{text-align:left}.cashflow-table td{padding:.75rem 1rem;text-align:right;border-bottom:1px solid rgba(229,231,235,.5);font-family:JetBrains Mono,monospace;font-size:.8125rem}.cashflow-table td:first-child{text-align:left;font-family:inherit}.cashflow-table tbody tr:hover{background:#00000005}.cashflow-table tr.future{opacity:.6;font-style:italic}.period-cell{font-weight:500;color:var(--text-primary, #1f2937)}.variance.positive{color:#059669}.variance.negative{color:#dc2626}.forecast-section{background:#fffffff2;border-radius:16px;padding:1.5rem;border:1px solid var(--border-color, #e5e7eb)}.forecast-section h2{font-size:1.125rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0 0 1rem}.forecast-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.forecast-card{padding:1rem;background:#f8fafc99;border-radius:8px;text-align:center}.forecast-card .forecast-label{font-size:.875rem;color:var(--text-secondary, #6b7280);margin-bottom:.5rem}.forecast-card .forecast-value{font-size:1.5rem;font-weight:700;font-family:var(--font-display, "Inter", sans-serif);color:var(--text-primary, #1f2937)}.forecast-card .forecast-value.good{color:#059669}.forecast-card .forecast-value.warning{color:#f59e0b}@media(max-width:1200px){.summary-cards{grid-template-columns:repeat(2,1fr)}.forecast-cards{grid-template-columns:1fr}}@media(max-width:768px){.cashflow-page{padding:1rem}.page-header .header-content{flex-direction:column;align-items:flex-start}.header-controls{flex-wrap:wrap;width:100%}.chart-container{height:250px;padding-left:60px}.bar-label{display:none}}.hse-admin-page{max-width:1200px;margin:0 auto;padding:1.5rem 2rem 3rem}.page-header{background:#fffffff2;border-radius:16px;padding:1.5rem 2rem;margin-bottom:1.5rem;border:1px solid var(--border-color, #e5e7eb);box-shadow:0 4px 12px #0000000d}.page-header .header-content{display:flex;justify-content:space-between;align-items:center}.header-logo-title{display:flex;align-items:center;gap:1rem}.header-logo{height:48px;width:auto}.page-title{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1f2937);margin:0;font-family:var(--font-display, "Inter", sans-serif)}.page-subtitle{font-size:.875rem;color:var(--text-secondary, #6b7280);margin:.25rem 0 0}.admin-content{display:grid;grid-template-columns:1fr;gap:2rem}.history-section{background:#fffffff2;border-radius:16px;padding:1.5rem;border:1px solid var(--border-color, #e5e7eb)}.history-section h2{font-size:1.125rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0 0 1rem}.history-list{display:flex;flex-direction:column;gap:1rem}.history-item{padding:1rem;background:#f8fafc99;border-radius:8px;border:1px solid var(--border-color, #e5e7eb)}.history-date{font-weight:600;color:var(--text-primary, #1f2937);margin-bottom:.5rem}.history-metrics{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.875rem;color:var(--text-secondary, #6b7280)}.history-metrics .status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase}.history-metrics .status-badge.green{background:#059669}.history-metrics .status-badge.yellow{background:#f59e0b}.history-metrics .status-badge.red{background:#dc2626}.history-comments{margin-top:.5rem;font-size:.875rem;color:var(--text-secondary, #6b7280);font-style:italic}@media(max-width:768px){.hse-admin-page{padding:1rem}}.cfo-dashboard{min-height:100vh;padding:2rem 1.5rem;max-width:1800px;margin:0 auto}.cfo-error-state{max-width:600px;margin:4rem auto;text-align:center;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:2px solid rgba(220,38,38,.2);border-radius:16px;padding:3rem}.cfo-error-state .error-icon{font-size:4rem;margin-bottom:1rem}.cfo-error-state h2{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--emergency-red);margin:0 0 1rem}.cfo-error-state p{color:var(--text-secondary);margin-bottom:2rem}.cfo-gauges-section{margin-bottom:2rem}.cfo-gauges-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}@media(max-width:1200px){.cfo-gauges-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.cfo-gauges-grid{grid-template-columns:1fr}}.cfo-kpi-section{margin-bottom:2rem}.cfo-kpi-card{padding:1.5rem;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:2px solid rgba(212,175,55,.15);border-radius:12px;box-shadow:var(--shadow-md),inset 0 1px #fffc;transition:all var(--duration-normal) var(--ease-mechanical)}.cfo-kpi-card:hover{border-color:#d4af374d;transform:translateY(-2px);box-shadow:var(--shadow-lg),inset 0 1px #ffffffe6}.cfo-kpi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.cfo-kpi-label{font-family:var(--font-display);font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.cfo-kpi-value{font-family:var(--font-display);font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1.2;letter-spacing:-.02em}.cfo-kpi-value.negative{color:var(--emergency-red)}.overrun-indicator{font-size:.75rem;font-weight:700;color:var(--emergency-red);background:#dc26261a;padding:.125rem .5rem;border-radius:4px;margin-left:.5rem;vertical-align:middle}.cfo-kpi-subtitle{font-family:var(--font-body);font-size:.8125rem;color:var(--text-tertiary);margin-top:.5rem}.cfo-categories-section,.cfo-stacked-section{margin-bottom:2rem}.cfo-non-operating-section{border:2px solid rgba(220,38,38,.2);background:#dc262605}.cfo-non-operating-section:before{background:linear-gradient(90deg,var(--emergency-red) 0%,rgba(220,38,38,.5) 50%,var(--emergency-red) 100%)}.section-badge.warning{background:#dc26261a;color:var(--emergency-red);border:1px solid rgba(220,38,38,.2);padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600}.non-operating-alert{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;background:#dc26260d;border:1px solid rgba(220,38,38,.15);border-radius:8px;margin-bottom:1.5rem}.alert-icon{font-size:1.5rem;flex-shrink:0}.alert-content h3{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--emergency-red);margin:0 0 .25rem}.alert-content p{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.5}.non-operating-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:768px){.non-operating-grid{grid-template-columns:1fr}}.non-operating-card{padding:1.5rem;background:#ffffffb3;border:1px solid rgba(220,38,38,.1);border-radius:10px;text-align:center;transition:all var(--duration-fast)}.non-operating-card:hover{background:#ffffffe6;border-color:#dc262633}.non-operating-card.total{background:#dc26260d;border-color:#dc262633}.non-operating-icon{font-size:2rem;margin-bottom:.5rem}.non-operating-label{font-family:var(--font-display);font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.5rem}.non-operating-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:800;color:var(--emergency-red);margin-bottom:.25rem}.non-operating-gl{font-family:var(--font-mono);font-size:.75rem;color:var(--text-tertiary)}.cfo-actions-section{margin-bottom:2rem}.action-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:768px){.action-cards-grid{grid-template-columns:1fr}}.action-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#ffffffb3;border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all var(--duration-fast) var(--ease-mechanical);text-align:left;font-family:var(--font-body)}.action-card:hover{background:#fffffff2;border-color:var(--oilserv-gold);transform:translate(4px);box-shadow:var(--shadow-md)}.action-card:focus{outline:none;border-color:var(--oilserv-gold);box-shadow:0 0 0 3px #d4af3733}.action-icon{font-size:1.5rem;flex-shrink:0}.action-label{flex:1;font-size:.9375rem;font-weight:600;color:var(--text-primary)}.action-arrow{font-size:1.25rem;color:var(--oilserv-gold);opacity:0;transform:translate(-8px);transition:all var(--duration-fast)}.action-card:hover .action-arrow{opacity:1;transform:translate(0)}@media print{.cfo-dashboard{background:#fff;padding:0}.command-header,.cfo-actions-section{display:none}.dashboard-section{page-break-inside:avoid;background:#fff;border:1px solid #ccc;box-shadow:none}}@media(prefers-reduced-motion:reduce){.cfo-kpi-card,.action-card,.non-operating-card{transition-duration:.01ms!important}.action-card:hover{transform:none}.action-arrow{opacity:1;transform:none}}
