@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";@media print{*,*:before,*:after{background:#fff!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}.sidebar,.header,.footer,nav,button,.btn,.command-button,.filter-controls,.search-bar,.view-toggle,.export-btn,.refresh-btn,.tooltip,.breadcrumb,.loading-spinner,.skeleton-base,.gantt-controls,.pagination,.command-select,.quick-links{display:none!important}@page{size:A4 landscape;margin:1cm}body{font-size:10pt;line-height:1.4;font-family:Arial,sans-serif}.dashboard-page,.portfolio-overview,.main-content{padding:0!important;margin:0!important;width:100%!important;max-width:none!important}.command-header,.section-header{padding:.5rem 0!important;margin-bottom:.5rem!important;border-bottom:1px solid #000!important}.command-title{font-size:14pt!important;font-weight:700!important;margin:0!important}.section-title{font-size:12pt!important;font-weight:700!important;margin:0!important}.kpi-grid,.skeleton-kpi-grid{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:.5rem!important;page-break-inside:avoid}.kpi-card{border:1px solid #ccc!important;padding:.5rem!important;border-radius:0!important}.kpi-value{font-size:12pt!important;font-weight:700!important}.kpi-title{font-size:8pt!important}table{width:100%!important;border-collapse:collapse!important;page-break-inside:avoid;font-size:9pt!important}th,td{border:1px solid #ccc!important;padding:.25rem .5rem!important;text-align:left!important}th{font-weight:700!important;background:#f0f0f0!important}.recharts-wrapper,.chart-container,.s-curve-chart{page-break-inside:avoid;border:1px solid #ccc!important;padding:.5rem!important;min-height:200px!important;display:flex!important;align-items:center!important;justify-content:center!important}.recharts-wrapper:after{content:"Chart - See digital version for interactive chart"!important;display:block!important;font-style:italic!important;color:#666!important}.progress-bar{border:1px solid #000!important;height:12px!important}.progress-fill{background:#333!important;print-color-adjust:exact!important;-webkit-print-color-adjust:exact!important}.dashboard-section,section{page-break-inside:avoid;margin-bottom:1rem!important;padding:0!important}a{text-decoration:none!important}a[href]:after{content:none!important}.project-card,.portfolio-card{border:1px solid #ccc!important;padding:.5rem!important;margin-bottom:.5rem!important;page-break-inside:avoid}.status-badge,.critical-badge{border:1px solid #000!important;padding:.125rem .25rem!important;font-size:8pt!important}.gantt-chart{display:none!important}.milestones-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:.5rem!important}.milestone-card{border:1px solid #ccc!important;padding:.5rem!important;page-break-inside:avoid}body:after{content:"Printed on: " attr(data-print-date);position:fixed;bottom:0;right:0;font-size:8pt;color:#666}}.desktop-only{display:none}@media(min-width:769px){.desktop-only{display:block}.desktop-only-flex{display:flex}.desktop-only-grid{display:grid}}.mobile-only{display:block}.mobile-only-flex{display:flex}@media(min-width:769px){.mobile-only,.mobile-only-flex{display:none!important}}@media(max-width:768px){.table-desktop-only{display:none!important}}@media(min-width:769px){.table-mobile-only{display:none!important}}@media(pointer:coarse){.touch-target{min-height:44px;min-width:44px}button,a,[role=button]{min-height:44px}.tap-target-link{display:block;padding:12px 16px;margin:-12px -16px}}@media(max-width:768px){.mobile-heading-sm h1{font-size:1.75rem}.mobile-heading-sm h2{font-size:1.5rem}.mobile-heading-sm h3{font-size:1.25rem}.mobile-text-sm{font-size:.875rem}.mobile-text-xs{font-size:.75rem}}@media(max-width:768px){.mobile-p-sm{padding:1rem}.mobile-p-md{padding:1.5rem}.mobile-px-sm{padding-left:1rem;padding-right:1rem}.mobile-py-sm{padding-top:.75rem;padding-bottom:.75rem}.mobile-gap-sm{gap:.75rem}.mobile-gap-md{gap:1rem}.mobile-stack{flex-direction:column}.mobile-stack-reverse{flex-direction:column-reverse}}@media(max-width:768px){.mobile-cols-1{grid-template-columns:1fr!important}.mobile-cols-2{grid-template-columns:repeat(2,1fr)!important}.mobile-full-width{width:100%!important;max-width:100%!important}}@media(max-width:768px){.mobile-chart-container{min-height:300px}.recharts-legend-wrapper{font-size:11px!important}.recharts-default-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}}.mobile-scroll-x{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.mobile-scroll-x::-webkit-scrollbar{height:4px}.mobile-scroll-x::-webkit-scrollbar-thumb{background:var(--border-primary, rgba(255, 255, 255, .2));border-radius:2px}.mobile-scroll-snap{scroll-snap-type:x mandatory}.mobile-scroll-snap>*{scroll-snap-align:start}.safe-area-inset-top{padding-top:env(safe-area-inset-top,0)}.safe-area-inset-bottom{padding-bottom:env(safe-area-inset-bottom,0)}.safe-area-inset-left{padding-left:env(safe-area-inset-left,0)}.safe-area-inset-right{padding-right:env(safe-area-inset-right,0)}.mobile-optimize{transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden}@media(hover:none){.no-touch-hover:hover{background:inherit;color:inherit}}.pull-indicator{position:fixed;top:0;left:50%;transform:translate(-50%) translateY(-100%);padding:8px 16px;background:var(--bg-secondary);border-radius:0 0 8px 8px;font-size:12px;color:var(--text-tertiary);transition:transform .2s ease;z-index:1000}.pull-indicator.visible{transform:translate(-50%) translateY(0)}.glass{background:rgba(15,23,42,var(--glass-opacity, .85));backdrop-filter:blur(var(--glass-blur, 16px)) saturate(var(--glass-saturate, 180%));-webkit-backdrop-filter:blur(var(--glass-blur, 16px)) saturate(var(--glass-saturate, 180%));border:1px solid var(--glass-border, rgba(212, 175, 55, .15))}.glass-sm{background:#0f172abf;backdrop-filter:blur(12px) saturate(150%);-webkit-backdrop-filter:blur(12px) saturate(150%);border:1px solid rgba(212,175,55,.1)}.glass-lg{background:#0f172ae6;backdrop-filter:blur(var(--glass-blur-lg, 20px)) saturate(200%);-webkit-backdrop-filter:blur(var(--glass-blur-lg, 20px)) saturate(200%);border:1px solid var(--glass-border-strong, rgba(212, 175, 55, .25))}.glass-card{background:#0f172ad9;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1px solid rgba(212,175,55,.15);border-radius:var(--radius-lg, 8px)}.glass-panel{background:linear-gradient(135deg,#0f172ae6,#1e293bd9);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(212,175,55,.2);border-radius:var(--radius-xl, 12px)}.badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:var(--radius-full, 9999px);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;white-space:nowrap}.badge-success{background:var(--status-success-light, rgba(5, 150, 105, .1));color:var(--status-success, #059669);border:1px solid rgba(5,150,105,.3)}.badge-warning{background:var(--status-warning-light, rgba(217, 119, 6, .1));color:var(--status-warning, #d97706);border:1px solid rgba(217,119,6,.3)}.badge-critical,.badge-danger{background:var(--status-critical-light, rgba(220, 38, 38, .1));color:var(--status-critical, #dc2626);border:1px solid rgba(220,38,38,.3)}.badge-info{background:var(--status-info-light, rgba(14, 165, 233, .1));color:var(--status-info, #0ea5e9);border:1px solid rgba(14,165,233,.3)}.badge-neutral{background:#94a3b81a;color:#94a3b8;border:1px solid rgba(148,163,184,.3)}.badge-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge-sm{padding:.125rem .5rem;font-size:.625rem}.badge-lg{padding:.375rem .875rem;font-size:.875rem}.m-0{margin:0}.m-xs{margin:var(--spacing-xs, .25rem)}.m-sm{margin:var(--spacing-sm, .5rem)}.m-md{margin:var(--spacing-md, 1rem)}.m-lg{margin:var(--spacing-lg, 1.5rem)}.m-xl{margin:var(--spacing-xl, 2rem)}.mt-0{margin-top:0}.mt-xs{margin-top:var(--spacing-xs, .25rem)}.mt-sm{margin-top:var(--spacing-sm, .5rem)}.mt-md{margin-top:var(--spacing-md, 1rem)}.mt-lg{margin-top:var(--spacing-lg, 1.5rem)}.mt-xl{margin-top:var(--spacing-xl, 2rem)}.mb-0{margin-bottom:0}.mb-xs{margin-bottom:var(--spacing-xs, .25rem)}.mb-sm{margin-bottom:var(--spacing-sm, .5rem)}.mb-md{margin-bottom:var(--spacing-md, 1rem)}.mb-lg{margin-bottom:var(--spacing-lg, 1.5rem)}.mb-xl{margin-bottom:var(--spacing-xl, 2rem)}.ml-0{margin-left:0}.ml-xs{margin-left:var(--spacing-xs, .25rem)}.ml-sm{margin-left:var(--spacing-sm, .5rem)}.ml-md{margin-left:var(--spacing-md, 1rem)}.ml-lg{margin-left:var(--spacing-lg, 1.5rem)}.ml-auto{margin-left:auto}.mr-0{margin-right:0}.mr-xs{margin-right:var(--spacing-xs, .25rem)}.mr-sm{margin-right:var(--spacing-sm, .5rem)}.mr-md{margin-right:var(--spacing-md, 1rem)}.mr-lg{margin-right:var(--spacing-lg, 1.5rem)}.mr-auto{margin-right:auto}.p-0{padding:0}.p-xs{padding:var(--spacing-xs, .25rem)}.p-sm{padding:var(--spacing-sm, .5rem)}.p-md{padding:var(--spacing-md, 1rem)}.p-lg{padding:var(--spacing-lg, 1.5rem)}.p-xl{padding:var(--spacing-xl, 2rem)}.pt-0{padding-top:0}.pt-xs{padding-top:var(--spacing-xs, .25rem)}.pt-sm{padding-top:var(--spacing-sm, .5rem)}.pt-md{padding-top:var(--spacing-md, 1rem)}.pt-lg{padding-top:var(--spacing-lg, 1.5rem)}.pb-0{padding-bottom:0}.pb-xs{padding-bottom:var(--spacing-xs, .25rem)}.pb-sm{padding-bottom:var(--spacing-sm, .5rem)}.pb-md{padding-bottom:var(--spacing-md, 1rem)}.pb-lg{padding-bottom:var(--spacing-lg, 1.5rem)}.px-sm{padding-left:var(--spacing-sm, .5rem);padding-right:var(--spacing-sm, .5rem)}.px-md{padding-left:var(--spacing-md, 1rem);padding-right:var(--spacing-md, 1rem)}.px-lg{padding-left:var(--spacing-lg, 1.5rem);padding-right:var(--spacing-lg, 1.5rem)}.py-sm{padding-top:var(--spacing-sm, .5rem);padding-bottom:var(--spacing-sm, .5rem)}.py-md{padding-top:var(--spacing-md, 1rem);padding-bottom:var(--spacing-md, 1rem)}.py-lg{padding-top:var(--spacing-lg, 1.5rem);padding-bottom:var(--spacing-lg, 1.5rem)}.gap-0{gap:0}.gap-xs{gap:var(--spacing-xs, .25rem)}.gap-sm{gap:var(--spacing-sm, .5rem)}.gap-md{gap:var(--spacing-md, 1rem)}.gap-lg{gap:var(--spacing-lg, 1.5rem)}.gap-xl{gap:var(--spacing-xl, 2rem)}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.6}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-shimmer{background:linear-gradient(90deg,#fff0,#ffffff0d,#fff0);background-size:200% 100%;animation:shimmer 2s ease-in-out infinite}.animate-pulse{animation:pulse-glow 2s ease-in-out infinite}.animate-fade-in{animation:fade-in .3s ease-out forwards}.animate-slide-up{animation:slide-up .4s ease-out forwards}.animate-slide-in-right{animation:slide-in-right .3s ease-out forwards}.animate-scale-in{animation:scale-in .2s ease-out forwards}.transition-fast{transition:all .15s ease}.transition-base{transition:all .2s ease}.transition-slow{transition:all .3s ease}.transition-colors{transition:color .2s ease,background-color .2s ease,border-color .2s ease}.transition-transform{transition:transform .2s ease}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.flex-1{flex:1}.flex-grow{flex-grow:1}.flex-shrink-0{flex-shrink:0}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-around{justify-content:space-around}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.font-normal{font-weight:400}.text-left{text-align:left}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.text-muted{color:#94a3b8}.text-gold{color:var(--gold-primary, #d4af37)}.text-success{color:var(--status-success, #059669)}.text-warning{color:var(--status-warning, #d97706)}.text-critical{color:var(--status-critical, #dc2626)}.text-info{color:var(--status-info, #0ea5e9)}.border{border:1px solid rgba(212,175,55,.15)}.border-0{border:none}.border-gold{border-color:#d4af374d}.border-strong{border-color:#d4af3780}.rounded-none{border-radius:0}.rounded-sm{border-radius:var(--radius-sm, 4px)}.rounded{border-radius:var(--radius-md, 6px)}.rounded-lg{border-radius:var(--radius-lg, 8px)}.rounded-xl{border-radius:var(--radius-xl, 12px)}.rounded-2xl{border-radius:var(--radius-2xl, 16px)}.rounded-full{border-radius:var(--radius-full, 9999px)}.invisible{visibility:hidden}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.overflow-x-auto{overflow-x:auto}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.pointer-events-none{pointer-events:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.focus-ring:focus{outline:none;box-shadow:0 0 0 2px #d4af3766}.focus-ring:focus-visible{outline:2px solid var(--gold-primary, #d4af37);outline-offset:2px}.skeleton{background:linear-gradient(90deg,#ffffff08 25%,#ffffff14,#ffffff08 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm, 4px)}.skeleton-text{height:1rem;width:100%}.skeleton-heading{height:1.5rem;width:60%}.skeleton-card{height:120px;width:100%;border-radius:var(--radius-lg, 8px)}.skeleton-circle{border-radius:50%}:root{--font-size-base: 16px;--font-size-sm: 14px;--font-size-xs: 12px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-2xl: 30px;--font-size-3xl: 36px;--font-size-4xl: 48px;--gauge-size-sm: 120px;--gauge-size-md: 160px;--gauge-size-lg: 200px;--kpi-min-width: 260px;--kpi-padding: 1.25rem;--page-padding: 1.5rem;--grid-gap: 1rem}@media(min-width:1366px){:root{--font-size-base: 15px;--font-size-sm: 13px;--font-size-xs: 11px;--font-size-lg: 17px;--font-size-xl: 22px;--font-size-2xl: 28px;--font-size-3xl: 34px;--font-size-4xl: 44px;--gauge-size-sm: 110px;--gauge-size-md: 150px;--gauge-size-lg: 180px;--kpi-min-width: 240px;--kpi-padding: 1rem;--page-padding: 1.25rem;--grid-gap: .875rem}html{font-size:15px}}@media(min-width:1440px){:root{--font-size-base: 16px;--font-size-sm: 14px;--font-size-xs: 12px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-2xl: 30px;--font-size-3xl: 36px;--font-size-4xl: 48px;--gauge-size-sm: 120px;--gauge-size-md: 160px;--gauge-size-lg: 200px;--kpi-min-width: 280px;--kpi-padding: 1.25rem;--page-padding: 1.5rem;--grid-gap: 1rem}html{font-size:16px}}@media(min-width:1680px){:root{--font-size-base: 16px;--font-size-sm: 14px;--font-size-xs: 12px;--font-size-lg: 19px;--font-size-xl: 25px;--font-size-2xl: 32px;--font-size-3xl: 40px;--font-size-4xl: 52px;--gauge-size-sm: 140px;--gauge-size-md: 180px;--gauge-size-lg: 220px;--kpi-min-width: 300px;--kpi-padding: 1.5rem;--page-padding: 2rem;--grid-gap: 1.25rem}html,body{font-size:16px}}@media(min-width:1920px){:root{--font-size-base: 16px;--font-size-sm: 14px;--font-size-xs: 12px;--font-size-lg: 20px;--font-size-xl: 26px;--font-size-2xl: 34px;--font-size-3xl: 44px;--font-size-4xl: 56px;--gauge-size-sm: 150px;--gauge-size-md: 200px;--gauge-size-lg: 260px;--kpi-min-width: 320px;--kpi-padding: 1.5rem;--page-padding: 2.5rem;--grid-gap: 1.5rem}html,body{font-size:16px}h1{font-size:clamp(2rem,3.5vw,3rem)!important}h2{font-size:clamp(1.5rem,2.5vw,2.25rem)!important}h3{font-size:clamp(1.25rem,2vw,1.75rem)!important}}@media(min-width:2560px){:root{--font-size-base: 18px;--font-size-sm: 16px;--font-size-xs: 14px;--font-size-lg: 22px;--font-size-xl: 28px;--font-size-2xl: 36px;--font-size-3xl: 48px;--font-size-4xl: 60px;--gauge-size-sm: 180px;--gauge-size-md: 280px;--gauge-size-lg: 380px;--kpi-min-width: 380px;--kpi-padding: 2rem;--page-padding: 4rem;--grid-gap: 2rem}html,body{font-size:18px}h1{font-size:clamp(2.5rem,4vw,4rem)!important}h2{font-size:clamp(2rem,3vw,3rem)!important}h3{font-size:clamp(1.5rem,2.5vw,2.25rem)!important}p,span,div{font-size:inherit}}@media(min-width:3840px){:root{--font-size-base: 22px;--font-size-sm: 18px;--font-size-xs: 16px;--font-size-lg: 28px;--font-size-xl: 36px;--font-size-2xl: 48px;--font-size-3xl: 64px;--font-size-4xl: 80px;--gauge-size-sm: 240px;--gauge-size-md: 400px;--gauge-size-lg: 500px;--kpi-min-width: 480px;--kpi-padding: 2.5rem;--page-padding: 6rem;--grid-gap: 3rem}html,body{font-size:22px}}@media(min-width:5120px){:root{--font-size-base: 28px;--font-size-sm: 22px;--font-size-xs: 18px;--font-size-lg: 34px;--font-size-xl: 44px;--font-size-2xl: 56px;--font-size-3xl: 72px;--font-size-4xl: 96px;--gauge-size-sm: 300px;--gauge-size-md: 500px;--gauge-size-lg: 650px;--kpi-min-width: 600px;--kpi-padding: 3rem;--page-padding: 8rem;--grid-gap: 4rem}html{font-size:28px}}.page-container,.dashboard-container,.main-content,[class*=container]{max-width:100%!important;width:100%!important}.page-container,.dashboard-container,main,[class*=page-content]{padding-left:clamp(1rem,3vw,var(--page-padding, 4rem))!important;padding-right:clamp(1rem,3vw,var(--page-padding, 4rem))!important}.kpi-grid,[class*=kpi-grid],[class*=metrics-grid],[class*=card-grid]{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(var(--kpi-min-width, 300px),1fr))!important;gap:var(--grid-gap, 1.5rem)!important;width:100%}@media(min-width:2560px){.kpi-card{padding:var(--kpi-padding, 2rem)!important}.kpi-card__value{font-size:2.75rem!important}.kpi-card__title,.kpi-card__subtitle{font-size:1rem!important}.kpi-card__icon{width:3rem!important;height:3rem!important}}@media(min-width:3840px){.kpi-card{padding:var(--kpi-padding, 2.5rem)!important;border-radius:16px!important}.kpi-card__value{font-size:3.5rem!important}.kpi-card__title,.kpi-card__subtitle{font-size:1.125rem!important}.kpi-card__icon{width:4rem!important;height:4rem!important}.kpi-card__trend{font-size:1rem!important;padding:.5rem 1rem!important}}.radial-gauge,.gauge,[class*=gauge],[class*=Gauge]{min-width:var(--gauge-size-md, 200px)!important;min-height:var(--gauge-size-md, 200px)!important}@media(min-width:2560px){.radial-gauge,.gauge,[class*=gauge]{min-width:280px!important;min-height:280px!important}.radial-gauge--sm{min-width:200px!important;min-height:220px!important}.radial-gauge--md{min-width:300px!important;min-height:320px!important}.radial-gauge--lg{min-width:400px!important;min-height:420px!important}.radial-gauge__value{font-size:2.5rem!important}.radial-gauge__label{font-size:1.125rem!important}.radial-gauge__svg{width:240px!important;height:240px!important}.radial-gauge--lg .radial-gauge__svg{width:320px!important;height:320px!important}}@media(min-width:3840px){.radial-gauge,.gauge,[class*=gauge]{min-width:400px!important;min-height:400px!important}.radial-gauge--sm{min-width:280px!important;min-height:300px!important}.radial-gauge--md{min-width:420px!important;min-height:450px!important}.radial-gauge--lg{min-width:550px!important;min-height:580px!important}.radial-gauge__value{font-size:3.5rem!important}.radial-gauge__label{font-size:1.5rem!important}.radial-gauge__svg{width:350px!important;height:350px!important}.radial-gauge--lg .radial-gauge__svg{width:450px!important;height:450px!important}}.chart-container,.recharts-wrapper,.recharts-responsive-container,[class*=chart-container],[class*=chart-wrapper]{width:100%!important;min-height:400px}@media(min-width:2560px){.chart-container,.recharts-wrapper,.recharts-responsive-container,[class*=chart-container]{min-height:500px!important}[class*=s-curve],[class*=scurve],[class*=main-chart]{min-height:600px!important}}@media(min-width:3840px){.chart-container,.recharts-wrapper,.recharts-responsive-container,[class*=chart-container]{min-height:700px!important}[class*=s-curve],[class*=scurve],[class*=main-chart]{min-height:900px!important}.recharts-text,.recharts-label,.recharts-legend-item-text{font-size:18px!important}.recharts-tooltip-label,.recharts-tooltip-item-value{font-size:16px!important}}@media(min-width:2560px){table{font-size:1rem!important}th{font-size:.9375rem!important;padding:1rem 1.25rem!important}td{padding:1rem 1.25rem!important}}@media(min-width:3840px){table{font-size:1.125rem!important}th{font-size:1.0625rem!important;padding:1.25rem 1.5rem!important}td{padding:1.25rem 1.5rem!important}}@media(min-width:2560px){.sidebar,[class*=sidebar]{width:320px!important}.sidebar a,.sidebar button,[class*=sidebar] a{font-size:1rem!important;padding:1rem 1.5rem!important}.sidebar svg,[class*=sidebar] svg{width:24px!important;height:24px!important}}@media(min-width:3840px){.sidebar,[class*=sidebar]{width:400px!important}.sidebar a,.sidebar button,[class*=sidebar] a{font-size:1.125rem!important;padding:1.25rem 2rem!important}.sidebar svg,[class*=sidebar] svg{width:28px!important;height:28px!important}}@media(min-width:2560px){.battery,.battery-indicator,[class*=battery]{min-width:80px!important;min-height:36px!important}.battery__value,[class*=battery] [class*=value]{font-size:1rem!important}}@media(min-width:3840px){.battery,.battery-indicator,[class*=battery]{min-width:100px!important;min-height:44px!important}.battery__value,[class*=battery] [class*=value]{font-size:1.125rem!important}}@media(min-width:2560px){.progress-bar,[class*=progress-bar],[role=progressbar]{height:12px!important;border-radius:6px!important}[class*=progress] [class*=label],[class*=progress] [class*=value]{font-size:1rem!important}}@media(min-width:3840px){.progress-bar,[class*=progress-bar],[role=progressbar]{height:16px!important;border-radius:8px!important}[class*=progress] [class*=label],[class*=progress] [class*=value]{font-size:1.125rem!important}}@media(min-width:2560px){.breadcrumb,[class*=breadcrumb]{font-size:1rem!important}header h1,[class*=page-title],[class*=pageTitle]{font-size:2.5rem!important}header h2,[class*=page-subtitle]{font-size:1.5rem!important}}@media(min-width:3840px){.breadcrumb,[class*=breadcrumb]{font-size:1.125rem!important}header h1,[class*=page-title],[class*=pageTitle]{font-size:3.5rem!important}header h2,[class*=page-subtitle]{font-size:2rem!important}}@media(min-width:2560px){button,.btn,[class*=button]{font-size:1rem!important;padding:1rem 2rem!important}}@media(min-width:3840px){button,.btn,[class*=button]{font-size:1.125rem!important;padding:1.25rem 2.5rem!important}}@media(min-width:2560px){.modal,.drawer,[class*=modal],[class*=drawer]{max-width:1200px!important}.modal-content,.drawer-content{padding:2.5rem!important}}@media(min-width:3840px){.modal,.drawer,[class*=modal],[class*=drawer]{max-width:1600px!important}.modal-content,.drawer-content{padding:3rem!important}}@media(min-width:2560px){.tooltip,[class*=tooltip],.recharts-tooltip-wrapper{font-size:1rem!important}.recharts-default-tooltip{padding:1rem!important}}@media(min-width:3840px){.tooltip,[class*=tooltip],.recharts-tooltip-wrapper{font-size:1.125rem!important}.recharts-default-tooltip{padding:1.25rem!important}}@media(min-aspect-ratio:21/9)and (min-width:3440px){.dashboard-grid,.main-grid,[class*=main-content]{display:grid!important;grid-template-columns:1fr 1fr!important;gap:3rem!important}[class*=full-width],.chart-section,[class*=chart-section]{grid-column:1 / -1!important}}@media print{html{font-size:12pt!important}.kpi-card__value{font-size:18pt!important}.radial-gauge__value{font-size:16pt!important}}*,: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}.static{position:static}.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-1{margin-bottom:.25rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.table-row{display:table-row}.grid{display:grid}.hidden{display:none}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-screen{height:100vh}.w-12{width:3rem}.w-2{width:.5rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-auto{width:auto}.w-full{width:100%}.max-w-7xl{max-width:80rem}.max-w-md{max-width:28rem}.max-w-xs{max-width:20rem}.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))}.resize{resize:both}.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-1\.5{gap:.375rem}.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}.rounded-md{border-radius:6px}.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-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / 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-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-yellow-500{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / 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-1{padding:.25rem}.p-2{padding:.5rem}.p-4{padding:1rem}.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-center{text-align:center}.font-mono{font-family:JetBrains Mono,Courier New,monospace}.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}.italic{font-style:italic}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.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-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-600{--tw-text-opacity: 1;color:rgb(202 138 4 / 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}.ring{--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(3px + 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)}.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}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;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;--petroleum-deep: #1A1A1A;--natural-gas-amber: #FF9500;--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: #525252;--text-tertiary: #737373;--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;--spacing-0: 0;--spacing-px: 1px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-0: 0;--radius-xs: 2px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-3xl: 20px;--radius-full: 9999px;--glass-blur: 16px;--glass-blur-lg: 20px;--glass-opacity: .85;--glass-saturate: 180%;--glass-border: rgba(212, 175, 55, .15);--glass-border-strong: rgba(212, 175, 55, .25);--status-success: var(--pipeline-green);--status-success-light: rgba(5, 150, 105, .1);--status-success-glow: var(--pipeline-green-glow);--status-warning: var(--crude-oil);--status-warning-light: rgba(217, 119, 6, .1);--status-warning-glow: var(--crude-oil-glow);--status-critical: var(--emergency-red);--status-critical-light: rgba(220, 38, 38, .1);--status-critical-glow: var(--emergency-red-glow);--status-info: var(--tech-cyan);--status-info-light: rgba(14, 165, 233, .1);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:.6;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 fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@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\:border-gray-300:hover{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.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}}:root{--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Consolas", monospace;--font-display: var(--font-primary);--text-2xs: .625rem;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .875rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-extrabold: 800;--leading-none: 1;--leading-tight: 1.2;--leading-snug: 1.3;--leading-normal: 1.5;--leading-relaxed: 1.625;--tracking-tighter: -.02em;--tracking-tight: -.01em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--tracking-widest: .1em;--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--text-inverse: #ffffff;--color-success: #059669;--color-warning: #d97706;--color-danger: #dc2626;--color-info: #2563eb;--color-accent: #92700c}.typo-section-header{font-family:var(--font-primary);font-size:var(--text-base);font-weight:var(--weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--text-primary)}.typo-section-subtitle{font-family:var(--font-primary);font-size:var(--text-sm);font-weight:var(--weight-normal);line-height:var(--leading-normal);color:var(--text-secondary)}.typo-label{font-family:var(--font-primary);font-size:var(--text-xs);font-weight:var(--weight-semibold);line-height:var(--leading-tight);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-secondary)}.typo-micro{font-family:var(--font-primary);font-size:var(--text-2xs);font-weight:var(--weight-medium);line-height:var(--leading-tight);color:var(--text-muted)}.typo-kpi-large{font-family:var(--font-mono);font-size:var(--text-3xl);font-weight:var(--weight-extrabold);line-height:var(--leading-none);letter-spacing:var(--tracking-tight)}.typo-kpi-medium{font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:var(--weight-extrabold);line-height:var(--leading-none);letter-spacing:var(--tracking-tight)}.typo-kpi-small{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:var(--weight-bold);line-height:var(--leading-none)}.typo-data{font-family:var(--font-mono);font-size:var(--text-base);font-weight:var(--weight-medium);line-height:var(--leading-normal);color:var(--text-primary)}.typo-body{font-family:var(--font-primary);font-size:var(--text-base);font-weight:var(--weight-normal);line-height:var(--leading-normal);color:var(--text-primary)}.typo-page-title{font-family:var(--font-primary);font-size:var(--text-2xl);font-weight:var(--weight-bold);line-height:var(--leading-tight);color:var(--text-primary)}.typo-badge{font-family:var(--font-primary);font-size:var(--text-xs);font-weight:var(--weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-wider);text-transform:uppercase}@media(max-width:1199px){:root{--text-2xs: .625rem;--text-xs: .6875rem;--text-sm: .75rem;--text-base: .8125rem;--text-md: .875rem;--text-lg: 1rem;--text-xl: 1.125rem;--text-2xl: 1.375rem;--text-3xl: 1.625rem;--text-4xl: 2rem;--text-5xl: 2.5rem}}@media(max-width:767px){:root{--text-2xs: .5625rem;--text-xs: .625rem;--text-sm: .6875rem;--text-base: .75rem;--text-md: .8125rem;--text-lg: .875rem;--text-xl: 1rem;--text-2xl: 1.125rem;--text-3xl: 1.375rem;--text-4xl: 1.75rem;--text-5xl: 2rem}}.rag-green{color:var(--color-success)}.rag-amber{color:var(--color-warning)}.rag-red{color:var(--color-danger)}.rag-bg-green{background-color:#0596691f}.rag-bg-amber{background-color:#d977061f}.rag-bg-red{background-color:#dc26261f}.rag-border-green{border-color:#0596694d}.rag-border-amber{border-color:#d977064d}.rag-border-red{border-color:#dc26264d}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse-indicator{animation:pulse 2s ease-in-out infinite}.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:1rem;border-radius:8px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000f;transition:box-shadow .2s ease,border-color .2s ease;height:120px;display:flex;flex-direction:column;overflow:hidden}.kpi-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#d4af37;border-radius:8px 0 0 8px}.kpi-card__backdrop,.kpi-card__border-glow{display:none}.kpi-card__content{position:relative;z-index:1;display:flex;flex-direction:column;gap:.375rem;flex:1;min-width:0}.kpi-card__header{display:flex;align-items:center;gap:.5rem;min-width:0}.kpi-card__icon{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#1a1a1a;border-radius:5px;color:#d4af37;font-size:.75rem}.kpi-card__title{font-size:.6875rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:#64748b;margin:0;line-height:1.3;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kpi-card__drill-indicator{margin-left:auto;font-size:.875rem;color:#94a3b8;opacity:0;transition:opacity .2s ease;flex-shrink:0}.kpi-card--clickable:hover .kpi-card__drill-indicator{opacity:1}.kpi-card--clickable{cursor:pointer}.kpi-card__value-section{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;margin-top:auto;min-width:0}.kpi-card__value-container{display:flex;align-items:baseline;gap:.125rem;min-width:0;flex:1}.kpi-card__currency-icon{color:#d4af37;opacity:.8;flex-shrink:0}.kpi-card__value{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;line-height:1;letter-spacing:-.02em;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.kpi-card__unit{font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:#64748b;text-transform:uppercase;margin-left:.125rem;flex-shrink:0}.kpi-card__trend{display:inline-flex;align-items:center;gap:.125rem;padding:.125rem .375rem;border-radius:3px;font-family:var(--font-mono);font-size:.625rem;font-weight:600;flex-shrink:0}.kpi-card__trend--up{background:#10b9811a;color:#059669}.kpi-card__trend--down{background:#ef44441a;color:#dc2626}.kpi-card__trend--neutral{background:#64748b1a;color:#64748b}.kpi-card__trend-icon{width:12px;height:12px}.kpi-card__trend-value{line-height:1}.kpi-card__subtitle{font-size:.625rem;color:#94a3b8;margin:0;margin-top:.125rem;line-height:1.3;white-space:normal;word-wrap:break-word}.kpi-card__status-bar{position:absolute;bottom:0;left:0;right:0;height:2px;background:#e5e7eb;border-radius:0 0 8px 8px}.kpi-card--good:before{background:#10b981}.kpi-card--good .kpi-card__status-bar{background:#10b981}.kpi-card--good .kpi-card__icon{color:#10b981}.kpi-card--warning:before{background:#f59e0b}.kpi-card--warning .kpi-card__status-bar{background:#f59e0b}.kpi-card--warning .kpi-card__icon{color:#f59e0b}.kpi-card--critical:before{background:#ef4444}.kpi-card--critical .kpi-card__status-bar{background:#ef4444}.kpi-card--critical .kpi-card__icon{color:#ef4444}.kpi-card--info:before{background:#d4af37}.kpi-card--info .kpi-card__status-bar{background:#d4af37}.kpi-card--clickable:hover{box-shadow:0 4px 12px #00000014;border-color:#d4af37}.kpi-card--clickable:focus-visible{outline:2px solid #D4AF37;outline-offset:2px}.kpi-card--critical-alert{border-color:#ef4444;background:#fef2f2}.kpi-card--critical-alert:before{background:#ef4444}.kpi-card--critical-alert .kpi-card__value{color:#dc2626}.kpi-card--no-data{background:#f8fafc;border-style:dashed;border-color:#cbd5e1}.kpi-card--no-data:before{background:#94a3b8}.kpi-card--no-data .kpi-card__value{color:#94a3b8;font-size:.75rem;font-weight:500;font-style:italic}.kpi-card--no-data .kpi-card__title{opacity:.6}@media(max-width:1024px){.kpi-card{padding:.875rem;height:110px}.kpi-card__value{font-size:1.375rem}.kpi-card__icon{width:26px;height:26px}.kpi-card__title{font-size:.625rem}}@media(max-width:768px){.kpi-card{padding:.75rem;height:100px}.kpi-card__value{font-size:1.25rem}.kpi-card__icon{width:24px;height:24px;font-size:.625rem}.kpi-card__title{font-size:.5625rem}.kpi-card__unit{font-size:.625rem}.kpi-card__trend{font-size:.5625rem;padding:.125rem .25rem}}@media(max-width:480px){.kpi-card{padding:.625rem;height:90px}.kpi-card__value{font-size:1.125rem}.kpi-card__icon{width:22px;height:22px}.kpi-card__title{font-size:.5rem}.kpi-card__header{gap:.375rem}}@media print{.kpi-card{background:#fff;border:1px solid #ccc;box-shadow:none}}@media(prefers-reduced-motion:reduce){.kpi-card,.kpi-card--clickable:hover{transition: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:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.breakdown-header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #f1f5f9}.header-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.breakdown-title{font-family:var(--font-primary, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);font-size:.875rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#1e293b;margin:0}.header-badges{display:flex;gap:.5rem;align-items:center}.data-source-badge{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;padding:.25rem .5rem;border-radius:4px}.total-tasks-badge{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:.6875rem;font-weight:500;color:#94a3b8;background:#f8fafc;border:1px solid #e2e8f0;padding:.25rem .5rem;border-radius:4px}.weighted-progress-summary{display:flex;align-items:baseline;gap:.5rem;margin-top:.75rem}.summary-label{font-family:var(--font-primary);font-size:.75rem;font-weight:500;color:#64748b}.summary-value{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:1.25rem;font-weight:700;color:#1e293b}.phases-grid{display:flex;flex-direction:column;gap:.75rem}.phase-progress-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;transition:background-color .2s ease}.phase-progress-item:hover{background:#f1f5f9}.phase-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.phase-name-section{display:flex;align-items:center;gap:.5rem;flex:1}.phase-status-indicator{font-size:.625rem;line-height:1;color:#64748b}.phase-name{font-family:var(--font-primary);font-size:.875rem;font-weight:600;color:#334155;margin:0}.phase-meta{display:flex;gap:.5rem;align-items:center;margin-left:auto;margin-right:1rem}.task-count-badge,.phase-weight-badge{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:.625rem;font-weight:500;padding:.125rem .375rem;border-radius:3px;color:#94a3b8;background:#fff;border:1px solid #e2e8f0}.phase-progress-value{display:flex;align-items:baseline;gap:1px;font-family:var(--font-mono, "JetBrains Mono", monospace)}.progress-number{font-size:1.25rem;font-weight:700;color:#1e293b}.progress-unit{font-size:.75rem;color:#64748b;font-weight:500}.progress-bar-container{position:relative;height:6px;margin-bottom:.5rem}.progress-bar-track{position:relative;width:100%;height:100%;background:#e2e8f0;border-radius:3px;overflow:hidden}.progress-bar-fill{position:absolute;left:0;top:0;height:100%;border-radius:3px;transition:width .6s ease-out;background:#475569}.phase-progress-item[data-phase=engineering] .progress-bar-fill,.phase-progress-item[data-phase=general] .progress-bar-fill,.phase-progress-item[data-phase=procurement] .progress-bar-fill,.phase-progress-item[data-phase=construction] .progress-bar-fill,.phase-progress-item[data-phase=linear] .progress-bar-fill,.phase-progress-item[data-phase=sections] .progress-bar-fill{background:#475569}.progress-shine,.phase-weight-marker,.progress-gradient-overlay,.micro-indicators{display:none}.breakdown-footer{margin-top:1rem;padding-top:.75rem;border-top:1px solid #f1f5f9}.legend{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.legend-item{display:flex;align-items:center;gap:.25rem;font-family:var(--font-primary);font-size:.6875rem;color:#64748b}.legend-symbol{color:#94a3b8;font-size:.625rem}.loading-state .breakdown-subtitle{font-family:var(--font-primary);font-size:.75rem;color:#64748b;margin:.5rem 0 0}.loading-skeleton{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.skeleton-bar{height:60px;background:linear-gradient(90deg,#f1f5f9,#e2e8f0,#f1f5f9);background-size:200% 100%;border-radius:8px;animation:loading 1.5s ease-in-out infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{min-height:120px;display:flex;flex-direction:column;justify-content:center;align-items:center}.empty-state .breakdown-subtitle{font-family:var(--font-primary);font-size:.8125rem;color:#94a3b8;margin:0}@media(max-width:768px){.progress-breakdown-v2{padding:1rem}.header-title-row{flex-direction:column;align-items:flex-start;gap:.5rem}.phase-header-row{flex-direction:column;gap:.5rem;align-items:flex-start}.phase-meta{margin-left:0;margin-right:0}.progress-number{font-size:1.125rem}.legend{gap:.75rem}}.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:var(--spacing-sm) 0;margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.breadcrumb-list{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:0;font-family:var(--font-body)}.breadcrumb-item{display:flex;align-items:center;gap:var(--spacing-sm)}.breadcrumb-link{color:var(--oilserv-gold-dark);text-decoration:none;font-size:.875rem;font-weight:500;padding:var(--spacing-xs) 0;transition:color var(--duration-fast) var(--ease-mechanical)}.breadcrumb-link:hover{color:var(--oilserv-gold);text-decoration:none}.breadcrumb-current{color:var(--text-primary);font-size:.875rem;font-weight:600;padding:var(--spacing-xs) 0}.breadcrumb-separator{color:var(--steel-400);margin:0 var(--spacing-xs);font-size:.75rem}@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:300px;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:normal;word-wrap:break-word;line-height:1.3}.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}}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--bg-secondary, #1a2332);border-top:1px solid var(--border-primary, rgba(255, 255, 255, .1));z-index:1000;padding-bottom:env(safe-area-inset-bottom,0)}@media(max-width:768px){.mobile-bottom-nav{display:flex;align-items:center;justify-content:space-around}}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;height:100%;min-width:64px;padding:8px 4px;background:transparent;border:none;cursor:pointer;color:var(--text-tertiary, #737373);transition:color .2s ease,transform .1s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.mobile-nav-item:active{transform:scale(.95)}.mobile-nav-item.active{color:var(--accent-primary, #3b82f6)}.mobile-nav-item:focus-visible{outline:2px solid var(--accent-primary, #3b82f6);outline-offset:-2px;border-radius:8px}.mobile-nav-icon{width:24px;height:24px;margin-bottom:4px}.mobile-nav-icon svg{width:100%;height:100%}.mobile-nav-label{font-size:10px;font-weight:500;letter-spacing:.02em;text-transform:uppercase}.mobile-nav-item.active:after{content:"";position:absolute;top:4px;left:50%;transform:translate(-50%);width:4px;height:4px;background:var(--accent-primary, #3b82f6);border-radius:50%}@media(pointer:coarse){.mobile-nav-item{min-height:48px;min-width:48px}}@media(max-height:500px)and (orientation:landscape){.mobile-bottom-nav{height:48px}.mobile-nav-icon{width:20px;height:20px;margin-bottom:2px}.mobile-nav-label{font-size:9px}}@media(max-height:400px){.mobile-bottom-nav{display:none}}.app-layout{display:flex;min-height:100vh;background:var(--bg-primary, #0f1729);position:relative}.app-main{flex:1;margin-left:300px;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.app-main--expanded{margin-left:80px}.mobile-sidebar-overlay{position:fixed;inset:0;background:#0009;z-index:999;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1024px){.app-main,.app-main--expanded{margin-left:0}}@media(max-width:768px){.app-layout.has-mobile-nav .app-main{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}.app-main--mobile{margin-left:0!important}}.app-main>*{width:100%;max-width:100%}.app-main{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}@media(prefers-reduced-motion:reduce){.app-main{transition:none;scroll-behavior:auto}.mobile-sidebar-overlay{animation:none}}@media print{.app-layout{display:block}.app-main{margin-left:0;padding-bottom:0}.mobile-sidebar-overlay{display:none}}.project-selector{display:flex;flex-direction:column;gap:.5rem}.project-selector--compact{flex-direction:row;align-items:center;gap:.75rem}.project-selector--error{display:flex;align-items:center;gap:.5rem;color:var(--color-red, #ef4444);font-size:.875rem}.project-selector__label{display:flex;align-items:center;gap:.375rem;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #64748b)}.project-selector__dropdown-wrapper{position:relative;display:flex;align-items:center}.project-selector__dropdown{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-bg-elevated, rgba(30, 41, 59, .8));border:1px solid var(--color-border, rgba(148, 163, 184, .2));border-radius:.5rem;padding:.625rem 2.5rem .625rem .875rem;font-size:.875rem;font-weight:500;color:var(--color-text, #f1f5f9);cursor:pointer;min-width:200px;transition:all .2s ease}.project-selector--compact .project-selector__dropdown{min-width:160px;padding:.5rem 2rem .5rem .75rem;font-size:.8125rem}.project-selector__dropdown:hover:not(:disabled){border-color:var(--color-primary, #3b82f6);background:var(--color-bg-hover, rgba(30, 41, 59, .9))}.project-selector__dropdown:focus{outline:none;border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 3px #3b82f633}.project-selector__dropdown:disabled{opacity:.5;cursor:not-allowed}.project-selector__dropdown option{background:var(--color-bg-elevated, #1e293b);color:var(--color-text, #f1f5f9);padding:.5rem}.project-selector__chevron{position:absolute;right:.75rem;color:var(--color-text-muted, #64748b);pointer-events:none}.project-selector__loader{position:absolute;right:2rem;color:var(--color-primary, #3b82f6);animation:spin 1s linear infinite}.project-selector__info{display:flex;flex-direction:column;gap:.125rem}.project-selector__name{font-size:.8125rem;font-weight:500;color:var(--color-text, #f1f5f9);line-height:1.3}.project-selector__client{font-size:.6875rem;color:var(--color-text-muted, #64748b)}@media(prefers-color-scheme:dark){.project-selector__dropdown{background:#1e293be6}}.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}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.error-boundary-content{max-width:480px;text-align:center;background:#fff;border-radius:16px;padding:3rem 2rem;box-shadow:0 4px 24px #00000014;border:1px solid rgba(0,0,0,.06)}.error-icon{display:flex;justify-content:center;margin-bottom:1.5rem;color:#dc2626}.error-icon svg{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.error-title{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin:0 0 .75rem;font-family:var(--font-body, system-ui, -apple-system, sans-serif)}.error-message{color:#64748b;font-size:1rem;line-height:1.5;margin:0 0 1.5rem}.error-details{text-align:left;margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid rgba(0,0,0,.06)}.error-details summary{cursor:pointer;font-weight:500;color:#64748b;font-size:.875rem;margin-bottom:.5rem}.error-stack{font-family:var(--font-mono, "SF Mono", Monaco, Consolas, monospace);font-size:.75rem;color:#dc2626;white-space:pre-wrap;word-break:break-all;margin:0;padding:.75rem;background:#fff;border-radius:4px;max-height:200px;overflow-y:auto}.error-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.error-btn{padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;border:none;font-family:var(--font-body, system-ui, -apple-system, sans-serif)}.error-btn-primary{background:linear-gradient(135deg,#059669,#047857);color:#fff}.error-btn-primary:hover{background:linear-gradient(135deg,#047857,#065f46);transform:translateY(-1px);box-shadow:0 4px 12px #0596694d}.error-btn-secondary{background:#fff;color:#1a1a1a;border:1px solid rgba(0,0,0,.12)}.error-btn-secondary:hover{background:#f8f9fa;border-color:#0003}@media(max-width:480px){.error-boundary-content{padding:2rem 1.5rem}.error-actions{flex-direction:column}.error-btn{width:100%}}.empty-state-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;background:#fff9;border:1px dashed rgba(0,0,0,.12);border-radius:12px;min-height:200px}.empty-state-icon{font-size:3rem;color:#94a3b8;margin-bottom:1rem;opacity:.8}.empty-state-icon svg{width:48px;height:48px;stroke:currentColor}.empty-state-title{font-size:1.125rem;font-weight:600;color:#1a1a1a;margin:0 0 .5rem;font-family:var(--font-body, system-ui, -apple-system, sans-serif)}.empty-state-message{font-size:.875rem;color:#64748b;margin:0 0 1.5rem;max-width:320px;line-height:1.5}.empty-state-action{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#059669,#047857);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:var(--font-body, system-ui, -apple-system, sans-serif)}.empty-state-action:hover{background:linear-gradient(135deg,#047857,#065f46);transform:translateY(-1px);box-shadow:0 4px 12px #05966940}.table-empty-state{padding:2rem 1rem}.table-empty-state .empty-state-icon{font-size:2rem;margin-bottom:.75rem}.table-empty-state .empty-state-title{font-size:1rem}.table-empty-state .empty-state-message{font-size:.8125rem}.skeleton-base{background:linear-gradient(90deg,#0000000f 25%,#0000001a,#0000000f 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}.skeleton-kpi-card{background:#fffc;border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.skeleton-kpi-header{display:flex;align-items:center;gap:.75rem}.skeleton-kpi-value{margin:.5rem 0}.skeleton-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}@media(min-width:768px){.skeleton-kpi-grid{grid-template-columns:repeat(4,1fr)}}.skeleton-table-container{background:#fffc;border:1px solid rgba(0,0,0,.08);border-radius:12px;overflow:hidden;margin-top:1rem}.skeleton-table{width:100%;border-collapse:collapse}.skeleton-table th,.skeleton-table td{padding:1rem;text-align:left;border-bottom:1px solid rgba(0,0,0,.05)}.skeleton-table th{background:#00000005}.skeleton-table-row td{padding:1rem}.skeleton-chart{background:#fffc;border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:1.5rem;margin-top:1rem;display:flex;flex-direction:column;justify-content:flex-end}.skeleton-chart-bars{display:flex;align-items:flex-end;justify-content:space-around;height:calc(100% - 30px);gap:1rem;padding:0 2rem}.skeleton-bar{flex:1;max-width:60px;background:linear-gradient(90deg,#0000000f 25%,#0000001a,#0000000f 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px 4px 0 0}.skeleton-chart-axis{margin-top:1rem;padding-top:.5rem}.skeleton-section-header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.skeleton-dashboard{padding:1.5rem;max-width:1400px;margin:0 auto}.skeleton-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(0,0,0,.08)}.skeleton-header-text{display:flex;flex-direction:column;gap:.5rem}.skeleton-section{margin-bottom:2rem}@media(max-width:640px){.skeleton-kpi-grid{grid-template-columns:repeat(2,1fr)}.skeleton-kpi-card{padding:1rem}.skeleton-chart-bars{padding:0 1rem}.skeleton-bar{max-width:40px}}.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:var(--font-mono)}.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:var(--font-mono);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:var(--font-mono);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:var(--font-mono)}.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:var(--font-mono);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:var(--font-mono);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:1.5rem;background:linear-gradient(145deg,#fffffff2,#fafaf8fa,#f5f5f3f2);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(212,175,55,.2);border-radius:20px;box-shadow:0 8px 32px #00000014,0 4px 16px #0000000a,0 2px 8px #00000005,inset 0 1px #ffffffe6,inset 0 -1px #d4af3714;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.radial-gauge:before{content:"";position:absolute;top:0;left:20%;right:20%;height:3px;background:linear-gradient(90deg,transparent 0%,var(--oilserv-gold) 30%,var(--oilserv-gold-light) 50%,var(--oilserv-gold) 70%,transparent 100%);border-radius:0 0 2px 2px;opacity:.7}.radial-gauge:hover{transform:translateY(-4px);border-color:#d4af3759;box-shadow:0 16px 48px #0000001f,0 8px 24px #00000014,0 4px 12px #0000000a,0 0 20px #d4af3726,inset 0 1px #fffffff2,inset 0 -1px #d4af371f}.radial-gauge:hover:before{opacity:1}.radial-gauge__svg{display:block;margin-bottom:.5rem}.radial-gauge__track{fill:none;stroke:#0000000f;stroke-linecap:round}.radial-gauge__progress{fill:none;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.radial-gauge__inner-circle{fill:linear-gradient(180deg,rgba(255,255,255,.9) 0%,rgba(245,245,245,.95) 100%);fill:url(#inner-fill)}.radial-gauge__inner-circle{fill:#ffffffd9;filter:drop-shadow(0 2px 4px rgba(0,0,0,.08))}.radial-gauge__highlight{fill:#fff6;filter:blur(8px)}.radial-gauge__tick{stroke:#d4af3766;stroke-linecap:round}.radial-gauge__status-dot{filter:drop-shadow(0 0 4px currentColor);transition:all .3s ease}.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-top:.25rem}.radial-gauge__value{font-family:var(--font-display, "Archivo", system-ui, sans-serif);font-weight:800;line-height:1;letter-spacing:-.03em;color:var(--text-primary, #1A1A1A);text-shadow:0 1px 2px rgba(0,0,0,.08)}.radial-gauge__label{font-family:var(--font-display, "Archivo", system-ui, sans-serif);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary, #525252);margin-top:.375rem;opacity:.85}.radial-gauge__subtitle{font-family:var(--font-body, "IBM Plex Sans", system-ui, sans-serif);font-size:.75rem;color:var(--text-tertiary, #737373);margin-top:.25rem;opacity:.8}.radial-gauge--good .radial-gauge__value{color:var(--pipeline-green, #059669)}.radial-gauge--good .radial-gauge__status-dot{animation:pulse-good 2s ease-in-out infinite}@keyframes pulse-good{0%,to{filter:drop-shadow(0 0 4px rgba(5,150,105,.6));transform:scale(1)}50%{filter:drop-shadow(0 0 8px rgba(5,150,105,.8));transform:scale(1.1)}}.radial-gauge--warning .radial-gauge__value{color:var(--natural-gas-amber, #D97706)}.radial-gauge--warning .radial-gauge__status-dot{animation:pulse-warning 1.5s ease-in-out infinite}@keyframes pulse-warning{0%,to{filter:drop-shadow(0 0 4px rgba(217,119,6,.6));transform:scale(1)}50%{filter:drop-shadow(0 0 10px rgba(217,119,6,.9));transform:scale(1.15)}}.radial-gauge--critical .radial-gauge__value{color:var(--emergency-red, #DC2626);animation:value-pulse-critical 2s ease-in-out infinite}.radial-gauge--critical{border-color:#dc262640;box-shadow:0 8px 32px #dc26261a,0 4px 16px #0000000a,inset 0 1px #ffffffe6}.radial-gauge--critical .radial-gauge__status-dot{animation:pulse-critical 1s ease-in-out infinite}@keyframes pulse-critical{0%,to{filter:drop-shadow(0 0 6px rgba(220,38,38,.7));transform:scale(1)}50%{filter:drop-shadow(0 0 12px rgba(220,38,38,1));transform:scale(1.2)}}@keyframes value-pulse-critical{0%,to{opacity:1}50%{opacity:.85}}.radial-gauge--info .radial-gauge__value{color:var(--oilserv-gold-dark, #B8941F)}.radial-gauge--info .radial-gauge__status-dot{animation:pulse-info 2.5s ease-in-out infinite}@keyframes pulse-info{0%,to{filter:drop-shadow(0 0 4px rgba(212,175,55,.5));transform:scale(1)}50%{filter:drop-shadow(0 0 8px rgba(212,175,55,.7));transform:scale(1.08)}}.radial-gauge--sm{min-width:190px;min-height:200px;padding:1.25rem}.radial-gauge--md{min-width:230px;min-height:250px;padding:1.5rem}.radial-gauge--lg{min-width:300px;min-height:320px;padding:2rem}@media(max-width:768px){.radial-gauge{padding:1rem}.radial-gauge--lg{min-width:220px;min-height:240px}.radial-gauge--lg .radial-gauge__svg{width:180px;height:180px}}@media(max-width:480px){.radial-gauge--md{min-width:180px;min-height:200px}.radial-gauge--md .radial-gauge__svg{width:150px;height:150px}}@keyframes gauge-fill{0%{stroke-dashoffset:var(--circumference)}}.radial-gauge__progress{animation:gauge-fill 1.2s cubic-bezier(.4,0,.2,1) forwards}@media(prefers-reduced-motion:reduce){.radial-gauge,.radial-gauge__progress,.radial-gauge__status-dot,.radial-gauge--critical .radial-gauge__value{transition-duration:.01ms!important;animation-duration:.01ms!important;animation:none!important}.radial-gauge:hover{transform:none}}@media print{.radial-gauge{background:#fff;box-shadow:none;border:1px solid #e5e5e5}.radial-gauge:before{display:none}.radial-gauge__status-dot{animation:none}}.animated-gauge{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-md, 1rem);gap:var(--spacing-sm, .5rem)}.animated-gauge__container{display:flex;align-items:center;justify-content:center;aspect-ratio:1}.animated-gauge__container svg{width:100%!important;height:100%!important}.animated-gauge__footer{display:flex;flex-direction:column;align-items:center;gap:.25rem;text-align:center}.animated-gauge__label{font-family:var(--font-display, "Archivo", sans-serif);font-weight:600;color:var(--text-primary, #1A1A1A);font-size:var(--gauge-label-size, 1rem);letter-spacing:-.01em}.animated-gauge__subtitle{font-family:var(--font-body, "IBM Plex Sans", sans-serif);font-weight:400;color:var(--text-secondary, #525252);font-size:var(--gauge-subtitle-size, .875rem)}.animated-gauge--sm{--gauge-size-sm: 150px;--gauge-value-size: 24px;--gauge-label-size: .875rem;--gauge-subtitle-size: .75rem;--gauge-tick-size: 10px}.animated-gauge--md{--gauge-size-md: 200px;--gauge-value-size: 32px;--gauge-label-size: 1rem;--gauge-subtitle-size: .875rem;--gauge-tick-size: 12px}.animated-gauge--lg{--gauge-size-lg: 280px;--gauge-value-size: 40px;--gauge-label-size: 1.125rem;--gauge-subtitle-size: .9375rem;--gauge-tick-size: 14px}.animated-gauge--xl{--gauge-size-xl: 400px;--gauge-value-size: 56px;--gauge-label-size: 1.5rem;--gauge-subtitle-size: 1.125rem;--gauge-tick-size: 16px}@media(min-width:1366px){.animated-gauge--sm{--gauge-size-sm: 130px;--gauge-value-size: 22px}.animated-gauge--md{--gauge-size-md: 170px;--gauge-value-size: 28px}.animated-gauge--lg{--gauge-size-lg: 220px;--gauge-value-size: 36px}.animated-gauge--xl{--gauge-size-xl: 320px;--gauge-value-size: 48px}}@media(min-width:1440px){.animated-gauge--sm{--gauge-size-sm: 140px;--gauge-value-size: 24px}.animated-gauge--md{--gauge-size-md: 180px;--gauge-value-size: 30px}.animated-gauge--lg{--gauge-size-lg: 240px;--gauge-value-size: 38px}.animated-gauge--xl{--gauge-size-xl: 360px;--gauge-value-size: 52px}}@media(min-width:1680px){.animated-gauge--sm{--gauge-size-sm: 150px;--gauge-value-size: 26px}.animated-gauge--md{--gauge-size-md: 200px;--gauge-value-size: 32px}.animated-gauge--lg{--gauge-size-lg: 280px;--gauge-value-size: 42px}.animated-gauge--xl{--gauge-size-xl: 400px;--gauge-value-size: 56px}}@media(min-width:1920px){.animated-gauge--sm{--gauge-size-sm: 160px;--gauge-value-size: 28px}.animated-gauge--md{--gauge-size-md: 220px;--gauge-value-size: 36px}.animated-gauge--lg{--gauge-size-lg: 320px;--gauge-value-size: 48px}.animated-gauge--xl{--gauge-size-xl: 450px;--gauge-value-size: 64px}.animated-gauge__label{font-size:1.125rem}.animated-gauge__subtitle{font-size:1rem}}@media(min-width:2560px){.animated-gauge--sm{--gauge-size-sm: 200px;--gauge-value-size: 32px}.animated-gauge--md{--gauge-size-md: 280px;--gauge-value-size: 44px}.animated-gauge--lg{--gauge-size-lg: 400px;--gauge-value-size: 60px}.animated-gauge--xl{--gauge-size-xl: 550px;--gauge-value-size: 80px}.animated-gauge__label{font-size:1.25rem}.animated-gauge__subtitle{font-size:1.125rem}.animated-gauge{padding:1.5rem;gap:.75rem}}@media(min-width:3840px){.animated-gauge--sm{--gauge-size-sm: 280px;--gauge-value-size: 44px}.animated-gauge--md{--gauge-size-md: 400px;--gauge-value-size: 64px}.animated-gauge--lg{--gauge-size-lg: 550px;--gauge-value-size: 84px}.animated-gauge--xl{--gauge-size-xl: 750px;--gauge-value-size: 110px}.animated-gauge__label{font-size:1.5rem}.animated-gauge__subtitle{font-size:1.25rem}.animated-gauge{padding:2rem;gap:1rem}}@media(min-width:5120px){.animated-gauge--sm{--gauge-size-sm: 350px;--gauge-value-size: 56px}.animated-gauge--md{--gauge-size-md: 500px;--gauge-value-size: 80px}.animated-gauge--lg{--gauge-size-lg: 700px;--gauge-value-size: 110px}.animated-gauge--xl{--gauge-size-xl: 950px;--gauge-value-size: 140px}.animated-gauge__label{font-size:2rem}.animated-gauge__subtitle{font-size:1.5rem}.animated-gauge{padding:3rem;gap:1.5rem}}.animated-gauge{animation:fadeInGauge .5s ease-out}@keyframes fadeInGauge{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animated-gauge:hover .animated-gauge__container{transform:scale(1.02);transition:transform .3s ease-out}@media print{.animated-gauge--sm{--gauge-size-sm: 100px;--gauge-value-size: 16px}.animated-gauge--md{--gauge-size-md: 120px;--gauge-value-size: 18px}.animated-gauge--lg{--gauge-size-lg: 150px;--gauge-value-size: 22px}.animated-gauge--xl{--gauge-size-xl: 180px;--gauge-value-size: 26px}.animated-gauge__label{font-size:10pt}.animated-gauge__subtitle{font-size:8pt}}.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}}.commitment-drawer-backdrop{--drawer-gold: #D4AF37;--drawer-gold-dark: #B8941F;--drawer-gold-light: #E8C547;--drawer-petroleum: #1A1F2E;--drawer-surface: rgba(250, 248, 244, .98);--drawer-surface-elevated: rgba(255, 255, 255, .95);--drawer-border: rgba(212, 175, 55, .25);--drawer-text: #2D3748;--drawer-text-secondary: #64748B;--drawer-success: #059669;--drawer-shadow: 0 25px 50px -12px rgba(0, 0, 0, .25)}.commitment-drawer-backdrop{position:fixed;inset:0;z-index:9999;display:flex;justify-content:flex-end;background:#1a1f2e99;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:backdropFadeIn .3s ease-out}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.commitment-drawer{position:relative;width:100%;max-width:950px;height:100%;background:var(--drawer-surface);box-shadow:var(--drawer-shadow);display:flex;flex-direction:column;transform:translate(100%);transition:transform .4s cubic-bezier(.32,.72,0,1);overflow:hidden}.commitment-drawer--open{transform:translate(0)}.commitment-drawer:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--drawer-gold) 0%,var(--drawer-gold-light) 25%,var(--drawer-gold) 50%,var(--drawer-gold-light) 75%,var(--drawer-gold) 100%);background-size:200% 100%;animation:goldShimmer 3s ease-in-out infinite}@keyframes goldShimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.drawer-header{padding:1.5rem 1.5rem 1.25rem;background:var(--drawer-surface-elevated);border-bottom:1px solid var(--drawer-border);flex-shrink:0}.drawer-header-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}.drawer-title-row{display:flex;align-items:center;gap:1rem}.drawer-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--drawer-gold) 0%,var(--drawer-gold-dark) 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #d4af374d}.drawer-icon svg{width:24px;height:24px;color:#fff}.drawer-title-text{flex:1}.drawer-title{margin:0;font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--drawer-text);line-height:1.2}.drawer-subtitle{margin:.25rem 0 0;font-size:.875rem;color:var(--drawer-text-secondary);font-weight:500}.drawer-close-btn{width:40px;height:40px;border-radius:10px;background:#d4af3714;border:1px solid var(--drawer-border);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.drawer-close-btn svg{width:20px;height:20px;color:var(--drawer-text-secondary);transition:color .2s ease}.drawer-close-btn:hover{background:#dc26261a;border-color:#dc26264d}.drawer-close-btn:hover svg{color:#dc2626}.drawer-search-container{position:relative;display:flex;align-items:center}.drawer-search-icon{position:absolute;left:1rem;pointer-events:none}.drawer-search-icon svg{width:18px;height:18px;color:var(--drawer-text-secondary)}.drawer-search-input{width:100%;padding:.875rem 2.75rem;font-family:inherit;font-size:.9375rem;color:var(--drawer-text);background:#fff;border:2px solid var(--drawer-border);border-radius:10px;transition:all .2s ease}.drawer-search-input::-moz-placeholder{color:#94a3b8}.drawer-search-input::placeholder{color:#94a3b8}.drawer-search-input:hover{border-color:#d4af3766}.drawer-search-input:focus{outline:none;border-color:var(--drawer-gold);box-shadow:0 0 0 3px #d4af3726}.drawer-search-clear{position:absolute;right:.75rem;width:24px;height:24px;border-radius:6px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.drawer-search-clear svg{width:14px;height:14px;color:var(--drawer-text-secondary)}.drawer-search-clear:hover{background:#0000000d}.drawer-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.25rem;background:linear-gradient(180deg,#faf8f400,#d4af3705)}.drawer-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.25rem}.drawer-stat{background:#fff;border:1px solid var(--drawer-border);border-radius:10px;padding:1rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.drawer-stat:hover{transform:translateY(-2px);box-shadow:0 4px 12px #d4af3726}.drawer-stat-value{display:block;font-family:var(--font-mono);font-size:1.25rem;font-weight:700;color:var(--drawer-gold-dark);line-height:1.2}.drawer-stat-label{display:block;font-size:.75rem;color:var(--drawer-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.drawer-table-wrapper{background:#fff;border:1px solid var(--drawer-border);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000a}.drawer-table{width:100%;border-collapse:collapse;font-size:.875rem}.drawer-table thead{background:linear-gradient(180deg,#d4af3714,#d4af370a);position:sticky;top:0;z-index:10}.drawer-table th{padding:.875rem 1rem;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--drawer-gold-dark);border-bottom:2px solid var(--drawer-border);white-space:nowrap}.drawer-table th.col-value{text-align:right}.drawer-table-row{animation:rowSlideIn .4s ease-out forwards;opacity:0;transform:translate(-10px);border-bottom:1px solid rgba(212,175,55,.1);transition:background .15s ease}.drawer-table-row:hover{background:#d4af370a}@keyframes rowSlideIn{to{opacity:1;transform:translate(0)}}.drawer-table td{padding:.875rem 1rem;vertical-align:middle}.col-po{width:12%}.col-item{width:6%;text-align:center}.col-desc{width:25%}.col-value{width:14%;text-align:right}.col-wbs{width:18%}.col-vendor{width:13%}.col-date{width:12%}.po-desc{font-size:.8125rem;color:var(--drawer-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;display:block;cursor:help}.po-number{font-family:var(--font-mono);font-weight:600;color:var(--drawer-text);font-size:.8125rem}.po-item-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:.25rem .5rem;background:#d4af371a;border-radius:6px;font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--drawer-gold-dark)}.po-value{font-family:var(--font-mono);font-weight:700;color:var(--drawer-success);font-size:.875rem}.wbs-code,.vendor-code{font-family:var(--font-mono);font-size:.8125rem;color:var(--drawer-text-secondary)}.po-date{font-size:.8125rem;color:var(--drawer-text-secondary)}.drawer-cards-mobile{display:none}.drawer-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.drawer-loading-spinner{width:48px;height:48px;border:3px solid rgba(212,175,55,.2);border-top-color:var(--drawer-gold);border-radius:50%;animation:spinnerRotate .8s linear infinite}@keyframes spinnerRotate{to{transform:rotate(360deg)}}.drawer-loading p{font-size:.9375rem;color:var(--drawer-text-secondary);margin:0}.drawer-error{display:flex;flex-direction:column;align-items:center;padding:4rem 2rem;text-align:center}.drawer-error-icon{width:56px;height:56px;border-radius:50%;background:#dc26261a;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#dc2626;margin-bottom:1rem}.drawer-error h3{margin:0 0 .5rem;font-size:1.25rem;color:var(--drawer-text)}.drawer-error p{margin:0;color:var(--drawer-text-secondary)}.drawer-empty{display:flex;flex-direction:column;align-items:center;padding:4rem 2rem;text-align:center}.drawer-empty-icon{width:64px;height:64px;margin-bottom:1rem}.drawer-empty-icon svg{width:100%;height:100%;color:var(--drawer-gold);opacity:.5}.drawer-empty h3{margin:0 0 .5rem;font-size:1.25rem;color:var(--drawer-text)}.drawer-empty p{margin:0;color:var(--drawer-text-secondary)}.drawer-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--drawer-surface-elevated);border-top:1px solid var(--drawer-border);flex-shrink:0}.drawer-pagination-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#fff;border:1px solid var(--drawer-border);border-radius:8px;font-family:inherit;font-size:.875rem;font-weight:500;color:var(--drawer-text);cursor:pointer;transition:all .2s ease}.drawer-pagination-btn svg{width:16px;height:16px}.drawer-pagination-btn:hover:not(:disabled){background:#d4af3714;border-color:var(--drawer-gold);color:var(--drawer-gold-dark)}.drawer-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.drawer-pagination-info{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--drawer-text-secondary)}.pagination-current{font-weight:600;color:var(--drawer-gold-dark)}@media(max-width:900px){.commitment-drawer{max-width:100%}.col-vendor,.col-date{display:none}.col-po{width:30%}.col-item{width:12%}.col-value{width:30%}.col-wbs{width:28%}}@media(max-width:640px){.commitment-drawer-backdrop{justify-content:center;align-items:flex-end}.commitment-drawer{max-width:100%;height:95vh;border-radius:20px 20px 0 0;transform:translateY(100%)}.commitment-drawer--open{transform:translateY(0)}.commitment-drawer:after{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:36px;height:4px;background:#00000026;border-radius:2px}.drawer-header{padding:1.75rem 1rem 1rem}.drawer-icon{width:40px;height:40px;border-radius:10px}.drawer-icon svg{width:20px;height:20px}.drawer-title{font-size:1.25rem}.drawer-subtitle{font-size:.8125rem}.drawer-close-btn{width:36px;height:36px}.drawer-content{padding:1rem}.drawer-stats{gap:.5rem}.drawer-stat{padding:.75rem .5rem}.drawer-stat-value{font-size:1rem}.drawer-table-wrapper{display:none}.drawer-cards-mobile{display:flex;flex-direction:column;gap:.75rem}.drawer-card{background:#fff;border:1px solid var(--drawer-border);border-radius:12px;padding:1rem;animation:cardSlideUp .4s ease-out forwards;opacity:0;transform:translateY(10px)}@keyframes cardSlideUp{to{opacity:1;transform:translateY(0)}}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.card-po-number{font-family:var(--font-mono);font-weight:600;font-size:.9375rem;color:var(--drawer-text)}.card-po-item{font-size:.75rem;color:var(--drawer-text-secondary);background:#d4af371a;padding:.25rem .5rem;border-radius:4px}.card-value{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;color:var(--drawer-success);margin-bottom:.75rem}.card-details{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding-top:.75rem;border-top:1px solid rgba(212,175,55,.1)}.card-detail{display:flex;flex-direction:column;gap:.125rem}.card-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;color:var(--drawer-text-secondary)}.card-data{font-family:var(--font-mono);font-size:.75rem;color:var(--drawer-text);word-break:break-all}.drawer-footer{padding:.875rem 1rem}.drawer-pagination-btn{padding:.5rem .75rem;font-size:.8125rem}.drawer-pagination-btn span{display:none}.drawer-pagination-info{font-size:.8125rem}}.card-description{font-size:.8125rem;color:var(--drawer-text-secondary);padding:.5rem 0;border-bottom:1px solid rgba(212,175,55,.1);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}@media print{.commitment-drawer-backdrop{position:static;background:none}.commitment-drawer{max-width:100%;box-shadow:none;transform:none}.drawer-close-btn,.drawer-search-container,.drawer-footer{display:none}.drawer-table-row{animation:none;opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.commitment-drawer-backdrop,.commitment-drawer,.drawer-table-row,.drawer-card,.drawer-loading-spinner{animation-duration:.01ms!important;transition-duration:.01ms!important}.commitment-drawer:before{animation:none}}.progress-bar-container{width:100%}.progress-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.progress-bar-label{font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--text-primary)}.progress-bar-percentage{font-family:var(--font-mono);font-size:.875rem;font-weight:600;color:var(--text-secondary)}.progress-bar-track{width:100%;background:#0000000f;border-radius:999px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;border-radius:999px;transition:width .6s var(--ease-mechanical);position:relative}.progress-bar-fill.animated{animation:progressGrow .8s ease-out}.progress-bar-fill.striped{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:1rem 1rem;animation:progressStripes 1s linear infinite}@keyframes progressGrow{0%{width:0}}@keyframes progressStripes{0%{background-position:1rem 0}to{background-position:0 0}}.stacked-progress-container{width:100%}.stacked-progress-track{width:100%;background:#0000000f;border-radius:6px;overflow:hidden;position:relative}.stacked-progress-segment{position:absolute;top:0;height:100%;transition:width .6s var(--ease-mechanical)}.stacked-progress-segment:first-child{border-radius:6px 0 0 6px}.stacked-progress-segment:last-child{border-radius:0 6px 6px 0}.stacked-progress-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.75rem}.stacked-progress-legend .legend-item{display:flex;align-items:center;gap:.375rem}.stacked-progress-legend .legend-dot{width:10px;height:10px;border-radius:2px}.stacked-progress-legend .legend-label{font-family:var(--font-body);font-size:.75rem;color:var(--text-secondary)}.stacked-progress-legend .legend-value{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--text-primary)}.comparison-progress-container{width:100%}.comparison-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:1rem}.comparison-stat{display:flex;flex-direction:column;gap:.125rem}.comparison-label{font-family:var(--font-body);font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.comparison-value{font-family:var(--font-mono);font-size:1rem;font-weight:600;color:var(--text-primary)}.comparison-variance{font-family:var(--font-mono);font-size:.875rem;font-weight:700;padding:.25rem .5rem;border-radius:4px}.comparison-variance.positive{background:#0596691a;color:var(--pipeline-green)}.comparison-variance.negative{background:#dc26261a;color:var(--emergency-red)}.comparison-track{width:100%;background:#0000000a;border-radius:6px;position:relative;overflow:hidden}.comparison-bar{position:absolute;left:0;border-radius:6px;transition:width .6s var(--ease-mechanical)}.comparison-bar--planned{background:#94a3b8}.comparison-bar--actual{background:var(--pipeline-green)}.comparison-legend{display:flex;gap:1.5rem;margin-top:.75rem}.comparison-legend .legend-item{display:flex;align-items:center;gap:.375rem;font-family:var(--font-body);font-size:.75rem;color:var(--text-secondary)}.comparison-legend .legend-line{width:16px;height:4px;border-radius:2px}.comparison-legend .legend-line--planned{background:#94a3b8}.comparison-legend .legend-line--actual{background:var(--pipeline-green)}@media(max-width:640px){.stacked-progress-legend{flex-direction:column;gap:.5rem}.comparison-header{flex-wrap:wrap}}.standard-bar-chart{width:100%;font-family:var(--font-body)}.bar-chart-tooltip{background:#fffffffa;border:1px solid rgba(0,0,0,.08);border-radius:8px;padding:.75rem 1rem;box-shadow:0 4px 12px #00000026;min-width:140px}.bar-chart-tooltip .tooltip-title{font-family:var(--font-display);font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(0,0,0,.06)}.bar-chart-tooltip .tooltip-row{display:flex;align-items:center;gap:.5rem;margin:.25rem 0}.bar-chart-tooltip .tooltip-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}.bar-chart-tooltip .tooltip-label{font-size:.8125rem;color:var(--text-secondary);flex:1}.bar-chart-tooltip .tooltip-value{font-family:var(--font-mono);font-size:.8125rem;font-weight:600;color:var(--text-primary)}.bar-chart-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:1rem}.bar-chart-legend .legend-item{display:flex;align-items:center;gap:.5rem}.bar-chart-legend .legend-color{width:14px;height:14px;border-radius:3px}.bar-chart-legend .legend-text{font-size:.8125rem;color:var(--text-secondary)}.mini-bar{background:#0000000f;border-radius:4px;overflow:hidden}.mini-bar-fill{height:100%;border-radius:4px;transition:width .4s ease-out}@media(max-width:640px){.bar-chart-legend{gap:1rem}.bar-chart-tooltip{min-width:120px}}.scurve-container{width:100%;font-family:var(--font-body)}.scurve-header{margin-bottom:1rem}.scurve-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.scurve-subtitle{font-size:.875rem;color:var(--text-secondary);margin:0}.scurve-status-banner{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-radius:10px;margin-bottom:1.5rem;background:linear-gradient(135deg,#3b82f614,#3b82f605);border:1px solid rgba(59,130,246,.15)}.scurve-status-banner--ahead{background:linear-gradient(135deg,#10b98114,#10b98105);border-color:#10b98133}.scurve-status-banner--behind{background:linear-gradient(135deg,#f59e0b14,#f59e0b05);border-color:#f59e0b33}.scurve-status-banner--critical{background:linear-gradient(135deg,#ef444414,#ef444405);border-color:#ef444433}.status-indicator{display:flex;align-items:center;gap:.75rem}.status-icon{font-size:1.25rem;line-height:1}.scurve-status-banner--ahead .status-icon{color:#10b981}.scurve-status-banner--on-track .status-icon{color:#3b82f6}.scurve-status-banner--behind .status-icon{color:#f59e0b}.scurve-status-banner--critical .status-icon{color:#ef4444}.status-label{font-family:var(--font-display);font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.scurve-status-banner--ahead .status-label{color:#059669}.scurve-status-banner--on-track .status-label{color:#2563eb}.scurve-status-banner--behind .status-label{color:#d97706}.scurve-status-banner--critical .status-label{color:#dc2626}.status-variance{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.variance-value{font-family:var(--font-mono);font-size:1.25rem;font-weight:700}.scurve-status-banner--ahead .variance-value{color:#059669}.scurve-status-banner--on-track .variance-value{color:#2563eb}.scurve-status-banner--behind .variance-value{color:#d97706}.scurve-status-banner--critical .variance-value{color:#dc2626}.variance-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary)}.scurve-chart{width:100%;min-height:300px}.scurve-tooltip{background:#fffffffa;border:1px solid rgba(0,0,0,.08);border-radius:8px;padding:.75rem 1rem;box-shadow:0 4px 12px #00000026;min-width:160px}.scurve-tooltip .tooltip-header{font-family:var(--font-display);font-size:.8125rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(0,0,0,.06)}.scurve-tooltip .tooltip-row{display:flex;align-items:center;gap:.5rem;margin:.375rem 0}.scurve-tooltip .tooltip-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}.scurve-tooltip .tooltip-label{font-size:.8125rem;color:var(--text-secondary);flex:1}.scurve-tooltip .tooltip-value{font-family:var(--font-mono);font-size:.8125rem;font-weight:600;color:var(--text-primary)}.scurve-legend{display:flex;justify-content:center;gap:2rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.06)}.scurve-legend .legend-item{display:flex;align-items:center;gap:.5rem}.scurve-legend .legend-line{width:24px;height:3px;border-radius:2px}.scurve-legend .legend-line--planned{background:#94a3b8;background-image:repeating-linear-gradient(90deg,#94A3B8 0,#94A3B8 6px,transparent 6px,transparent 10px)}.scurve-legend .legend-line--actual{background:#10b981}.scurve-legend .legend-item span:last-child{font-size:.8125rem;color:var(--text-secondary)}@media(max-width:640px){.scurve-status-banner{flex-direction:column;gap:1rem;text-align:center}.status-variance{align-items:center}.scurve-legend{flex-direction:column;align-items:center;gap:.75rem}}.ccurve-container{width:100%;font-family:var(--font-body)}.ccurve-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.ccurve-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.ccurve-summary{display:flex;gap:1.5rem;flex-wrap:wrap}.summary-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem 1rem;background:#00000005;border-radius:8px;border:1px solid rgba(0,0,0,.04)}.summary-item--highlight{background:#3b82f60d;border-color:#3b82f626}.summary-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}.summary-value{font-family:var(--font-mono);font-size:1.125rem;font-weight:700;color:var(--text-primary)}.summary-value.positive{color:#059669}.summary-value.negative{color:#dc2626}.ccurve-chart{width:100%;min-height:350px}.ccurve-tooltip{background:#fffffffa;border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:.875rem 1rem;box-shadow:0 4px 16px #00000026;min-width:180px}.ccurve-tooltip .tooltip-header{font-family:var(--font-display);font-size:.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(0,0,0,.06)}.ccurve-tooltip .tooltip-section{margin-bottom:.75rem}.ccurve-tooltip .tooltip-section:last-child{margin-bottom:0}.ccurve-tooltip .tooltip-section-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:.375rem}.ccurve-tooltip .tooltip-row{display:flex;align-items:center;gap:.5rem;margin:.25rem 0}.ccurve-tooltip .tooltip-row--net{padding-top:.375rem;margin-top:.375rem;border-top:1px dashed rgba(0,0,0,.08)}.ccurve-tooltip .tooltip-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.ccurve-tooltip .tooltip-label{font-size:.8125rem;color:var(--text-secondary);flex:1}.ccurve-tooltip .tooltip-value{font-family:var(--font-mono);font-size:.8125rem;font-weight:600;color:var(--text-primary)}.ccurve-tooltip .tooltip-value.positive{color:#059669}.ccurve-tooltip .tooltip-value.negative{color:#dc2626}.ccurve-status{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;border-radius:8px;margin-top:1rem;font-size:.875rem;font-weight:600}.ccurve-status.positive{background:#10b98114;color:#059669}.ccurve-status.negative{background:#ef444414;color:#dc2626}.status-icon{font-size:1rem}@media(max-width:768px){.ccurve-header{flex-direction:column}.ccurve-summary{width:100%;justify-content:space-between}.summary-item{flex:1;min-width:100px}}@media(max-width:640px){.ccurve-summary{flex-direction:column}.summary-item{flex-direction:row;justify-content:space-between;align-items:center}}.budget-waterfall-container{--gold-primary: #D4AF37;--gold-dark: #B8941F;--slate-900: #0f172a;--slate-700: #334155;--slate-500: #64748B;--slate-200: #e2e8f0;--font-display: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;background:#fff;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000000a,0 10px 40px #0000000f;animation:fadeSlideIn .5s ease-out}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.waterfall-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid var(--slate-200)}.summary-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:linear-gradient(135deg,#f8fafccc,#ffffffe6);border-radius:12px;border:1px solid rgba(0,0,0,.04);transition:all .25s ease}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #00000014;border-color:var(--gold-primary)}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-content{display:flex;flex-direction:column;gap:.25rem;min-width:0}.summary-label{font-size:.875rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em}.summary-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.02em}.utilization-section{margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#0f172a05,#d4af3708);border-radius:12px;border:1px solid rgba(212,175,55,.1)}.utilization-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.utilization-label{font-family:var(--font-display);font-size:.875rem;font-weight:700;color:var(--slate-900);text-transform:uppercase;letter-spacing:.05em}.utilization-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:800}.utilization-bar{margin-bottom:1rem}.utilization-track{position:relative;height:16px;background:var(--slate-200);border-radius:8px;overflow:hidden}.utilization-fill{position:absolute;top:0;height:100%;transition:width .8s ease-out}.utilization-fill--actuals{left:0;background:linear-gradient(90deg,#ef4444,#dc2626);border-radius:6px 0 0 6px;animation:fillActuals 1s ease-out forwards}.utilization-fill--commitments{background:linear-gradient(90deg,#f59e0b,#d97706);animation:fillCommitments 1s ease-out .3s forwards}@keyframes fillActuals{0%{width:0!important}}@keyframes fillCommitments{0%{width:0!important}}.utilization-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.8125rem;color:var(--slate-500);font-family:var(--font-mono);font-weight:500}.utilization-legend{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.06)}.legend-item{display:flex;align-items:center;gap:.625rem;font-size:1rem;font-weight:500;color:var(--slate-700)}.legend-dot{width:12px;height:12px;border-radius:4px}.chart-section{margin-top:1.5rem}.chart-title{font-family:var(--font-display);font-size:.8125rem;font-weight:700;color:var(--slate-900);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem;padding-left:.5rem;border-left:3px solid var(--gold-primary)}.chart-wrapper{background:#f8fafc80;border-radius:12px;padding:1rem;border:1px solid rgba(0,0,0,.03)}.waterfall-tooltip{background:#0f172af2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;padding:1rem 1.25rem;box-shadow:0 8px 32px #00000040;min-width:160px}.tooltip-title{font-family:var(--font-display);font-size:.9375rem;font-weight:700;color:#fff;margin:0 0 .25rem}.tooltip-label{font-size:.75rem;color:#fff9;margin:0 0 .75rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.tooltip-value{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;margin:0 0 .25rem}.tooltip-pct{font-size:.75rem;color:#ffffffb3;margin:0}@media(max-width:1024px){.waterfall-summary{grid-template-columns:repeat(2,1fr)}.utilization-legend{gap:1rem}}@media(max-width:768px){.budget-waterfall-container{padding:1.5rem}.waterfall-summary{grid-template-columns:1fr 1fr;gap:.75rem}.summary-card{padding:1rem;flex-direction:column;text-align:center;gap:.75rem}.summary-value{font-size:1.125rem}.utilization-legend{flex-direction:column;gap:.5rem}}@media(max-width:480px){.waterfall-summary{grid-template-columns:1fr}.summary-card{flex-direction:row;text-align:left}.summary-icon{width:40px;height:40px}.summary-value{font-size:1.25rem}.chart-wrapper{padding:.5rem}}.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}.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}}.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-color:#1e293b!important;background:#1e293b!important;border:1px solid rgba(212,175,55,.3);border-radius:8px;font-family:var(--font-body, "IBM Plex Sans", sans-serif);font-size:1rem;color:#fff!important;-webkit-text-fill-color:#ffffff!important;caret-color:#fff;transition:border-color .2s ease,box-shadow .2s ease}.form-input:-webkit-autofill,.form-input:-webkit-autofill:hover,.form-input:-webkit-autofill:focus,.form-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px #1e293b inset!important;-webkit-text-fill-color:#ffffff!important;background-color:#1e293b!important;caret-color:#fff!important;-webkit-transition:background-color 5000s ease-in-out 0s;transition:background-color 5000s ease-in-out 0s}.form-input:-webkit-autofill{background-color:#1e293b!important;color:#fff!important}.form-input:autofill{background-color:#1e293b!important;color:#fff!important}.form-input::-moz-placeholder{color:#94a3b880}.form-input::placeholder{color:#94a3b880}.form-input:focus{outline:none;border-color:var(--oilserv-gold);background-color:#1e293b!important;box-shadow:0 0 0 3px #d4af3733}.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:repeat(2,1fr);gap:1rem}.kpi-metrics-grid .kpi-card{height:120px}.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(max-width:767px){.kpi-metrics-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.kpi-metrics-grid .kpi-card{height:100px}}@media(min-width:768px){.kpi-metrics-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.kpi-metrics-grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:1440px){.portfolio-overview{padding:3rem 2rem}.kpi-metrics-grid{grid-template-columns:repeat(5,1fr);gap:1.25rem}}@media(max-width:640px){.portfolio-overview{padding:1rem .75rem;padding-bottom:calc(1rem + 72px)}.command-header{padding:1.5rem 1rem;margin-bottom:1rem;border-radius:12px}.command-header .header-content{flex-direction:column;align-items:flex-start;gap:.5rem}.command-header img{height:40px}.command-title{font-size:1.375rem;line-height:1.2}.command-subtitle{font-size:.8125rem}.control-panel{padding:1rem;gap:.75rem;border-radius:10px}.control-grid{grid-template-columns:1fr;gap:.75rem}.command-search{font-size:16px}.command-select{font-size:16px;min-height:44px}.results-badge{padding:.75rem 1rem;border-radius:8px}.badge-value{font-size:1.25rem}.badge-label{font-size:.6875rem}.project-command-card{padding:1rem;gap:1rem;border-radius:12px;-webkit-tap-highlight-color:transparent}.project-command-card:active{transform:scale(.995)}.project-title-main{font-size:1.25rem;line-height:1.3}.project-code-badge{font-size:.75rem;padding:.25rem .5rem}.kpi-metrics-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.kpi-metrics-grid .kpi-card{height:90px}.empty-command{padding:2rem 1rem;min-height:250px}.empty-icon-large{font-size:2.5rem;margin-bottom:.75rem}.empty-title{font-size:1.25rem}.empty-message{font-size:.875rem}.view-toggle-desktop{display:none}}@media(max-width:375px){.portfolio-overview{padding:.75rem .5rem}.command-title{font-size:1.25rem}.project-title-main{font-size:1.125rem}}@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-header-right{display:flex;align-items:center;gap:1rem}.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)}.chart-container{background:linear-gradient(135deg,#fffffff2,#fefefefa);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(212,175,55,.15);box-shadow:0 4px 16px #0000000a,inset 0 1px #ffffffe6;overflow:hidden}.chart-container:hover{border-color:#d4af3740;box-shadow:0 8px 24px #0000000f,inset 0 1px #ffffffe6}@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{--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}@keyframes criticalPulse{0%,to{opacity:1}50%{opacity:.85}}.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:var(--font-mono);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-x:auto;box-shadow:0 4px 16px #0000000a;-webkit-overflow-scrolling:touch}.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:var(--font-mono);font-weight:700;color:#0f172a;font-size:17px;background:#f8fafc}.variance-table td.formula{font-family:var(--font-mono);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}}@media(max-width:640px){.variance-grid{gap:16px;margin-bottom:24px}.variance-box{padding:16px}.variance-table{min-width:500px}.variance-table th,.variance-table td{padding:12px;font-size:13px}.variance-table td.code,.variance-table td.formula{font-size:13px}.variance-value{font-size:1.75rem}.variance-percent{font-size:1.25rem}.variance-summary{padding:20px}.variance-summary h3{font-size:18px}.variance-notes li{font-size:14px}}.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-gauge-section{margin-top:2rem;padding:2rem;background:linear-gradient(135deg,#fffffffa,#f8f8f8f2);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(212,175,55,.2);border-radius:16px;box-shadow:0 4px 20px #0000000f,0 2px 8px #0000000a}.evm-gauge-title{font-family:var(--font-display, "Archivo", sans-serif);font-size:.875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--oilserv-gold-dark, #B8941F);margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:1px solid rgba(212,175,55,.2)}.evm-gauge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;justify-items:center;align-items:start}.evm-gauge-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;background:#ffffff80;border-radius:12px;border:1px solid rgba(0,0,0,.04);transition:all .3s ease;width:100%;max-width:400px}.evm-gauge-wrapper:hover{background:#fffc;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}@media(max-width:1200px){.evm-gauge-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.evm-gauge-wrapper:nth-child(3){grid-column:1 / -1;max-width:400px;justify-self:center}}@media(max-width:768px){.evm-gauge-section{padding:1.25rem}.evm-gauge-grid{grid-template-columns:1fr;gap:1.25rem}.evm-gauge-wrapper:nth-child(3){grid-column:auto}}@media(min-width:2560px){.evm-gauge-section{padding:3rem}.evm-gauge-title{font-size:1rem;margin-bottom:2rem}.evm-gauge-grid{gap:3rem}.evm-gauge-wrapper{padding:1.5rem;max-width:500px}}@media(min-width:3840px){.evm-gauge-section{padding:4rem}.evm-gauge-title{font-size:1.25rem;margin-bottom:3rem}.evm-gauge-grid{gap:4rem}.evm-gauge-wrapper{padding:2rem;max-width:700px}}.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:var(--font-mono);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:var(--font-mono)}.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}.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 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 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}.doc-title{color:var(--text-secondary);font-size:.8125rem;max-width:350px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-row:hover .doc-title{color:var(--text-primary)}.status-badge{display:inline-block;padding:.3rem .75rem;border-radius:4px;font-family:var(--font-mono);font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;border:none;box-shadow:0 1px 2px #0000001a}.status-afc{background:#059669;color:#fff}.status-ifc{background:#10b981;color:#fff}.status-ifa{background:#f59e0b;color:#fff}.status-ifr{background:#3b82f6;color:#fff}.status-idc{background:#8b5cf6;color:#fff}.status-dev{background:#64748b;color:#fff}.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}}.table-container:before,.table-container:after,.document-table:before,.document-table:after{display:none!important;content:none!important}.dashboard-section .table-container:before,.dashboard-section .table-container:after{display:none!important}.document-table thead:before,.document-table tbody:before,.document-table tr:before,.document-table th:before,.document-table td:before{display:none!important;content:none!important}.document-table th:first-child,.document-table td:first-child{position:relative;z-index:1;padding-left:1rem}.dashboard-section>.section-header+.filter-bar+.table-container{margin-top:0}.table-container{position:relative;isolation:isolate}.dashboard-section:has(.document-table) .section-title:before{display:none!important}.dashboard-section:has(.document-table) .section-title{margin-left:0;padding-left:0;position:relative;z-index:10}.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}.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}.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}}.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}.col-float{width:90px;text-align:center}.schedule-drilldown .float-badge{display:inline-block;padding:.25rem .625rem;font-size:.75rem;font-weight:700;font-family:var(--font-mono);border-radius:6px;border:1px solid}.schedule-drilldown .float-critical{background:#dc262626;border-color:#dc262680;color:#dc2626}.schedule-drilldown .float-atrisk{background:#f59e0b26;border-color:#f59e0b80;color:#d97706}.schedule-drilldown .float-healthy{background:#05966926;border-color:#05966980;color:#059669}.schedule-drilldown .milestones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;margin-top:1.5rem}.schedule-drilldown .milestone-card{display:flex;gap:1rem;padding:1.25rem;background:#fffc;border:2px solid rgba(212,175,55,.2);border-radius:12px;transition:all .2s ease}.schedule-drilldown .milestone-card:hover{background:#fffffff2;border-color:#d4af3766;transform:translateY(-2px);box-shadow:0 4px 12px #d4af3726}.schedule-drilldown .milestone-complete{background:#05966914;border-color:#0596694d}.schedule-drilldown .milestone-atrisk{background:#dc26260d;border-color:#dc26264d}.schedule-drilldown .milestone-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;font-size:1.25rem;flex-shrink:0;background:#d4af3726;color:var(--oilserv-gold-dark)}.schedule-drilldown .milestone-complete .milestone-icon{background:#05966933;color:#059669}.schedule-drilldown .milestone-atrisk .milestone-icon{background:#dc262626;color:#dc2626}.schedule-drilldown .milestone-content{flex:1;min-width:0}.schedule-drilldown .milestone-name{margin:0 0 .5rem;font-family:var(--font-display);font-size:.9375rem;font-weight:600;color:var(--text-primary);line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.schedule-drilldown .milestone-details{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.schedule-drilldown .milestone-date{font-family:var(--font-mono);font-size:.8125rem;color:var(--tech-cyan);font-weight:500}.schedule-drilldown .milestone-wbs{font-size:.75rem;color:var(--text-secondary);padding:.125rem .5rem;background:#d4af371a;border-radius:4px}.schedule-drilldown .milestone-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.schedule-drilldown .milestone-status{display:inline-block;padding:.25rem .5rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:4px}.schedule-drilldown .milestone-status.status-completed,.schedule-drilldown .milestone-status.status-achieved{background:#05966926;color:#059669}.schedule-drilldown .milestone-status.status-in_progress,.schedule-drilldown .milestone-status.status-active{background:#0ea5e926;color:#0ea5e9}.schedule-drilldown .milestone-status.status-not_started,.schedule-drilldown .milestone-status.status-pending,.schedule-drilldown .milestone-status.status-planned{background:#6b728026;color:#6b7280}.schedule-drilldown .milestone-filter-controls{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#d4af3714;border:2px solid rgba(212,175,55,.2);border-radius:8px}.schedule-drilldown .filter-label{font-family:var(--font-body);font-size:.8125rem;font-weight:600;color:var(--oilserv-gold-dark)}.schedule-drilldown .milestone-status-select{padding:.5rem 2rem .5rem .75rem;font-family:var(--font-body);font-size:.8125rem;font-weight:600;color:var(--text-primary);background:#fff;border:2px solid rgba(212,175,55,.3);border-radius:6px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23B8860B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;transition:all .2s ease}.schedule-drilldown .milestone-status-select:hover{border-color:var(--oilserv-gold)}.schedule-drilldown .milestone-status-select:focus{outline:none;border-color:var(--oilserv-gold);box-shadow:0 0 0 3px #d4af3726}.schedule-drilldown .milestone-progress{font-family:var(--font-mono);font-size:.875rem;font-weight:700;color:var(--oilserv-gold-dark)}.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:1000px}.schedule-drilldown .wbs-grid,.schedule-drilldown .kpi-command-grid{grid-template-columns:1fr}}.schedule-drilldown .wbs-accordion{display:flex;flex-direction:column;gap:1rem}.schedule-drilldown .wbs-accordion-item{background:#ffffffb3;border:2px solid rgba(212,175,55,.2);border-radius:12px;overflow:hidden;transition:all .3s ease;box-shadow:0 2px 8px #0000000f}.schedule-drilldown .wbs-accordion-item:hover{border-color:#d4af3766;box-shadow:0 4px 16px #0000001a}.schedule-drilldown .wbs-accordion-header{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;cursor:pointer;background:transparent;transition:background .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.schedule-drilldown .wbs-accordion-header:hover{background:#d4af370d}.schedule-drilldown .wbs-accordion-header--expanded{background:#d4af371a;border-bottom:1px solid rgba(212,175,55,.2)}.schedule-drilldown .wbs-accordion-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:#d4af3726;color:var(--oilserv-gold-dark);flex-shrink:0;transition:transform .2s ease}.schedule-drilldown .wbs-accordion-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.schedule-drilldown .wbs-accordion-title{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.schedule-drilldown .wbs-accordion-id{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);letter-spacing:.02em}.schedule-drilldown .wbs-accordion-stats{display:flex;align-items:center;gap:1.5rem;flex-shrink:0}.schedule-drilldown .wbs-stat{display:flex;flex-direction:column;align-items:center;min-width:70px}.schedule-drilldown .wbs-stat-value{font-family:var(--font-mono);font-size:1.125rem;font-weight:700;color:var(--text-primary)}.schedule-drilldown .wbs-stat-label{font-family:var(--font-body);font-size:.65rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.schedule-drilldown .wbs-stat--critical .wbs-stat-value{color:var(--emergency-red)}.schedule-drilldown .wbs-progress-bar-mini{position:relative;width:100px;height:20px;background:#d4af371a;border:1px solid rgba(212,175,55,.3);border-radius:4px;overflow:hidden}.schedule-drilldown .wbs-progress-fill-mini{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--oilserv-gold),var(--oilserv-gold-dark));transition:width .4s ease}.schedule-drilldown .wbs-progress-text-mini{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:.7rem;font-weight:700;color:var(--text-primary);text-shadow:0 0 4px rgba(255,255,255,.9)}.schedule-drilldown .wbs-accordion-content{padding:0 1.5rem 1.5rem;background:#ffffff80}.schedule-drilldown .wbs-activities-table{width:100%;border-collapse:collapse;font-family:var(--font-body);margin-top:1rem}.schedule-drilldown .wbs-activities-table th{text-align:left;padding:.75rem 1rem;font-family:var(--font-heading);font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;background:#d4af3714;border-bottom:1px solid rgba(212,175,55,.2)}.schedule-drilldown .wbs-activities-table th:first-child{border-top-left-radius:8px}.schedule-drilldown .wbs-activities-table th:last-child{border-top-right-radius:8px}.schedule-drilldown .wbs-activities-table td{padding:.75rem 1rem;font-size:.85rem;color:var(--text-primary);border-bottom:1px solid rgba(212,175,55,.1)}.schedule-drilldown .activity-row:hover{background:#d4af370d}.schedule-drilldown .activity-row--critical{background:#dc26260a!important;border-left:3px solid var(--emergency-red)}.schedule-drilldown .activity-row--critical:hover{background:#dc262614!important}.schedule-drilldown .mini-progress-bar{position:relative;width:80px;height:16px;background:#d4af371a;border:1px solid rgba(212,175,55,.25);border-radius:4px;overflow:hidden}.schedule-drilldown .mini-progress-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--oilserv-gold),var(--oilserv-gold-dark));transition:width .3s ease}.schedule-drilldown .mini-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:.65rem;font-weight:700;color:var(--text-primary);text-shadow:0 0 3px rgba(255,255,255,.9)}.schedule-drilldown .critical-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;font-family:var(--font-mono);font-size:.65rem;font-weight:700;color:var(--emergency-red);background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:4px;text-transform:uppercase}@media(max-width:1024px){.schedule-drilldown .wbs-accordion-stats{gap:1rem}.schedule-drilldown .wbs-stat{min-width:60px}.schedule-drilldown .wbs-progress-bar-mini{width:80px}}@media(max-width:768px){.schedule-drilldown .wbs-accordion-header{flex-wrap:wrap;gap:.75rem;padding:1rem}.schedule-drilldown .wbs-accordion-info{flex:1 1 calc(100% - 50px);order:1}.schedule-drilldown .wbs-accordion-toggle{order:0}.schedule-drilldown .wbs-accordion-stats{order:2;width:100%;justify-content:space-between;padding-top:.75rem;border-top:1px dashed rgba(212,175,55,.2)}.schedule-drilldown .wbs-activities-table{display:block;overflow-x:auto}.schedule-drilldown .wbs-activities-table th,.schedule-drilldown .wbs-activities-table td{padding:.5rem .75rem;font-size:.8rem;white-space:nowrap}}.schedule-drilldown .pagination-controls{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#d4af370d;border-top:2px solid rgba(212,175,55,.15);gap:1rem;flex-wrap:wrap}.schedule-drilldown .pagination-info{font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--text-secondary)}.schedule-drilldown .pagination-buttons{display:flex;align-items:center;gap:.5rem}.schedule-drilldown .pagination-btn{padding:.5rem 1rem;font-family:var(--font-body);font-size:.8125rem;font-weight:600;background:#fffc;color:var(--oilserv-gold-dark);border:2px solid rgba(212,175,55,.3);border-radius:6px;cursor:pointer;transition:all .2s ease}.schedule-drilldown .pagination-btn:hover:not(:disabled){background:var(--oilserv-gold);color:#fff;border-color:var(--oilserv-gold)}.schedule-drilldown .pagination-btn:disabled{opacity:.4;cursor:not-allowed}.schedule-drilldown .pagination-page{font-family:var(--font-mono);font-size:.875rem;font-weight:700;color:var(--oilserv-gold-dark);padding:0 1rem}@media(max-width:768px){.schedule-drilldown .pagination-controls{flex-direction:column;align-items:stretch;text-align:center}.schedule-drilldown .pagination-buttons{flex-wrap:wrap;justify-content:center}.schedule-drilldown .pagination-btn{padding:.5rem .75rem;font-size:.75rem}}.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:var(--font-mono);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:var(--font-mono);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:var(--font-mono);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-rag-hero-section{margin-bottom:2rem}.cfo-rag-hero{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem;padding:2rem 2.5rem;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:3px solid var(--border-color);border-radius:16px;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}.cfo-rag-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--border-color)}.cfo-rag-hero--green{border-color:#10b98166}.cfo-rag-hero--green:before{background:linear-gradient(90deg,#10b981,#34d399,#10b981)}.cfo-rag-hero--amber{border-color:#f59e0b66}.cfo-rag-hero--amber:before{background:linear-gradient(90deg,#f59e0b,#fbbf24,#f59e0b)}.cfo-rag-hero--red{border-color:#dc262666}.cfo-rag-hero--red:before{background:linear-gradient(90deg,#dc2626,#ef4444,#dc2626)}.rag-traffic-light{display:flex;flex-direction:column;align-items:center;gap:.75rem}.traffic-light-indicator{width:72px;height:72px;border-radius:50%;border:4px solid rgba(255,255,255,.9);box-shadow:0 0 30px var(--rag-glow, rgba(0,0,0,.1));transition:all .3s ease}.traffic-light-indicator--green{background:#10b981;--rag-glow: rgba(16, 185, 129, .5)}.traffic-light-indicator--amber{background:#f59e0b;--rag-glow: rgba(245, 158, 11, .5);animation:rag-pulse 2s ease-in-out infinite}.traffic-light-indicator--red{background:#dc2626;--rag-glow: rgba(220, 38, 38, .5);animation:rag-pulse 1.5s ease-in-out infinite}@keyframes rag-pulse{0%,to{box-shadow:0 0 30px var(--rag-glow)}50%{box-shadow:0 0 50px var(--rag-glow),0 0 70px var(--rag-glow)}}.traffic-light-label{font-family:var(--font-mono);font-size:1.25rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em}.cfo-rag-hero--green .traffic-light-label{color:#059669}.cfo-rag-hero--amber .traffic-light-label{color:#d97706}.cfo-rag-hero--red .traffic-light-label{color:#b91c1c}.rag-hero-metrics{display:flex;gap:3rem}.rag-metric{display:flex;flex-direction:column}.rag-metric-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.rag-metric-value{font-family:var(--font-mono);font-size:2rem;font-weight:800;color:var(--text-primary);line-height:1.2}.rag-hero-message{max-width:300px;text-align:right}.message-text{font-family:var(--font-display);font-size:.875rem;color:var(--text-secondary);line-height:1.5}@media(max-width:1024px){.cfo-rag-hero{grid-template-columns:1fr;text-align:center;gap:1.5rem;padding:1.5rem}.rag-hero-metrics{justify-content:center;gap:2rem}.rag-hero-message{max-width:100%;text-align:center}}@media(max-width:640px){.rag-hero-metrics{flex-direction:column;gap:1rem;align-items:center}.traffic-light-indicator{width:56px;height:56px}.rag-metric-value{font-size:1.5rem}}.cfo-gauges-section{margin-bottom:2rem}.cfo-gauges-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}.cfo-gauge-card{background:#fffc;border-radius:12px;padding:1.5rem;border:2px solid var(--border-color);box-shadow:0 2px 8px #0000000f;transition:all .2s ease}.cfo-gauge-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.cfo-gauge-card--good{border-color:#10b981}.cfo-gauge-card--warning{border-color:#f59e0b}.cfo-gauge-card--critical{border-color:#dc2626}.cfo-gauge-card--neutral{border-color:#d4af374d}.gauge-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.gauge-icon{color:var(--text-secondary);flex-shrink:0}.cfo-gauge-card--good .gauge-icon{color:#059669}.cfo-gauge-card--warning .gauge-icon{color:#d97706}.cfo-gauge-card--critical .gauge-icon{color:#dc2626}.gauge-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.gauge-value-container{margin-bottom:.5rem}.gauge-value{font-family:var(--font-mono);font-size:2.25rem;font-weight:800;color:var(--text-primary);line-height:1}.cfo-gauge-card--good .gauge-value{color:#059669}.cfo-gauge-card--warning .gauge-value{color:#d97706}.cfo-gauge-card--critical .gauge-value{color:#dc2626}.gauge-subtitle{font-family:var(--font-body);font-size:.6875rem;color:var(--text-tertiary)}.gauge-status{font-family:var(--font-mono);font-size:.6875rem;font-weight:600;text-transform:uppercase;margin-top:.5rem}.gauge-status--green{color:#059669}.gauge-status--amber{color:#d97706}.gauge-status--red{color:#dc2626}.cfo-deep-analysis-strip{display:flex;gap:1rem;justify-content:center;padding:1.25rem;background:linear-gradient(135deg,#0596690d,#dc26260d);border:1px solid var(--border-color);border-radius:12px}.deep-analysis-btn{flex:1;max-width:280px;padding:.875rem 1.5rem;border-radius:8px;color:#fff;font-family:var(--font-display);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;text-align:center;border:none}.deep-analysis-btn--cost{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 0 20px #0596694d}.deep-analysis-btn--cost:hover{transform:translateY(-2px);box-shadow:0 4px 24px #05966966}.deep-analysis-btn--po{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 0 20px #dc26264d}.deep-analysis-btn--po:hover{transform:translateY(-2px);box-shadow:0 4px 24px #dc262666}@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-deep-analysis-strip{flex-direction:column}.deep-analysis-btn{max-width:100%}}.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}}button.cfo-kpi-card--clickable{width:100%;text-align:left;cursor:pointer;position:relative;overflow:hidden}.cfo-kpi-card--clickable:after{content:"";position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--oilserv-gold) 0%,var(--oilserv-gold-dark) 100%);opacity:0;transition:all .3s cubic-bezier(.32,.72,0,1)}.cfo-kpi-card--clickable:hover:after{opacity:1}.cfo-kpi-card--clickable:hover{border-color:var(--oilserv-gold);transform:translateY(-3px);box-shadow:0 12px 24px -4px #d4af3740,0 8px 16px -4px #d4af3726,inset 0 1px #ffffffe6}.cfo-kpi-card--clickable:active{transform:translateY(-1px)}.cfo-kpi-card--clickable:focus-visible{outline:2px solid var(--oilserv-gold);outline-offset:3px}.view-details-hint{display:inline-flex;align-items:center;gap:.25rem;font-size:.6875rem;font-weight:600;color:var(--oilserv-gold-dark);text-transform:uppercase;letter-spacing:.05em;margin-left:.5rem;padding:.125rem .375rem;background:#d4af371a;border-radius:4px;opacity:.7;transition:opacity .2s ease}.cfo-kpi-card--clickable:hover .view-details-hint{opacity:1}@media(max-width:640px){.view-details-hint{display:none}.cfo-kpi-card--clickable:after{opacity:.5;width:24px;height:24px;right:.75rem}}.cfo-po-status-section .section-badge.info{background:#2563eb1a;color:#2563eb}.cfo-loading-inline{padding:2rem;text-align:center;color:var(--intel-text-secondary, #94a3b8);font-size:.9rem;background:var(--intel-surface-secondary, rgba(0, 0, 0, .02));border-radius:8px}.cfo-error-inline{padding:2rem;text-align:center;color:var(--threat-critical, #dc2626);font-size:.9rem;background:#dc26260d;border-radius:8px}:root{--cfo-bg-primary: #f8fafc;--cfo-bg-secondary: #ffffff;--cfo-bg-tertiary: #f1f5f9;--cfo-text-primary: #1e293b;--cfo-text-secondary: #475569;--cfo-text-muted: #94a3b8;--cfo-border-light: #e2e8f0;--cfo-border-medium: #cbd5e1;--cfo-accent-gold: #b8860b;--cfo-accent-gold-light: #d4a91a;--cfo-success: #059669;--cfo-success-light: #d1fae5;--cfo-warning: #d97706;--cfo-warning-light: #fef3c7;--cfo-danger: #dc2626;--cfo-danger-light: #fee2e2;--cfo-info: #2563eb;--cfo-info-light: #dbeafe;--cfo-shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--cfo-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -1px rgba(0, 0, 0, .04);--cfo-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);--cfo-radius-sm: 6px;--cfo-radius-md: 10px;--cfo-radius-lg: 14px}.cfo-command-center{min-height:100vh;background:var(--cfo-bg-primary);padding:1.5rem 2rem 3rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--cfo-text-primary)}.cfo-header{display:flex;justify-content:space-between;align-items:center;padding:0 0 1.5rem;margin-bottom:2rem;border-bottom:1px solid var(--cfo-border-light)}.header-content,.header-logo-title{display:flex;align-items:center;gap:1rem}.header-logo{height:44px;width:auto}.header-text{display:flex;flex-direction:column}.command-title{font-size:1.5rem;font-weight:700;color:var(--cfo-text-primary);margin:0;letter-spacing:-.02em}.command-subtitle{font-size:.8rem;color:var(--cfo-text-muted);margin:.25rem 0 0;font-weight:500}.header-timestamp{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--cfo-text-muted);background:var(--cfo-bg-tertiary);padding:.5rem 1rem;border-radius:var(--cfo-radius-sm)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem;color:var(--cfo-text-muted)}.loading-spinner{width:40px;height:40px;border:3px solid var(--cfo-border-light);border-top-color:var(--cfo-accent-gold);border-radius:50%;animation:spin 1s linear infinite}.portfolio-rag-hero{display:grid;grid-template-columns:auto 1fr auto;gap:2.5rem;align-items:center;padding:1.5rem 2rem;border-radius:var(--cfo-radius-lg);margin-bottom:2rem;background:var(--cfo-bg-secondary);border:1px solid var(--cfo-border-light);box-shadow:var(--cfo-shadow-sm)}.portfolio-rag-hero--green{border-left:4px solid var(--cfo-success)}.portfolio-rag-hero--amber{border-left:4px solid var(--cfo-warning)}.portfolio-rag-hero--red{border-left:4px solid var(--cfo-danger)}.rag-hero-left{display:flex;align-items:center;gap:1.25rem}.rag-traffic-light{display:flex;flex-direction:column;align-items:center;gap:.5rem}.traffic-light{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.traffic-light--green{background:linear-gradient(135deg,var(--cfo-success),#10b981);box-shadow:0 4px 12px #05966940}.traffic-light--amber{background:linear-gradient(135deg,var(--cfo-warning),#f59e0b);box-shadow:0 4px 12px #d9770640;animation:pulse-amber 2s ease-in-out infinite}.traffic-light--red{background:linear-gradient(135deg,var(--cfo-danger),#ef4444);box-shadow:0 4px 12px #dc26264d;animation:pulse-red 1.5s ease-in-out infinite}@keyframes pulse-amber{0%,to{box-shadow:0 4px 12px #d9770640}50%{box-shadow:0 4px 20px #d9770666}}@keyframes pulse-red{0%,to{box-shadow:0 4px 12px #dc26264d}50%{box-shadow:0 4px 24px #dc262680}}.rag-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--cfo-text-secondary)}.rag-title h2{font-size:1.25rem;font-weight:700;color:var(--cfo-text-primary);margin:0}.rag-subtitle{font-size:.8rem;color:var(--cfo-text-muted);margin:.25rem 0 0}.rag-hero-center{padding:0 1.5rem}.rag-distribution{display:flex;flex-direction:column;gap:.75rem}.rag-bar{display:flex;height:20px;border-radius:10px;overflow:hidden;background:var(--cfo-bg-tertiary)}.rag-segment{height:100%;transition:width .5s ease;min-width:2px}.rag-segment--green{background:var(--cfo-success)}.rag-segment--amber{background:var(--cfo-warning)}.rag-segment--red{background:var(--cfo-danger)}.rag-counts{display:flex;justify-content:space-between;gap:1rem}.rag-count{font-size:.75rem;font-weight:600}.rag-count--green{color:var(--cfo-success)}.rag-count--amber{color:var(--cfo-warning)}.rag-count--red{color:var(--cfo-danger)}.rag-hero-right{display:flex;gap:2rem}.rag-kpi{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1rem;background:var(--cfo-bg-tertiary);border-radius:var(--cfo-radius-md)}.rag-kpi-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--cfo-text-muted);font-weight:600}.rag-kpi-value{font-size:1.35rem;font-weight:700;color:var(--cfo-text-primary)}.rag-kpi-value.positive{color:var(--cfo-success)}.rag-kpi-value.negative{color:var(--cfo-danger)}.portfolio-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2rem}.portfolio-financials-section{background:var(--cfo-bg-secondary);border:1px solid var(--cfo-border-light);border-radius:var(--cfo-radius-lg);padding:1.5rem;margin-bottom:2rem;box-shadow:var(--cfo-shadow-sm)}.financials-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.financials-header .header-left{display:flex;flex-direction:column;gap:.25rem}.exchange-rate-note{font-size:.7rem;color:var(--cfo-text-muted);font-weight:500}.currency-toggle{display:flex;gap:.5rem;background:var(--cfo-bg-tertiary);padding:.25rem;border-radius:var(--cfo-radius-sm)}.toggle-btn{padding:.5rem 1rem;font-size:.75rem;font-weight:600;border:none;background:transparent;color:var(--cfo-text-muted);cursor:pointer;border-radius:4px;transition:all .2s}.toggle-btn:hover{color:var(--cfo-text-secondary)}.toggle-btn.active{background:var(--cfo-bg-secondary);color:var(--cfo-accent-gold);box-shadow:var(--cfo-shadow-sm)}.financials-subsection{margin-bottom:1.5rem}.financials-subsection:last-child{margin-bottom:0}.subsection-title{font-size:.8rem;font-weight:600;color:var(--cfo-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--cfo-border-light)}.financials-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.revenue-kpi-clickable{background:transparent;border:none;padding:0;margin:0;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border-radius:var(--cfo-radius-md)}.revenue-kpi-clickable:hover{transform:translateY(-2px)}.revenue-kpi-clickable:hover .kpi-card{border-color:var(--cfo-info);box-shadow:0 4px 12px #2563eb26}.revenue-kpi-clickable:active{transform:translateY(0)}.budget-utilization-bar{margin-top:1rem;padding:.75rem 1rem;background:var(--cfo-bg-tertiary);border-radius:var(--cfo-radius-sm)}.budget-utilization-bar .utilization-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.75rem;color:var(--cfo-text-secondary)}.budget-utilization-bar .utilization-pct{font-weight:700;color:var(--cfo-text-primary)}.budget-utilization-bar .utilization-track{height:8px;background:var(--cfo-border-light);border-radius:4px;overflow:hidden}.budget-utilization-bar .utilization-fill{height:100%;background:linear-gradient(90deg,var(--cfo-success),#34d399);border-radius:4px;transition:width .5s ease}.budget-utilization-bar .utilization-fill.over-budget{background:linear-gradient(90deg,var(--cfo-danger),#f87171)}.revenue-pending-note{display:flex;align-items:center;gap:.5rem;padding:1rem 1.25rem;background:var(--cfo-warning-light);border:1px solid var(--cfo-warning);border-radius:var(--cfo-radius-md);color:var(--cfo-warning);font-size:.8rem;font-weight:500}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:var(--cfo-text-muted);font-size:.85rem}.cfo-two-column{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;color:var(--cfo-text-primary);margin:0}.section-title svg{color:var(--cfo-text-muted)}.section-subtitle{font-size:.75rem;color:var(--cfo-text-muted)}.executive-alerts-section{background:var(--cfo-bg-secondary);border:1px solid var(--cfo-border-light);border-radius:var(--cfo-radius-lg);padding:1.5rem;box-shadow:var(--cfo-shadow-sm)}.alert-count{font-size:.7rem;font-weight:600;color:var(--cfo-danger);background:var(--cfo-danger-light);padding:.25rem .75rem;border-radius:12px}.alerts-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem;color:var(--cfo-text-muted);gap:.75rem}.alerts-empty .success-icon{color:var(--cfo-success)}.alerts-list{display:flex;flex-direction:column;gap:.75rem;max-height:280px;overflow-y:auto}.alert-card{display:flex;gap:.75rem;padding:.875rem 1rem;border-radius:var(--cfo-radius-md);border-left:3px solid}.alert-card--critical{border-left-color:var(--cfo-danger);background:var(--cfo-danger-light)}.alert-card--warning{border-left-color:var(--cfo-warning);background:var(--cfo-warning-light)}.alert-card--info{border-left-color:var(--cfo-info);background:var(--cfo-info-light)}.alert-icon{flex-shrink:0;padding-top:.125rem}.alert-card--critical .alert-icon{color:var(--cfo-danger)}.alert-card--warning .alert-icon{color:var(--cfo-warning)}.alert-card--info .alert-icon{color:var(--cfo-info)}.alert-content{flex:1;min-width:0}.alert-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.alert-project{font-size:.75rem;font-weight:600;color:var(--cfo-text-primary)}.alert-severity{font-size:.6rem;font-weight:700;padding:.125rem .5rem;border-radius:4px;text-transform:uppercase}.alert-severity--critical{background:#dc262626;color:var(--cfo-danger)}.alert-severity--warning{background:#d9770626;color:var(--cfo-warning)}.alert-message{font-size:.8rem;color:var(--cfo-text-secondary);margin:0 0 .25rem}.alert-action{font-size:.7rem;color:var(--cfo-text-muted);margin:0}.alert-action strong{color:var(--cfo-text-secondary)}.cost-distribution-section{background:var(--cfo-bg-secondary);border:1px solid var(--cfo-border-light);border-radius:var(--cfo-radius-lg);padding:1.5rem;box-shadow:var(--cfo-shadow-sm);margin-bottom:2rem}.project-budget-list{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.budget-card{background:var(--cfo-bg-tertiary);border:1px solid var(--cfo-border-light);border-radius:var(--cfo-radius-md);padding:1rem 1.25rem;transition:all .2s}.budget-card:hover{background:var(--cfo-bg-secondary);box-shadow:var(--cfo-shadow-md)}.budget-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.budget-dot{width:10px;height:10px;border-radius:50%}.budget-project-id{font-weight:600;font-size:.85rem;color:var(--cfo-accent-gold);flex:1}.budget-currency-badge{font-size:.6rem;font-weight:700;padding:.2rem .5rem;background:#b8860b1a;color:var(--cfo-accent-gold);border-radius:4px;letter-spacing:.05em}.budget-amounts{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.625rem}.budget-amount{display:flex;flex-direction:column;gap:.125rem}.amount-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;color:var(--cfo-text-muted);font-weight:600}.amount-value{font-size:.9rem;font-weight:600;color:var(--cfo-text-primary);font-family:JetBrains Mono,Fira Code,monospace}.budget-utilization{display:flex;align-items:center;gap:.75rem;position:relative;overflow:hidden}.utilization-bar{flex:1;height:6px;background:var(--cfo-border-light);border-radius:3px;overflow:hidden;position:relative}.utilization-fill{height:100%;background:linear-gradient(90deg,var(--cfo-success),#34d399);border-radius:3px;transition:width .5s ease;position:relative;max-width:100%}.utilization-fill.over-budget{background:linear-gradient(90deg,var(--cfo-danger),#f87171)}.utilization-pct{font-size:.7rem;color:var(--cfo-text-muted);min-width:85px;text-align:right;font-weight:500}.utilization-pct.over-budget{color:var(--cfo-danger);font-weight:600}.project-comparison-section{background:var(--cfo-bg-secondary);border:1px solid var(--cfo-border-light);border-radius:var(--cfo-radius-lg);padding:1.5rem;margin-bottom:2rem;box-shadow:var(--cfo-shadow-sm)}.comparison-table-wrapper{overflow-x:auto}.comparison-table{width:100%;border-collapse:collapse;font-size:.8rem}.comparison-table th{text-align:left;padding:.875rem 1rem;font-weight:600;color:var(--cfo-text-muted);text-transform:uppercase;font-size:.65rem;letter-spacing:.05em;border-bottom:2px solid var(--cfo-border-light);background:var(--cfo-bg-tertiary)}.comparison-table th.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .2s}.comparison-table th.sortable:hover{color:var(--cfo-accent-gold)}.comparison-table td{padding:.875rem 1rem;border-bottom:1px solid var(--cfo-border-light);color:var(--cfo-text-secondary)}.project-row{cursor:pointer;transition:background .2s}.project-row:hover{background:var(--cfo-bg-tertiary)}.project-row--green{border-left:3px solid var(--cfo-success)}.project-row--amber{border-left:3px solid var(--cfo-warning)}.project-row--red{border-left:3px solid var(--cfo-danger)}.status-cell{width:40px}.status-indicator{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center}.status-indicator--green{background:var(--cfo-success-light);color:var(--cfo-success)}.status-indicator--amber{background:var(--cfo-warning-light);color:var(--cfo-warning)}.status-indicator--red{background:var(--cfo-danger-light);color:var(--cfo-danger)}.project-name-cell{display:flex;flex-direction:column;gap:.125rem}.project-id{font-weight:600;color:var(--cfo-accent-gold)}.project-name{font-size:.7rem;color:var(--cfo-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.currency-cell{font-family:JetBrains Mono,Fira Code,monospace;font-weight:500}.currency-cell.positive{color:var(--cfo-success)}.currency-cell.negative{color:var(--cfo-danger)}.kpi-cell{font-family:JetBrains Mono,Fira Code,monospace;font-weight:600}.kpi-cell.positive{color:var(--cfo-success)}.kpi-cell.negative{color:var(--cfo-danger)}.progress-cell{display:flex;align-items:center;gap:.5rem}.progress-bar-mini{width:60px;height:6px;background:var(--cfo-border-light);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--cfo-accent-gold),var(--cfo-accent-gold-light));border-radius:3px;transition:width .5s ease}.progress-value{font-size:.75rem;font-weight:500;min-width:45px;color:var(--cfo-text-secondary)}.currency-code{font-size:.7rem;color:var(--cfo-text-muted)}.action-cell{color:var(--cfo-text-muted);transition:color .2s}.project-row:hover .action-cell{color:var(--cfo-accent-gold)}.quick-actions-section{background:var(--cfo-bg-secondary);border:1px solid var(--cfo-border-light);border-radius:var(--cfo-radius-lg);padding:1.5rem;box-shadow:var(--cfo-shadow-sm)}.quick-actions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.quick-action-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--cfo-bg-tertiary);border:1px solid var(--cfo-border-light);border-radius:var(--cfo-radius-md);color:var(--cfo-text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.quick-action-btn:hover{background:var(--cfo-bg-secondary);border-color:var(--cfo-accent-gold);color:var(--cfo-accent-gold);box-shadow:var(--cfo-shadow-md)}.quick-action-btn span{flex:1;text-align:left}.cfo-footer{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;margin-top:1.5rem;border-top:1px solid var(--cfo-border-light)}.footer-left{display:flex;align-items:center;gap:.5rem}.footer-brand{font-weight:700;color:var(--cfo-accent-gold);font-size:.875rem}.footer-version{font-size:.7rem;color:var(--cfo-text-muted)}.footer-note{font-size:.75rem;color:var(--cfo-text-muted)}@media(max-width:1200px){.cfo-command-center{padding:1.25rem 1.5rem 2.5rem}.portfolio-kpi-row,.financials-kpi-grid,.quick-actions-grid{grid-template-columns:repeat(2,1fr)}.portfolio-rag-hero{grid-template-columns:1fr;gap:1.5rem;padding:1.25rem 1.5rem}.rag-hero-left{justify-content:flex-start}.rag-hero-center{padding:0}.rag-hero-right{justify-content:flex-start;flex-wrap:wrap;gap:1rem}.project-budget-list{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.cfo-command-center{padding:1rem 1rem 2rem}.cfo-header{flex-direction:column;gap:1rem;align-items:flex-start;padding-bottom:1rem;margin-bottom:1.5rem}.header-logo-title{flex-direction:row;gap:.75rem}.header-logo{height:36px}.command-title{font-size:1.25rem}.command-subtitle{font-size:.75rem}.header-timestamp{align-self:flex-start}.portfolio-rag-hero{padding:1rem;gap:1rem}.traffic-light{width:44px;height:44px}.rag-title h2{font-size:1.1rem}.rag-kpi{padding:.5rem .75rem}.rag-kpi-value{font-size:1.15rem}.rag-bar{height:16px}.portfolio-kpi-row{grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.5rem}.financials-kpi-grid{grid-template-columns:1fr 1fr;gap:.75rem}.portfolio-financials-section{padding:1rem}.project-budget-list{grid-template-columns:repeat(2,1fr);gap:.75rem}.executive-alerts-section,.cost-distribution-section,.project-comparison-section,.quick-actions-section{padding:1rem;border-radius:var(--cfo-radius-md)}.section-title{font-size:.9rem}.quick-actions-grid{grid-template-columns:1fr 1fr;gap:.75rem}.quick-action-btn{padding:.875rem 1rem;font-size:.75rem}.comparison-table-wrapper{margin:0 -.5rem;padding:0 .5rem}.comparison-table th,.comparison-table td{padding:.625rem .5rem;font-size:.75rem}.comparison-table th{font-size:.6rem}.project-name{max-width:120px;font-size:.65rem}.cfo-footer{flex-direction:column;gap:.75rem;text-align:center;padding:1rem 0}}@media(max-width:480px){.cfo-command-center{padding:.75rem .75rem 1.5rem}.command-title{font-size:1.1rem}.header-logo{height:32px}.portfolio-rag-hero{padding:.875rem}.rag-hero-left{gap:.75rem}.traffic-light{width:38px;height:38px}.traffic-light svg{width:18px;height:18px}.rag-title h2{font-size:1rem}.rag-subtitle{font-size:.7rem}.rag-hero-right{gap:.5rem}.rag-kpi{padding:.375rem .5rem}.rag-kpi-label{font-size:.55rem}.rag-kpi-value{font-size:1rem}.rag-counts{flex-wrap:wrap;gap:.5rem;justify-content:flex-start}.rag-count{font-size:.7rem}.portfolio-kpi-row{grid-template-columns:1fr;gap:.625rem}.financials-kpi-grid{grid-template-columns:1fr;gap:.5rem}.financials-header{flex-direction:column;gap:.75rem}.currency-toggle{align-self:flex-start}.executive-alerts-section,.cost-distribution-section,.project-comparison-section,.quick-actions-section{padding:.875rem}.section-title{font-size:.85rem}.alerts-list{max-height:220px}.alert-card{padding:.625rem .75rem}.alert-message{font-size:.75rem}.alert-action{font-size:.65rem}.project-budget-list{grid-template-columns:1fr}.budget-card{padding:.75rem 1rem}.budget-amounts{grid-template-columns:1fr 1fr;gap:.5rem}.amount-value{font-size:.85rem}.quick-actions-grid{grid-template-columns:1fr;gap:.5rem}.quick-action-btn{padding:.75rem 1rem}.comparison-table th:nth-child(3),.comparison-table td:nth-child(3),.comparison-table th:nth-child(5),.comparison-table td:nth-child(5),.comparison-table th:nth-child(9),.comparison-table td:nth-child(9){display:none}.comparison-table th,.comparison-table td{padding:.5rem .375rem;font-size:.7rem}.project-name{max-width:80px;font-size:.6rem}.progress-bar-mini{width:40px}.footer-note{font-size:.65rem;max-width:280px}}@media(pointer:coarse){.project-row{min-height:52px}.quick-action-btn{min-height:48px}.comparison-table th.sortable{padding:.875rem .625rem}.alert-card{padding:1rem}.budget-card{padding:1rem 1.25rem}}@media(max-height:500px)and (orientation:landscape){.portfolio-rag-hero{padding:.75rem 1rem}.traffic-light{width:32px;height:32px}.rag-title h2{font-size:.95rem}.portfolio-kpi-row{grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem}.alerts-list{max-height:140px}}@media(prefers-contrast:high){:root{--cfo-border-light: #94a3b8;--cfo-border-medium: #64748b}.comparison-table th,.comparison-table td{border-bottom-width:2px}}@media(prefers-reduced-motion:reduce){.traffic-light--amber,.traffic-light--red{animation:none}.loading-spinner{animation:none;border-top-color:var(--cfo-accent-gold);opacity:.7}*{transition-duration:.01ms!important}}@media print{.cfo-command-center{background:#fff;padding:0}.quick-actions-section{display:none}.portfolio-rag-hero,.executive-alerts-section,.cost-distribution-section,.project-comparison-section{box-shadow:none;border:1px solid #ccc}}.po-status-section{background:var(--cfo-bg-secondary);border-radius:var(--cfo-radius-lg);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--cfo-shadow-md)}.po-status-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--cfo-border-light)}.po-status-section .section-title{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;color:var(--cfo-text-primary);margin:0}.po-status-section .section-subtitle{font-size:.8rem;color:var(--cfo-text-muted)}.po-status-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.po-status-project-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.po-status-project-card{background:var(--cfo-bg-tertiary);border-radius:var(--cfo-radius-md);padding:1rem;border:1px solid var(--cfo-border-light)}.po-project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--cfo-border-light)}.po-project-id{font-weight:600;font-size:.95rem;color:var(--cfo-text-primary)}.po-project-currency{font-size:.75rem;padding:.15rem .5rem;background:var(--cfo-info-light);color:var(--cfo-info);border-radius:4px;font-weight:500}.po-project-values{display:flex;flex-direction:column;gap:.5rem}.po-value-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.po-value-label{color:var(--cfo-text-secondary);min-width:60px}.po-value-active{color:var(--cfo-success);font-weight:600;flex:1}.po-value-cancelled{color:var(--cfo-warning);font-weight:600;flex:1}.po-count{font-size:.75rem;color:var(--cfo-text-muted)}@media(max-width:1200px){.po-status-kpi-grid,.po-status-project-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.po-status-section{padding:1rem}.po-status-kpi-grid{grid-template-columns:1fr;gap:.75rem}.po-status-project-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.po-status-section .section-header{flex-direction:column;align-items:flex-start;gap:.5rem}}@media(max-width:480px){.po-status-project-grid{grid-template-columns:1fr}}.engineering-drilldown{max-width:1600px;margin:0 auto;padding:2rem;background-color:var(--petroleum-deep);min-height:100vh}.tab-navigation{display:flex;gap:1rem;margin-bottom:2rem;padding:.5rem;background:#1a233299;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:12px;border:1px solid rgba(59,130,246,.2);box-shadow:0 4px 12px #0000001a}.tab-button{flex:1;padding:1rem 1.5rem;background:transparent;border:2px solid transparent;border-radius:8px;color:var(--text-secondary);font-family:var(--font-mono);font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.tab-button:hover{background:#3b82f61a;color:var(--text-primary);border-color:#3b82f64d}.tab-button--active{background:linear-gradient(135deg,#3b82f633,#0ea5e91a);color:var(--tech-cyan);border-color:var(--tech-cyan);box-shadow:0 0 20px #0ea5e94d,inset 0 0 20px #0ea5e91a}.tab-icon{font-size:1.25rem}.tab-content{animation:fadeIn .3s ease}.drilldown-table{width:100%;border-collapse:collapse;background:#1a233299;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:12px;overflow:hidden;border:1px solid rgba(59,130,246,.2);box-shadow:0 4px 12px #0000001a}.drilldown-table thead{background:linear-gradient(135deg,#1a2332e6,#1e293be6);border-bottom:2px solid var(--tech-cyan)}.drilldown-table th{padding:1rem;text-align:left;color:var(--tech-cyan);font-family:var(--font-mono);font-size:.75rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;border-bottom:1px solid rgba(59,130,246,.3)}.drilldown-table tbody tr{border-bottom:1px solid rgba(59,130,246,.1);transition:all .2s ease}.drilldown-table tbody tr:hover{background:#3b82f60d;transform:translate(2px)}.drilldown-table td{padding:1rem;color:var(--text-primary);font-family:var(--font-mono);font-size:.875rem}.code-badge{display:inline-block;padding:.375rem .75rem;background:linear-gradient(135deg,#3b82f633,#0ea5e91a);border:1px solid var(--tech-cyan);border-radius:6px;color:var(--tech-cyan);font-family:var(--font-mono);font-size:.8125rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.progress-container{display:flex;align-items:center;gap:1rem}.progress-bar-wrapper{flex:1;height:8px;background:#64748b33;border-radius:4px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;border-radius:4px;transition:width .3s ease;background:linear-gradient(90deg,currentColor 0%,rgba(255,255,255,.8) 100%);box-shadow:0 0 8px currentColor}.progress-text{min-width:48px;text-align:right;font-family:var(--font-mono);font-size:.8125rem;font-weight:700;color:var(--text-primary)}.pipeline-flow{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem}.pipeline-stage{animation:slideIn .4s ease}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.pipeline-box{box-shadow:0 4px 12px #0003;transition:all .2s ease}.pipeline-box:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 20px #0000004d}.pipeline-arrow{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.command-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-right-color:var(--pipeline-green);border-radius:50%;animation:spin 1s cubic-bezier(.4,0,.2,1) infinite;box-shadow:0 0 20px #0ea5e94d}.loading-text{font-family:var(--font-mono);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;font-size:.875rem}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background:#1a2332cc;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-left:4px solid var(--emergency-red);padding:2rem;border-radius:12px;text-align:center;max-width:500px;margin:2rem auto;border:1px solid rgba(220,38,38,.3);box-shadow:0 4px 12px #0003}.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)}@media(max-width:768px){.tab-navigation{flex-direction:column}.tab-button{width:100%}.drilldown-table{font-size:.75rem}.drilldown-table th,.drilldown-table td{padding:.75rem}.pipeline-flow{flex-direction:column}.pipeline-arrow{transform:rotate(90deg)}}.financial-drilldown.vault-container{min-height:100vh;padding:var(--spacing-xl, 2rem) var(--spacing-lg, 1.5rem);max-width:1800px;margin:0 auto;background:var(--bg-primary, #ffffff);position:relative}.financial-drilldown .command-header{padding:var(--spacing-2xl, 3rem) var(--spacing-xl, 2rem);border-radius:var(--radius-2xl, 16px);margin-bottom:var(--spacing-xl, 2rem);position:relative;overflow:hidden;background:var(--oilserv-offwhite-glass);backdrop-filter:blur(var(--glass-blur-lg, 20px)) saturate(var(--glass-saturate, 180%));-webkit-backdrop-filter:blur(var(--glass-blur-lg, 20px)) saturate(var(--glass-saturate, 180%));border:2px solid var(--glass-border, rgba(212, 175, 55, .2));box-shadow:var(--shadow-lg),inset 0 1px #fffc,inset 0 -1px #d4af3714}.financial-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}.financial-drilldown .header-content{position:relative;z-index:1}.financial-drilldown .header-logo-title{display:flex;align-items:center;gap:var(--spacing-lg, 1.5rem);margin-bottom:var(--spacing-sm, .5rem)}.financial-drilldown .header-logo{height:60px;width:auto;-o-object-fit:contain;object-fit:contain}.financial-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}.financial-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)}.section-heading.treasury-heading{display:flex;align-items:center;gap:var(--spacing-lg, 1.5rem);margin:0 0 var(--spacing-xl, 2rem) 0;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--oilserv-gold-dark);text-transform:uppercase;letter-spacing:.08em;position:relative;z-index:1}.ledger-line{flex:1;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(212,175,55,.4) 50%,transparent 100%);box-shadow:0 1px 2px #d4af3733}.vault-stats-section{position:relative;z-index:1;margin-bottom:3rem}.stats-grid.treasury-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));max-width:1400px;gap:var(--spacing-lg, 1.5rem)}.stats-grid.treasury-grid>*{min-height:160px;max-height:160px;display:flex;flex-direction:column}.stats-grid.treasury-grid .kpi-card{height:100%;display:flex;flex-direction:column}.stats-grid.treasury-grid .kpi-card__content{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-height:0}.treasury-summary-card{padding:var(--spacing-lg, 1.5rem);background:linear-gradient(135deg,#d4af3714,#d4af370a);border:2px solid rgba(212,175,55,.3);border-radius:var(--radius-xl, 12px);box-shadow:0 4px 16px #d4af371a,inset 0 1px 2px #ffffff0d}.summary-header{display:flex;align-items:center;gap:var(--spacing-sm, .75rem);margin-bottom:var(--spacing-md, 1rem)}.summary-icon{font-size:1.5rem}.summary-header h3{margin:0;font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:#d4af37}.summary-gauge{width:100%;height:32px;background:#0000004d;border:2px solid rgba(212,175,55,.3);border-radius:6px;overflow:hidden;position:relative;margin-bottom:1rem;box-shadow:inset 0 2px 4px #0000004d}.gauge-fill{height:100%;background:linear-gradient(90deg,#22c55e99,#22c55ecc);transition:width .6s cubic-bezier(.4,0,.2,1);box-shadow:0 0 12px #22c55e80}.gauge-fill[data-status=warning]{background:linear-gradient(90deg,#fb923c99,#fb923ccc);box-shadow:0 0 12px #fb923c80}.gauge-fill[data-status=critical]{background:linear-gradient(90deg,#ef444499,#ef4444cc);box-shadow:0 0 12px #ef444480}.summary-text{margin:0;font-size:.9375rem;color:#fffc;font-style:italic}.vault-wbs-section{position:relative;z-index:1;margin-bottom:3rem}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.level-selector-group{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,#d4af3714,#d4af370a);border:2px solid rgba(212,175,55,.3);border-radius:8px}.level-label{font-family:var(--font-display);font-size:.875rem;font-weight:600;color:#d4af37;letter-spacing:.05em}.level-btn{padding:.5rem 1rem;font-family:var(--font-mono);font-size:.875rem;font-weight:700;background:#d4af371a;border:2px solid rgba(212,175,55,.3);color:#d4af37cc;border-radius:6px;cursor:pointer;transition:all .2s ease}.level-btn:hover{background:#d4af3726;border-color:#d4af3780}.level-btn--active{background:linear-gradient(135deg,#d4af37,#b8941f);border-color:#d4af37;color:#1a0f0a;box-shadow:0 4px 12px #d4af374d}.wbs-ledger-container{overflow-x:auto;background:#d4af3708;border:3px solid rgba(212,175,55,.25);border-radius:8px;box-shadow:0 8px 32px #0000004d}.wbs-ledger.treasury-table{width:100%;border-collapse:collapse;font-family:var(--font-display)}.wbs-ledger thead{background:linear-gradient(135deg,#d4af3726,#d4af3714);border-bottom:3px double rgba(212,175,55,.5)}.wbs-ledger th{padding:1.25rem 1rem;text-align:left;font-size:.8125rem;font-weight:700;color:#d4af37;text-transform:uppercase;letter-spacing:.1em;border-right:1px solid rgba(212,175,55,.2)}.wbs-ledger th:last-child{border-right:none}.wbs-ledger tbody tr{border-bottom:1px solid rgba(212,175,55,.15);transition:background .2s ease}.wbs-ledger tbody tr:hover{background:#d4af370d}.wbs-row.level-1{background:#d4af3714;font-weight:700}.wbs-row.level-2{background:#d4af370a}.wbs-ledger td{padding:1rem;font-size:.9375rem;color:var(--text-primary);border-right:1px solid rgba(212,175,55,.1)}.wbs-ledger td:last-child{border-right:none}.col-wbs-code{width:180px}.col-description{min-width:300px}.col-level{width:80px;text-align:center}.col-budget{width:180px;text-align:right}.col-currency{width:100px;text-align:center}.ledger-mono{font-family:var(--font-mono);color:#d4af37e6;letter-spacing:.02em;font-weight:600}.level-badge{display:inline-block;padding:.25rem .75rem;font-family:var(--font-mono);font-size:.75rem;font-weight:700;background:#d4af3733;border:1px solid rgba(212,175,55,.4);color:#e5c76b;border-radius:4px}.currency-value{font-family:var(--font-display);font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.currency-highlight{color:#d4af37;text-shadow:0 1px 2px rgba(212,175,55,.3)}.currency-badge{font-family:var(--font-mono);font-size:.8125rem;font-weight:700;color:#d4af37;background:#d4af371a;border-radius:4px;padding:.25rem .5rem}.wbs-ledger tfoot{background:linear-gradient(135deg,#d4af3733,#d4af371f);border-top:3px double rgba(212,175,55,.6)}.ledger-total-row td{padding:1.25rem 1rem;font-weight:700;color:#d4af37}.ledger-total{font-size:1.0625rem;text-shadow:0 1px 4px rgba(212,175,55,.4)}.ledger-footer-note{padding:1rem;text-align:center;font-size:.875rem;color:var(--text-secondary);font-style:italic;background:#d4af3708;border-top:1px solid rgba(212,175,55,.2)}.vault-links-section{position:relative;z-index:1;margin-bottom:3rem}.links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-lg, 1.5rem)}.report-link-card{display:block;padding:var(--spacing-xl, 2rem);background:linear-gradient(135deg,#d4af3714,#d4af370a);border:2px solid rgba(212,175,55,.3);border-radius:var(--radius-xl, 12px);text-decoration:none;color:inherit;transition:all var(--duration-normal, .3s) var(--ease-mechanical);position:relative;overflow:hidden;box-shadow:0 4px 16px #d4af371a}.report-link-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#d4af37,#e5c76b);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.report-link-card:hover:before{transform:scaleX(1)}.report-link-card:hover{background:linear-gradient(135deg,#d4af371f,#d4af370f);border-color:#d4af3780;transform:translateY(-4px);box-shadow:0 8px 24px #d4af3733}.link-icon{font-size:2.5rem;margin-bottom:1rem}.report-link-card h3{margin:0 0 .75rem;font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:#d4af37}.report-link-card p{margin:0 0 1rem;font-size:.9375rem;color:var(--text-secondary);line-height:1.6}.link-arrow{font-size:1.5rem;color:#d4af37;font-weight:700}.vault-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1.5rem}.loading-vault-spinner{width:60px;height:60px;border:4px solid rgba(212,175,55,.2);border-top-color:#d4af37;border-radius:50%;animation:vault-spin 1s ease-in-out infinite}@keyframes vault-spin{to{transform:rotate(360deg)}}.vault-loading p{font-family:var(--font-body);font-size:1rem;color:var(--text-secondary);font-style:italic}.vault-error{display:flex;align-items:center;justify-content:center;gap:1rem;padding:2rem;background:#ef44441a;border:2px solid rgba(239,68,68,.3);border-radius:8px;min-height:200px}.vault-error p{font-family:var(--font-display);font-size:1rem;color:#fca5a5}@media(max-width:1024px){.stats-grid.treasury-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));max-width:100%}.links-grid{grid-template-columns:1fr}}@media(max-width:768px){.financial-drilldown.vault-container{padding:1.5rem 1rem}.financial-drilldown .command-header{padding:2rem 1.5rem}.financial-drilldown .header-logo-title{flex-direction:column;align-items:flex-start;gap:1rem}.financial-drilldown .header-logo{height:50px}.financial-drilldown .command-title{font-size:1.75rem}.financial-drilldown .command-subtitle{font-size:.875rem}.section-header-row{flex-direction:column;align-items:stretch}.wbs-ledger-container{overflow-x:auto}.wbs-ledger{min-width:900px}.stats-grid.treasury-grid{grid-template-columns:1fr}}@media(max-width:640px){.financial-drilldown .command-header{padding:1.5rem 1rem}.section-heading.treasury-heading{font-size:1.25rem;gap:1rem}.level-selector-group{flex-wrap:wrap}}.cost-tabs-section{position:relative;z-index:1;margin-bottom:2rem}.cost-tabs{display:flex;gap:.5rem;padding:.5rem;background:linear-gradient(135deg,#d4af3714,#d4af370a);border:2px solid rgba(212,175,55,.3);border-radius:12px;overflow-x:auto}.cost-tab{flex:1;min-width:150px;padding:.875rem 1.5rem;font-family:var(--font-display);font-size:.9375rem;font-weight:600;background:#ffffff80;border:2px solid rgba(212,175,55,.2);color:var(--text-primary);border-radius:8px;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.05em}.cost-tab:hover{background:#d4af371a;border-color:#d4af3766;transform:translateY(-2px)}.cost-tab--active{background:linear-gradient(135deg,#d4af37,#b8941f);border-color:#d4af37;color:#1a0f0a;box-shadow:0 4px 12px #d4af374d,inset 0 1px #ffffff4d}.cost-content-section{position:relative;z-index:1;margin-bottom:3rem}.cost-tab-content{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cost-visualization-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl, 2rem);margin-top:2rem}.cost-chart-card{background:linear-gradient(135deg,#d4af370d,#d4af3705);border:2px solid rgba(212,175,55,.25);border-radius:var(--radius-xl, 12px);padding:var(--spacing-xl, 2rem);box-shadow:0 4px 16px #d4af3714}.cost-chart-wide{grid-column:1 / -1}.chart-title{margin:0 0 1.5rem;font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--oilserv-gold-dark);text-transform:uppercase;letter-spacing:.05em}.cost-table-card{background:linear-gradient(135deg,#d4af370d,#d4af3705);border:2px solid rgba(212,175,55,.25);border-radius:var(--radius-xl, 12px);padding:var(--spacing-xl, 2rem)}.text-right{text-align:right}.percentage-badge{display:inline-block;padding:.25rem .75rem;font-family:var(--font-mono);font-size:.875rem;font-weight:700;background:#10b98126;border:1px solid rgba(16,185,129,.3);color:#10b981;border-radius:4px}.cost-type-cards{display:flex;flex-direction:column;gap:1rem}.cost-type-summary-card{background:linear-gradient(135deg,#fffc,#fff9);border:2px solid rgba(212,175,55,.25);border-radius:12px;padding:1.5rem;transition:all .2s ease}.cost-type-summary-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4af3726}.type-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:2px solid rgba(212,175,55,.2)}.type-color-indicator{width:12px;height:48px;border-radius:6px;box-shadow:0 2px 8px #0003}.type-header h4{margin:0;font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.type-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.type-metric{display:flex;flex-direction:column;gap:.25rem}.type-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.type-value{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--oilserv-gold-dark)}.wbs-level-controls{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#d4af3714,#d4af370a);border:2px solid rgba(212,175,55,.3);border-radius:8px;margin-bottom:1.5rem}.wbs-row.level-1{background:#d4af371a;font-weight:700}.wbs-row.level-2{background:#d4af370f;font-weight:600}.wbs-row.level-3{background:#d4af3708}.wbs-row.level-4{background:#d4af3703}.wbs-row.level-5{background:transparent}@media(max-width:1200px){.cost-visualization-grid{grid-template-columns:1fr}.type-metrics{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.cost-tabs{flex-direction:column}.cost-tab{min-width:unset}.cost-visualization-grid{gap:1rem}.cost-chart-card{padding:1rem}.type-metrics{grid-template-columns:1fr}.wbs-level-controls{flex-wrap:wrap}}@media(max-width:640px){.chart-title{font-size:1rem}.cost-type-summary-card{padding:1rem}.type-header h4,.type-value{font-size:1rem}}.recharts-wrapper{margin:0 auto}.recharts-tooltip-wrapper{z-index:1000}.recharts-default-tooltip{background:#000000e6!important;border:1px solid rgba(212,175,55,.3)!important;border-radius:8px!important;padding:1rem!important}.recharts-tooltip-label{color:#d4af37!important;font-weight:700!important;margin-bottom:.5rem!important}.recharts-tooltip-item{color:#fff!important}.cost-drilldown .vault-loading{min-height:400px}@media print{.cost-tabs{display:none}.cost-chart-card,.cost-table-card,.wbs-ledger-container{page-break-inside:avoid}}.po-aging-dashboard{--intel-bg-primary: #f8fafc;--intel-bg-secondary: #ffffff;--intel-bg-card: #ffffff;--intel-bg-elevated: #f1f5f9;--threat-critical: #dc2626;--threat-critical-glow: rgba(220, 38, 38, .15);--threat-high: #ea580c;--threat-high-glow: rgba(234, 88, 12, .1);--threat-medium: #d97706;--threat-medium-glow: rgba(217, 119, 6, .1);--threat-low: #059669;--threat-low-glow: rgba(5, 150, 105, .1);--threat-safe: #0891b2;--threat-safe-glow: rgba(8, 145, 178, .1);--intel-gold: #b8860b;--intel-gold-dim: rgba(184, 134, 11, .6);--intel-text-primary: #0f172a;--intel-text-secondary: #475569;--intel-text-muted: #94a3b8;--intel-border: #e2e8f0;--intel-border-glow: rgba(184, 134, 11, .2);--gradient-threat-bg: linear-gradient(135deg, rgba(220, 38, 38, .05) 0%, rgba(234, 88, 12, .03) 50%, transparent 100%);--gradient-safe-bg: linear-gradient(135deg, rgba(5, 150, 105, .05) 0%, rgba(8, 145, 178, .03) 100%);--gradient-header: linear-gradient(180deg, rgba(184, 134, 11, .05) 0%, transparent 100%);--font-intel: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Inter", "SF Pro Display", -apple-system, BlinkMacSystemFont, sans-serif;--pulse-critical: none;--scan-line: none}@keyframes pulse-critical{0%,to{opacity:1;box-shadow:0 0 20px var(--threat-critical-glow)}50%{opacity:.85;box-shadow:0 0 40px var(--threat-critical-glow)}}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.9}}@keyframes scan-line{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}@keyframes glow-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.2)}}@keyframes threat-reveal{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes data-stream{0%{background-position:0% 50%}to{background-position:100% 50%}}.po-aging-dashboard{min-height:100vh;padding:1.5rem 2rem;max-width:1920px;margin:0 auto;background:var(--intel-bg-primary);position:relative;overflow-x:hidden}.po-aging-dashboard:before{display:none}.command-header{position:relative;z-index:1;padding:2rem 2.5rem;margin-bottom:2rem;background:var(--intel-bg-card);border:1px solid var(--intel-border);border-radius:16px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.command-header:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--intel-gold),#f59e0b,var(--intel-gold))}.header-content{position:relative;z-index:2}.header-logo-title{display:flex;align-items:center;gap:1.25rem;margin-bottom:.75rem}.header-logo{height:44px;width:auto;filter:brightness(1.1)}.command-title{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--intel-text-primary);letter-spacing:-.02em;margin:0}.command-subtitle{font-family:var(--font-intel);font-size:.875rem;color:var(--intel-text-secondary);margin:0;letter-spacing:.02em}.po-aging-kpi-section{position:relative;z-index:1;margin-bottom:2rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.section-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--intel-text-primary);text-transform:uppercase;letter-spacing:.1em;margin:0;display:flex;align-items:center;gap:.75rem}.section-title:before{content:"";width:4px;height:20px;background:var(--intel-gold);border-radius:2px}.section-subtitle{font-family:var(--font-intel);font-size:.75rem;color:var(--intel-gold);margin:.5rem 0 0;font-weight:600;letter-spacing:.03em}.section-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .875rem;background:#22c55e26;border:1px solid rgba(34,197,94,.4);border-radius:20px;font-family:var(--font-intel);font-size:.6875rem;font-weight:600;color:var(--threat-low);text-transform:uppercase;letter-spacing:.08em}.section-badge:before{content:"";width:6px;height:6px;background:var(--threat-low);border-radius:50%;animation:glow-pulse 2s ease-in-out infinite}.kpi-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}@media(max-width:1200px){.kpi-grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.kpi-grid-4{grid-template-columns:1fr}}.po-aging-chart-section{position:relative;z-index:1;margin-bottom:2rem}.aging-chart-container{background:var(--intel-bg-card);border:1px solid var(--intel-border);border-radius:16px;padding:1.5rem;overflow:hidden;box-shadow:0 1px 3px #0000000d}.aging-chart-container .recharts-cartesian-grid-horizontal line,.aging-chart-container .recharts-cartesian-grid-vertical line{stroke:#4b55634d}.aging-chart-container .recharts-text{fill:var(--intel-text-secondary);font-family:var(--font-intel);font-size:.75rem}.aging-legend{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.5rem}.aging-legend-item{position:relative;display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--intel-bg-elevated);border:1px solid var(--intel-border);border-radius:12px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);overflow:hidden}.aging-legend-item:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;transition:width .25s ease}.aging-legend-item[style*="border-color: rgb(5, 150, 105)"]:before,.aging-legend-item[style*="border-color: #059669"]:before{background:var(--threat-low)}.aging-legend-item[style*="border-color: rgb(245, 158, 11)"]:before,.aging-legend-item[style*="border-color: #F59E0B"]:before{background:var(--threat-medium)}.aging-legend-item[style*="border-color: rgb(255, 149, 0)"]:before,.aging-legend-item[style*="border-color: #FF9500"]:before{background:var(--threat-high)}.aging-legend-item[style*="border-color: rgb(220, 38, 38)"]:before,.aging-legend-item[style*="border-color: #DC2626"]:before{background:var(--threat-critical)}.aging-legend-item:hover{transform:translateY(-2px);border-color:var(--intel-gold-dim);box-shadow:0 8px 24px #0006}.aging-legend-item:hover:before{width:6px}.aging-legend-item.active{border-color:var(--intel-gold);box-shadow:0 0 20px #d4af3733}.aging-legend-item.active:before{width:6px}.aging-legend-item .filter-indicator{position:absolute;top:.5rem;right:.5rem;padding:.25rem .5rem;background:var(--intel-gold);color:var(--intel-bg-primary);font-size:.5rem;font-weight:700;letter-spacing:.05em;border-radius:4px;box-shadow:0 0 10px #d4af3780}.aging-legend-color{width:14px;height:14px;border-radius:4px;flex-shrink:0;box-shadow:0 0 12px currentColor}.aging-legend-details{display:flex;flex-direction:column;gap:.375rem;min-width:0}.aging-legend-label{font-family:var(--font-display);font-size:.8125rem;font-weight:600;color:var(--intel-text-primary);white-space:nowrap}.aging-legend-count{font-family:var(--font-intel);font-size:.75rem;color:var(--intel-text-muted)}.aging-legend-value{font-family:var(--font-intel);font-size:1rem;font-weight:700;color:var(--intel-text-primary)}@media(max-width:1200px){.aging-legend{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.aging-legend{grid-template-columns:1fr}}.po-aging-vendor-section{position:relative;z-index:1;margin-bottom:2rem}.risk-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:1.5rem}.risk-stat-card{position:relative;padding:1.5rem;background:var(--intel-bg-card);border:1px solid var(--intel-border);border-radius:12px;overflow:hidden;transition:all .25s cubic-bezier(.4,0,.2,1)}.risk-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.risk-stat-card.risk-high{border-color:#ef444466;background:linear-gradient(135deg,rgba(239,68,68,.1) 0%,var(--intel-bg-card) 50%)}.risk-stat-card.risk-high:before{background:var(--threat-critical);box-shadow:0 0 20px var(--threat-critical-glow)}.risk-stat-card.risk-high:hover{animation:pulse-warning 1.5s ease-in-out infinite}.risk-stat-card.risk-medium{border-color:#eab30866;background:linear-gradient(135deg,rgba(234,179,8,.08) 0%,var(--intel-bg-card) 50%)}.risk-stat-card.risk-medium:before{background:var(--threat-medium);box-shadow:0 0 15px var(--threat-medium-glow)}.risk-stat-card.risk-low{border-color:#22c55e66;background:linear-gradient(135deg,rgba(34,197,94,.08) 0%,var(--intel-bg-card) 50%)}.risk-stat-card.risk-low:before{background:var(--threat-low);box-shadow:0 0 15px var(--threat-low-glow)}.risk-stat-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--intel-text-secondary);margin-bottom:.5rem}.risk-stat-value{font-family:var(--font-intel);font-size:2.75rem;font-weight:700;line-height:1;margin-bottom:.5rem}.risk-high .risk-stat-value{color:var(--threat-critical);text-shadow:0 0 30px var(--threat-critical-glow)}.risk-medium .risk-stat-value{color:var(--threat-medium)}.risk-low .risk-stat-value{color:var(--threat-low)}.risk-stat-subtitle{font-family:var(--font-intel);font-size:.875rem;color:var(--intel-text-muted)}@media(max-width:1024px){.risk-stats-grid{grid-template-columns:1fr}}.data-table-container{background:var(--intel-bg-card);border:1px solid var(--intel-border);border-radius:12px;overflow:hidden}.table-stats{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;background:linear-gradient(180deg,rgba(212,175,55,.05) 0%,transparent 100%);border-bottom:1px solid var(--intel-border)}.stat-label{font-family:var(--font-intel);font-size:.75rem;color:var(--intel-text-muted);text-transform:uppercase;letter-spacing:.06em}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:linear-gradient(180deg,#d4af3714,#d4af3708);border-bottom:1px solid var(--intel-border)}.data-table th{padding:1rem 1.25rem;text-align:left;font-family:var(--font-display);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--intel-text-secondary);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all .2s ease;white-space:nowrap}.data-table th:hover{color:var(--intel-gold);background:#d4af370d}.data-table tbody tr{position:relative;border-bottom:1px solid rgba(75,85,99,.3);transition:all .2s ease}.data-table tbody tr:hover{background:#d4af370d}.data-table tbody tr.clickable{cursor:pointer}.data-table tbody tr.clickable:hover{background:#d4af3714}.data-table tbody tr.selected{background:#d4af371f;border-left:3px solid var(--intel-gold);box-shadow:0 0 20px #d4af3726}.data-table tbody tr.selected:after{content:"FILTERED";position:absolute;right:1rem;padding:.25rem .5rem;background:var(--intel-gold);color:var(--intel-bg-primary);font-size:.5rem;font-weight:700;letter-spacing:.05em;border-radius:4px;box-shadow:0 0 10px #d4af3780}.data-table td{padding:1rem 1.25rem;font-family:var(--font-intel);font-size:.8125rem;color:var(--intel-text-primary)}.data-table td.no-data{text-align:center;padding:3rem;color:var(--intel-text-muted);font-style:italic}.data-table td.po-number{font-weight:600;color:var(--intel-gold)}.data-table td.age-days{font-weight:700}.data-table td.po-description{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--intel-text-secondary)}.data-table td.currency-value{font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-size:.8125rem;font-weight:600;text-align:right;white-space:nowrap;color:var(--intel-text-primary);letter-spacing:.01em}.risk-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1px solid;border-radius:6px;font-family:var(--font-intel);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.risk-dot{width:6px;height:6px;border-radius:50%;animation:glow-pulse 2s ease-in-out infinite}.aging-badge{display:inline-block;padding:.375rem .75rem;border:1px solid;border-radius:6px;font-family:var(--font-intel);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.25rem;background:linear-gradient(180deg,rgba(212,175,55,.03) 0%,transparent 100%);border-top:1px solid var(--intel-border)}.pagination-button{padding:.5rem 1.25rem;background:var(--intel-bg-elevated);border:1px solid var(--intel-border);border-radius:6px;font-family:var(--font-intel);font-size:.75rem;font-weight:600;color:var(--intel-text-primary);cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.05em}.pagination-button:hover:not(:disabled){background:#d4af3726;border-color:var(--intel-gold-dim);color:var(--intel-gold)}.pagination-button:disabled{opacity:.35;cursor:not-allowed}.pagination-info{font-family:var(--font-intel);font-size:.75rem;color:var(--intel-text-muted)}.active-filters{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#d4af370d;border:1px solid var(--intel-border);border-radius:8px;margin-bottom:1rem}.filter-label{font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--intel-text-muted);text-transform:uppercase;letter-spacing:.08em}.filter-chip{padding:.375rem .875rem;background:var(--intel-bg-elevated);border:1px solid var(--intel-gold-dim);border-radius:20px;font-family:var(--font-intel);font-size:.75rem;color:var(--intel-gold);cursor:pointer;transition:all .2s ease}.filter-chip:hover{background:#d4af3726;border-color:var(--intel-gold)}.clear-filters{padding:.375rem .875rem;background:transparent;border:1px solid rgba(239,68,68,.4);border-radius:20px;font-family:var(--font-intel);font-size:.75rem;font-weight:600;color:var(--threat-critical);cursor:pointer;transition:all .2s ease}.clear-filters:hover{background:#ef444426;border-color:var(--threat-critical)}.section-filters{display:flex;align-items:center;gap:1rem}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--intel-text-muted);text-transform:uppercase;letter-spacing:.06em}.command-select{padding:.5rem 1rem;background:var(--intel-bg-elevated);border:1px solid var(--intel-border);border-radius:6px;font-family:var(--font-intel);font-size:.8125rem;color:var(--intel-text-primary);cursor:pointer;transition:all .2s ease}.command-select:hover{border-color:var(--intel-gold-dim)}.command-select:focus{outline:none;border-color:var(--intel-gold);box-shadow:0 0 0 3px #d4af3726}.command-search{padding:.625rem 1rem;background:var(--intel-bg-elevated);border:1px solid var(--intel-border);border-radius:6px;font-family:var(--font-intel);font-size:.8125rem;color:var(--intel-text-primary);min-width:320px;transition:all .2s ease}.command-search:hover{border-color:var(--intel-gold-dim)}.command-search:focus{outline:none;border-color:var(--intel-gold);box-shadow:0 0 0 3px #d4af3726}.command-search::-moz-placeholder{color:var(--intel-text-muted)}.command-search::placeholder{color:var(--intel-text-muted)}.po-aging-actions-section{position:relative;z-index:1;margin-bottom:2rem}.action-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.action-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:var(--intel-bg-card);border:1px solid var(--intel-border);border-radius:12px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.action-card:hover{border-color:var(--intel-gold-dim);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.action-icon{font-size:1.5rem;flex-shrink:0;filter:grayscale(.2)}.action-label{flex:1;font-family:var(--font-display);font-size:.875rem;font-weight:600;color:var(--intel-text-primary)}.action-arrow{font-size:1.25rem;color:var(--intel-gold);flex-shrink:0;transition:transform .2s ease}.action-card:hover .action-arrow{transform:translate(4px)}@media(max-width:1024px){.action-cards-grid{grid-template-columns:1fr}}.error-state{max-width:560px;margin:4rem auto;text-align:center;background:var(--intel-bg-card);border:1px solid rgba(239,68,68,.3);border-radius:16px;padding:3rem}.error-state .error-icon{font-size:4rem;margin-bottom:1rem;filter:grayscale(.2)}.error-state h2{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--threat-critical);margin:0 0 1rem}.error-state p{color:var(--intel-text-secondary);margin-bottom:2rem;font-family:var(--font-intel);font-size:.875rem}.command-button{padding:.75rem 1.5rem;background:var(--intel-bg-elevated);border:1px solid var(--intel-gold-dim);border-radius:8px;font-family:var(--font-display);font-size:.875rem;font-weight:600;color:var(--intel-gold);cursor:pointer;transition:all .2s ease}.command-button:hover{background:#d4af3726;border-color:var(--intel-gold)}@media(max-width:768px){.po-aging-dashboard{padding:1rem}.command-title{font-size:1.5rem}.command-search{min-width:100%}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.section-filters{flex-direction:column;align-items:stretch;width:100%}.filter-group{flex-direction:column;align-items:stretch}.active-filters{flex-wrap:wrap}}.po-aging-dashboard .recharts-tooltip-wrapper{outline:none}.po-aging-dashboard .recharts-default-tooltip{background:var(--intel-bg-elevated)!important;border:1px solid var(--intel-border)!important;border-radius:8px!important;box-shadow:0 8px 32px #00000080!important}.po-aging-dashboard .recharts-tooltip-label{color:var(--intel-gold)!important;font-family:var(--font-display)!important;font-weight:600!important}.po-aging-dashboard .recharts-tooltip-item{color:var(--intel-text-primary)!important;font-family:var(--font-intel)!important}.po-aging-dashboard .recharts-legend-item-text{color:var(--intel-text-secondary)!important;font-family:var(--font-intel)!important;font-size:.75rem!important}.po-aging-dashboard .kpi-card{background:var(--intel-bg-card)!important;border:1px solid var(--intel-border)!important;box-shadow:0 4px 20px #0000004d!important}.po-aging-dashboard .kpi-card__backdrop{background:transparent!important}.po-aging-dashboard .kpi-card__border-glow{opacity:0!important}.po-aging-dashboard .kpi-card__title{color:var(--intel-text-secondary)!important;font-family:var(--font-display)!important;font-size:.75rem!important;text-transform:uppercase!important;letter-spacing:.08em!important}.po-aging-dashboard .kpi-card__value{color:var(--intel-text-primary)!important;font-family:var(--font-intel)!important}.po-aging-dashboard .kpi-card__subtitle{color:var(--intel-text-muted)!important;font-family:var(--font-intel)!important;font-size:.75rem!important}.po-aging-dashboard .kpi-card__status-bar{background:var(--intel-gold)!important;opacity:.6!important}.po-aging-dashboard .kpi-card__currency-icon{color:var(--intel-gold)!important}.po-aging-dashboard .kpi-card.status-critical,.po-aging-dashboard .kpi-card.kpi-card--critical-alert{border-color:#ef444480!important;background:linear-gradient(135deg,rgba(239,68,68,.15) 0%,var(--intel-bg-card) 60%)!important}.po-aging-dashboard .kpi-card.status-critical .kpi-card__value,.po-aging-dashboard .kpi-card.kpi-card--critical-alert .kpi-card__value{color:var(--threat-critical)!important;text-shadow:0 0 25px var(--threat-critical-glow)!important}.po-aging-dashboard .kpi-card.status-critical .kpi-card__status-bar,.po-aging-dashboard .kpi-card.kpi-card--critical-alert .kpi-card__status-bar{background:var(--threat-critical)!important;box-shadow:0 0 15px var(--threat-critical-glow)!important;opacity:1!important}.po-aging-dashboard .kpi-card.status-warning{border-color:#eab30880!important;background:linear-gradient(135deg,rgba(234,179,8,.12) 0%,var(--intel-bg-card) 60%)!important}.po-aging-dashboard .kpi-card.status-warning .kpi-card__value{color:var(--threat-medium)!important}.po-aging-dashboard .kpi-card.status-warning .kpi-card__status-bar{background:var(--threat-medium)!important;opacity:1!important}.po-aging-dashboard .kpi-card.status-good{border-color:#22c55e80!important;background:linear-gradient(135deg,rgba(34,197,94,.1) 0%,var(--intel-bg-card) 60%)!important}.po-aging-dashboard .kpi-card.status-good .kpi-card__value{color:var(--threat-low)!important}.po-aging-dashboard .kpi-card.status-good .kpi-card__status-bar{background:var(--threat-low)!important;opacity:1!important}.po-aging-dashboard .kpi-card.status-info{border-color:var(--intel-border)!important}.po-aging-dashboard .kpi-card.status-info .kpi-card__status-bar{background:var(--intel-gold)!important;opacity:.5!important}.po-aging-dashboard .kpi-card__trend--up{color:var(--threat-critical)!important}.po-aging-dashboard .kpi-card__trend--down{color:var(--threat-low)!important}.po-aging-dashboard .kpi-card__icon{background:#d4af3726!important;color:var(--intel-gold)!important}.po-status-section .status-badge{background:#2563eb1a;color:#2563eb;font-size:.7rem;padding:.25rem .5rem;border-radius:4px;font-weight:600}.loading-state-inline{padding:2rem;text-align:center;color:var(--intel-text-secondary, #94a3b8);font-size:.9rem;background:#00000005;border-radius:8px}.error-state-inline{padding:2rem;text-align:center;color:var(--threat-critical, #dc2626);font-size:.9rem;background:#dc26260d;border-radius:8px}.po-status-section .kpi-card.status-good{border-color:var(--threat-low, #059669)!important}.po-status-section .kpi-card.status-good .kpi-card__status-bar{background:var(--threat-low, #059669)!important}.po-status-section .kpi-card.status-warning{border-color:var(--threat-medium, #f59e0b)!important}.po-status-section .kpi-card.status-warning .kpi-card__status-bar{background:var(--threat-medium, #f59e0b)!important}.revenue-breakdown-page{min-height:100vh;background:var(--bg-primary);padding-bottom:3rem}.revenue-breakdown-page .dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.revenue-breakdown-page .header-left{display:flex;align-items:center;gap:1rem}.revenue-breakdown-page .company-logo{height:48px;width:auto}.revenue-breakdown-page .main-title{font-family:var(--font-display);font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.revenue-breakdown-page .sub-title{font-family:var(--font-body);font-size:.875rem;color:var(--text-secondary);margin:0}.back-to-cfo-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:all .2s ease}.back-to-cfo-btn:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.revenue-breakdown-page .dashboard-section{margin:1.5rem 2rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-primary)}.revenue-breakdown-page .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-secondary)}.revenue-breakdown-page .section-title{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;margin:0}.revenue-breakdown-page .section-badge{padding:.375rem .75rem;background:#2563eb1a;color:#2563eb;border-radius:20px;font-family:var(--font-body);font-size:.75rem;font-weight:500}.revenue-breakdown-page .section-badge.info{background:#10b9811a;color:#10b981}.validation-note{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:8px;margin-top:1.5rem;color:#f59e0b;font-family:var(--font-body);font-size:.875rem}.validation-note strong{color:var(--text-primary)}.project-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.project-revenue-card{padding:1.25rem;background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left}.project-revenue-card:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.project-revenue-card.selected{border-color:var(--accent-primary);background:#2563eb0d}.project-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.project-id{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);background:var(--bg-primary);padding:.25rem .5rem;border-radius:4px}.project-percentage{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--accent-primary)}.project-name{font-family:var(--font-body);font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem}.project-revenue-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.project-doc-count{font-family:var(--font-body);font-size:.75rem;color:var(--text-tertiary);margin-bottom:.75rem}.contribution-bar{height:6px;background:var(--bg-primary);border-radius:3px;overflow:hidden}.contribution-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),#10b981);border-radius:3px;transition:width .3s ease}.fiscal-year-section{animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.close-detail-btn{padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:all .2s ease}.close-detail-btn:hover{background:var(--threat-critical);color:#fff;border-color:var(--threat-critical)}.fiscal-year-table{width:100%;border-collapse:collapse;font-family:var(--font-body)}.fiscal-year-table th,.fiscal-year-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-secondary)}.fiscal-year-table th{font-family:var(--font-display);font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-tertiary)}.fiscal-year-table tbody tr:hover{background:var(--bg-tertiary)}.fy-cell .fy-badge{display:inline-block;padding:.375rem .75rem;background:var(--accent-primary);color:#fff;border-radius:4px;font-family:var(--font-mono);font-size:.875rem;font-weight:600}.doc-count-cell{font-family:var(--font-mono);color:var(--text-secondary)}.currency-cell{font-family:var(--font-mono);font-size:.875rem;color:var(--text-tertiary)}.amount-cell{font-family:var(--font-mono);font-size:.875rem}.amount-cell.native{color:var(--text-secondary)}.amount-cell.usd{color:var(--text-primary);font-weight:600}.period-cell{font-family:var(--font-mono);font-size:.75rem;color:var(--text-tertiary)}.fiscal-year-table tfoot .total-row{background:var(--bg-tertiary)}.fiscal-year-table tfoot .total-row td{font-weight:600;color:var(--text-primary);border-top:2px solid var(--border-primary)}.fiscal-year-table tfoot .total-row .amount-cell.total{color:var(--accent-primary);font-size:1rem}.revenue-matrix-container{overflow-x:auto}.revenue-matrix-table{width:100%;min-width:800px;border-collapse:collapse;font-family:var(--font-body)}.revenue-matrix-table th,.revenue-matrix-table td{padding:.875rem 1rem;text-align:right;border-bottom:1px solid var(--border-secondary)}.revenue-matrix-table th{font-family:var(--font-display);font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-tertiary)}.revenue-matrix-table .project-col{text-align:left;min-width:120px}.project-id-badge{display:inline-block;padding:.25rem .5rem;background:var(--bg-primary);color:var(--text-secondary);border-radius:4px;font-family:var(--font-mono);font-size:.75rem}.revenue-matrix-table .fy-col{min-width:100px}.revenue-matrix-table .total-col{min-width:120px;background:#2563eb0d}.revenue-matrix-table tbody tr:hover{background:var(--bg-tertiary)}.revenue-matrix-table .amount-cell{font-family:var(--font-mono);font-size:.875rem;color:var(--text-primary)}.revenue-matrix-table .amount-cell.empty{color:var(--text-tertiary)}.revenue-matrix-table tfoot .grand-total-row{background:var(--bg-tertiary)}.revenue-matrix-table tfoot .grand-total-row td{font-weight:600;color:var(--text-primary);border-top:2px solid var(--border-primary)}.revenue-matrix-table tfoot .total-col.grand{background:#2563eb26;color:var(--accent-primary);font-size:1rem}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:2rem;text-align:center;color:var(--text-secondary)}.error-state svg{color:var(--threat-critical);margin-bottom:1rem}.error-state h2{font-family:var(--font-display);font-size:1.5rem;color:var(--text-primary);margin-bottom:.5rem}.error-state p{margin-bottom:1.5rem}.error-state .back-btn{padding:.75rem 1.5rem;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:all .2s ease}.error-state .back-btn:hover{background:#1d4ed8}.user-management-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;display:flex;justify-content:space-between;align-items:center}.header-title{display:flex;align-items:center;gap:.75rem}.header-title h1{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1f2937);margin:0}.header-title svg{color:#3b82f6}.header-actions{display:flex;gap:.75rem}.btn-primary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-secondary{padding:.625rem 1.25rem;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#e5e7eb}.btn-refresh{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;transition:all .2s ease}.btn-refresh:hover{background:#e5e7eb}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fffffff2;border-radius:12px;padding:1.25rem;border:1px solid var(--border-color, #e5e7eb);text-align:center}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary, #1f2937)}.stat-label{font-size:.75rem;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.stat-active .stat-value{color:#059669}.stat-admin .stat-value{color:#7c3aed}.stat-viewer .stat-value{color:#3b82f6}.users-table-container{background:#fffffff2;border-radius:16px;border:1px solid var(--border-color, #e5e7eb);overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table th{padding:1rem 1.5rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.05em;background:#f9fafb;border-bottom:1px solid #e5e7eb}.users-table td{padding:1rem 1.5rem;font-size:.875rem;color:var(--text-primary, #1f2937);border-bottom:1px solid #f3f4f6}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover{background:#3b82f605}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.role-admin,.role-super_admin{background:#f3e8ff;color:#7c3aed}.role-viewer{background:#dbeafe;color:#2563eb}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.status-badge.active{background:#d1fae5;color:#059669}.status-badge.inactive{background:#fee2e2;color:#dc2626}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;color:#6b7280;cursor:pointer;transition:all .2s ease}.btn-icon:hover{background:#f3f4f6;color:#374151}.btn-icon.btn-danger:hover{background:#fee2e2;color:#dc2626}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:16px;padding:2rem;width:100%;max-width:480px;box-shadow:0 20px 60px #0003}.modal h2{font-size:1.25rem;font-weight:700;color:var(--text-primary, #1f2937);margin:0 0 1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary, #6b7280);margin-bottom:.5rem}.form-group input,.form-group select{width:100%;padding:.75rem 1rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.875rem;color:var(--text-primary, #1f2937);background:#fff;transition:all .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:var(--text-secondary, #6b7280);text-align:center}.access-denied svg{color:#dc2626;margin-bottom:1rem}.access-denied h2{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1f2937);margin:0}@media(max-width:768px){.user-management-page{padding:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column;gap:1rem;align-items:stretch}.header-actions{justify-content:flex-end}.users-table-container{overflow-x:auto}}
