body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.data-pipeline-docs{background-color:var(--background-color);margin:0 auto;max-width:1200px;min-height:100vh;padding:2rem}.docs-header{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:12px;box-shadow:var(--shadow);color:#fff;margin-bottom:2rem;padding:2rem;text-align:center}.docs-header h1{font-size:2.5rem;font-weight:600;margin:0 0 .5rem}.docs-subtitle{font-size:1.1rem;margin:0;opacity:.9}.docs-tabs{border-bottom:2px solid var(--border-color);display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:2rem}.docs-tabs .tab{background:none;border:none;border-bottom:3px solid #0000;border-radius:4px 4px 0 0;color:var(--text-color);cursor:pointer;font-weight:500;padding:1rem 1.5rem;transition:all .2s ease}.docs-tabs .tab:hover{background-color:var(--primary-light);color:var(--primary-dark)}.docs-tabs .tab.active{border-bottom-color:var(--primary-color);color:var(--primary-color)}.docs-content,.docs-tabs .tab.active{background-color:var(--card-background)}.docs-content{border-radius:8px;box-shadow:var(--shadow);min-height:600px;padding:2rem}.tab-content h2{border-bottom:2px solid var(--primary-light);color:var(--primary-color);margin-bottom:1.5rem;padding-bottom:.5rem}.tab-content h3{color:var(--primary-dark);margin-bottom:1rem;margin-top:2rem}.tab-content h4{color:var(--text-color);margin-bottom:.75rem;margin-top:1.5rem}.units-requirement{background:var(--warning-color);background:#ff98001a;border:2px solid var(--warning-color);border-radius:8px;margin:2rem 0;padding:2rem}.units-requirement h3{color:var(--warning-color);margin-top:0}.supported-units-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:1.5rem 0}.units-card{background:var(--card-background);border:1px solid var(--border-color);border-radius:6px;padding:1rem}.units-card h5{color:var(--primary-dark);font-size:.9rem;font-weight:600;margin-bottom:.75rem;margin-top:0;text-transform:uppercase}.units-card ul{margin:0;padding-left:1rem}.units-card li{font-size:.85rem;line-height:1.4;margin-bottom:.4rem}.units-card code{background:var(--primary-light);border-radius:3px;color:var(--primary-dark);font-weight:600;padding:.1rem .3rem}.conversion-note{background:var(--success-color);background:#4caf501a;border-left:1px solid var(--success-color);border:1px solid var(--success-color);border-left-width:4px;border-radius:6px;margin:2rem 0;padding:1.5rem}.conversion-note h4{color:var(--success-color);margin-top:0}.conversion-note ul{margin:1rem 0;padding-left:1.5rem}.conversion-note li{line-height:1.5;margin-bottom:.5rem}.conversion-note strong{color:var(--success-color)}.integration-flow{background:var(--background-color);border-radius:8px;margin:2rem 0;padding:1.5rem}.integration-flow h3{color:var(--primary-color);margin-top:0}.integration-flow ol{margin:1rem 0;padding-left:1.5rem}.integration-flow li{line-height:1.5;margin-bottom:.75rem}.integration-flow strong{color:var(--primary-dark)}.endpoint-status{background:var(--success-color);border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;padding:.2rem .6rem}.stage-id-info{background:var(--info-color);background:#2196f31a;border:1px solid var(--info-color);border-radius:6px;margin:1.5rem 0;padding:1.5rem}.stage-id-info h4{color:var(--info-color);margin-top:0}.common-issues{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:2rem 0}.issue-card{background:var(--card-background);border-left:1px solid var(--danger-color);border:1px solid var(--danger-color);border-left-width:4px;border-radius:6px;padding:1.5rem}.issue-card h4{color:var(--danger-color);margin-bottom:1rem;margin-top:0}.issue-card ul{margin:0;padding-left:1.2rem}.issue-card li{line-height:1.4;margin-bottom:.5rem}.script-validator{background:var(--background-color);border-radius:8px;margin:2rem 0;padding:2rem}.script-input{border:1px solid var(--border-color);border-radius:6px;font-family:Fira Code,Monaco,Consolas,monospace;font-size:.9rem;line-height:1.5;margin-bottom:1rem;min-height:200px;padding:1rem;resize:vertical;width:100%}.script-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #1a73e81a;outline:none}.validate-script-btn{background:var(--primary-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s}.validate-script-btn:hover{background:var(--primary-dark)}.testing-note{background:var(--primary-light);border:1px solid var(--primary-color);border-radius:6px;margin:2rem 0;padding:1.5rem}.testing-note h4{color:var(--primary-color);margin-top:0}.testing-note ul{margin:1rem 0;padding-left:1.5rem}.testing-note li{line-height:1.5;margin-bottom:.5rem}.overview-card{background:var(--primary-light);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;transition:transform .2s ease}.overview-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.overview-card h3{color:var(--primary-dark);font-size:1.1rem;margin-bottom:1rem;margin-top:0}.overview-card p{color:var(--text-color);line-height:1.5;margin:0}.quick-start{background:var(--card-background);border:1px solid var(--border-color);border-left:4px solid var(--primary-color);border-radius:4px;margin:2rem 0;padding:1.5rem}.quick-start h3{color:var(--primary-color);margin-top:0}.quick-start ol{margin:1rem 0;padding-left:1.5rem}.quick-start li{line-height:1.5;margin-bottom:.5rem}.base-url-info{background:var(--background-color);border-radius:6px;margin:2rem 0;padding:1.5rem}.code-block{background:#1e1e1e;border-radius:6px;box-shadow:0 2px 8px #0000001a;margin:1rem 0;overflow:hidden}.code-header{align-items:center;background:#2d2d2d;border-bottom:1px solid #404040;display:flex;justify-content:space-between;padding:.5rem 1rem}.language-tag{color:#a0a0a0;font-size:.8rem;font-weight:500;text-transform:uppercase}.copy-btn{background:var(--primary-color);border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:.8rem;padding:.25rem .5rem;transition:background-color .2s}.copy-btn:hover{background:var(--primary-dark)}.code-block pre{background:#0000;margin:0;overflow-x:auto;padding:1rem}.code-block code{color:#f8f8f2;font-family:Fira Code,Monaco,Consolas,monospace;font-size:.9rem;line-height:1.5}.api-endpoint{background:var(--card-background);border:1px solid var(--border-color);border-radius:8px;margin:1.5rem 0;padding:1.5rem}.endpoint-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.method-badge{border-radius:4px;color:#fff;font-size:.8rem;font-weight:600;padding:.3rem .8rem;text-transform:uppercase}.method-badge.get{background-color:var(--success-color)}.method-badge.post{background-color:var(--primary-color)}.method-badge.put{background-color:var(--warning-color)}.method-badge.delete{background-color:var(--danger-color)}.endpoint-path{background:var(--background-color);border-radius:4px;flex:1 1;font-family:monospace;font-size:.9rem;min-width:200px;padding:.3rem .8rem}.test-btn{background:var(--secondary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.85rem;padding:.5rem 1rem;transition:background-color .2s}.test-btn:hover:not(:disabled){background:#45a049}.test-btn:disabled{background:var(--text-light);cursor:not-allowed}.endpoint-description{color:var(--text-light);font-style:italic;margin:0 0 1rem}.field-table-container{border:1px solid var(--border-color);border-radius:6px;margin:1rem 0;overflow-x:auto}.field-table{background:var(--card-background);border-collapse:collapse;width:100%}.field-table td,.field-table th{border-bottom:1px solid var(--border-color);padding:.75rem;text-align:left}.field-table th{background:var(--background-color);color:var(--text-color);font-weight:600;position:sticky;top:0}.field-table tbody tr:hover{background:var(--primary-light)}.field-table code{background:var(--background-color);border-radius:3px;font-size:.85rem;padding:.2rem .4rem}.required-yes{color:var(--success-color);font-weight:700}.required-no{color:var(--text-light)}.auth-note{background:var(--warning-color);background:#ff98001a;border:1px solid var(--warning-color);border-radius:6px;margin:2rem 0;padding:1.5rem}.auth-note h4{color:var(--warning-color);margin-top:0}.auth-note ul{margin:1rem 0;padding-left:1.5rem}.auth-note li{line-height:1.5;margin-bottom:.5rem}.data-note{background:var(--info-color);background:#2196f31a;border:1px solid var(--info-color);border-radius:6px;margin:2rem 0;padding:1.5rem}.data-note h4{color:var(--info-color);margin-top:0}.data-note ul{margin:1rem 0;padding-left:1.5rem}.data-note li{line-height:1.5;margin-bottom:.5rem}.validation-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:2rem 0}.validation-card{background:var(--card-background);border:1px solid var(--border-color);border-radius:6px;padding:1.5rem}.validation-card h4{color:var(--primary-color);margin-bottom:1rem;margin-top:0}.validation-card ul{margin:0;padding-left:1.2rem}.validation-card li{line-height:1.4;margin-bottom:.5rem}.logical-validations{margin:2rem 0}.logic-rule{background:var(--background-color);border-radius:6px;margin:1.5rem 0;padding:1.5rem}.logic-rule h4{color:var(--primary-dark);margin-bottom:1rem;margin-top:0}.logic-rule p{color:var(--text-light);font-style:italic;margin:1rem 0 0}.test-section{background:var(--background-color);border-radius:8px;margin:2rem 0;padding:2rem}.test-buttons{display:flex;flex-wrap:wrap;gap:1rem;margin:1.5rem 0}.test-api-btn{background:var(--primary-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:1rem 1.5rem;transition:background-color .2s}.test-api-btn:hover:not(:disabled){background:var(--primary-dark)}.test-api-btn:disabled{background:var(--text-light);cursor:not-allowed}.test-result{border-radius:6px;margin:2rem 0;overflow:hidden}.test-result.success{border:2px solid var(--success-color)}.test-result.error{border:2px solid var(--danger-color)}.test-result h4{background:var(--background-color);color:var(--text-color);margin:0;padding:1rem}.testing-checklist{margin:2rem 0}.checklist-item{align-items:center;background:var(--card-background);border:1px solid var(--border-color);border-radius:4px;display:flex;gap:.75rem;margin:1rem 0;padding:.75rem;transition:background-color .2s}.checklist-item:hover{background:var(--primary-light)}.checklist-item input[type=checkbox]{transform:scale(1.2)}.checklist-item label{cursor:pointer;line-height:1.4;margin:0}.test-samples{margin:2rem 0}.test-samples h4{color:var(--primary-dark);margin-bottom:1rem}.status-codes{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:2rem 0}.status-code{border-radius:6px;font-weight:500;padding:1rem;text-align:center}.status-code.success{background:#4caf501a;border:1px solid var(--success-color);color:var(--success-color)}.status-code.error{background:#f443361a;border:1px solid var(--danger-color);color:var(--danger-color)}@media (max-width:768px){.data-pipeline-docs{padding:1rem}.docs-header{padding:1.5rem}.docs-header h1{font-size:2rem}.docs-tabs{flex-direction:column}.docs-tabs .tab{text-align:center}.docs-content{padding:1.5rem}.overview-grid{grid-template-columns:1fr}.endpoint-header{align-items:stretch;flex-direction:column}.endpoint-path{min-width:auto}.validation-grid{grid-template-columns:1fr}.test-buttons{flex-direction:column}.status-codes{grid-template-columns:1fr}.field-table-container{font-size:.85rem}}@media (max-width:480px){.docs-header h1{font-size:1.5rem}.docs-subtitle{font-size:1rem}.code-block code{font-size:.8rem}}.public-page-wrapper{align-items:center;background:linear-gradient(#2c5aa0d9,#2c5aa0d9),url(/static/media/ro-plant-background.2f452d5bb8a6f5162b4e.jpg) 50%;background-attachment:fixed;background-repeat:no-repeat;background-size:cover;display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow-x:hidden;padding:2rem 1rem;position:relative;width:100%}.public-page{height:100%;margin:0;overflow-x:hidden;padding:0}.public-page .app-container{min-height:100vh;width:100%}.public-page-wrapper:before{background:linear-gradient(135deg,#2c5aa01a,#2c5aa04d 50%,#2c5aa01a);content:"";inset:0;pointer-events:none;position:absolute;z-index:1}.public-page-wrapper>*{position:relative;z-index:2}@media (max-width:768px){.public-page-wrapper{background-attachment:scroll;min-height:100vh;min-height:100dvh;padding:1rem .5rem}}@media (min-width:769px) and (max-width:1024px){.public-page-wrapper{padding:2rem 1.5rem}}@media (min-width:1025px){.public-page-wrapper{padding:3rem 2rem}}.landing-container{background:linear-gradient(#2c5aa0d9,#2c5aa0d9),url(/static/media/ro-plant-background.2f452d5bb8a6f5162b4e.jpg) 50%;background-attachment:fixed;background-repeat:no-repeat;background-size:cover;color:#fff;min-height:100vh;overflow-x:hidden}.landing-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-bottom:1px solid #fff3;padding:1.5rem 0;position:relative;z-index:10}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.logo-section{display:flex;flex-direction:column}.brand-title{color:#fff;font-size:2.5rem;font-weight:700;margin:0;text-shadow:0 2px 4px #0000004d}.brand-tagline{color:#ffffffe6;font-size:1rem;font-weight:300;margin:0}.landing-nav{align-items:center;display:flex;gap:1rem}.nav-btn{border:2px solid #0000;border-radius:6px;font-weight:500;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.login-btn{border-color:#ffffff4d;color:#fff}.login-btn:hover{background:#ffffff1a;text-decoration:none}.signup-btn{background:#fff;color:var(--primary-color);font-weight:600}.signup-btn:hover{background:#ffffffe6;box-shadow:0 4px 15px #0003;text-decoration:none;transform:translateY(-2px)}.hero-section{padding:6rem 0;position:relative}.hero-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;padding:0 2rem}.hero-text{z-index:5}.hero-title{color:#fff;font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:1.5rem;text-shadow:0 2px 4px #0000004d}.highlight{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ff9800,#f99);-webkit-background-clip:text;background-clip:text;font-weight:800}.hero-description{color:#ffffffe6;font-size:1.2rem;font-weight:300;line-height:1.6;margin-bottom:2.5rem}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}.cta-button{border-radius:8px;display:inline-block;font-size:1.1rem;font-weight:600;min-width:160px;padding:1rem 2rem;text-align:center;text-decoration:none;transition:all .3s ease}.cta-button.primary{background:linear-gradient(135deg,#ff9800,#f99);box-shadow:0 4px 15px #ffd7004d;color:var(--primary-color)}.cta-button.primary:hover{box-shadow:0 8px 25px #ffd70066;text-decoration:none;transform:translateY(-3px)}.cta-button.secondary{background:#0000;border:2px solid #ffffff4d;color:#fff}.cta-button.secondary:hover{background:#ffffff1a;border-color:#fff9;text-decoration:none}.cta-button.large{font-size:1.2rem;padding:1.25rem 2.5rem}.hero-visual{position:relative;z-index:3}.dashboard-preview{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:12px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.preview-header{background:var(--primary-color);color:#fff;padding:1rem}.health-map-image{border-radius:0 0 12px 12px;display:block;height:auto;max-height:300px;object-fit:cover;width:100%}.preview-content{display:block;padding:0}.preview-tabs{display:flex;gap:.5rem}.tab{background:#ffffff1a;border-radius:6px;font-size:.9rem;opacity:.7;padding:.5rem 1rem}.tab.active{background:#fff3;opacity:1}.preview-content{grid-gap:1rem;display:grid;gap:1rem;padding:1.5rem}.metric-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1rem}.metric-card h4{color:var(--text-color);font-size:.9rem;font-weight:600;margin-bottom:.75rem}.metric-chart{background:linear-gradient(90deg,var(--primary-light) 0,var(--primary-color) 50%,var(--primary-light) 100%);border-radius:4px;height:40px;overflow:hidden;position:relative}.metric-chart:after{animation:shimmer 2s infinite;background:linear-gradient(45deg,#0000 30%,#ffffff4d 50%,#0000 70%);content:"";inset:0;position:absolute}.features-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;padding:6rem 0}.features-content{margin:0 auto;max-width:1200px;padding:0 2rem}.section-title{color:#fff;font-size:2.5rem;font-weight:600;margin-bottom:3rem;text-align:center;text-shadow:0 2px 4px #0000004d}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.feature-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;padding:2rem;text-align:center;transition:all .3s ease}.feature-card:hover{background:#ffffff26;box-shadow:0 15px 40px #0003;transform:translateY(-8px)}.feature-icon{display:block;font-size:3rem;margin-bottom:1rem}.feature-card h4{color:#fff;font-size:1.3rem;font-weight:600;margin-bottom:1rem}.feature-card p{color:#fffc;font-weight:300;line-height:1.6}.value-proposition-section{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0000001a;padding:6rem 0;position:relative}.value-proposition-content{margin:0 auto;max-width:1200px;padding:0 2rem}.value-proposition-content .section-title{color:#fff}.value-proposition-subtitle{color:#ffffffe6;font-size:1.3rem;font-weight:300;line-height:1.5;margin-bottom:4rem;margin-left:auto;margin-right:auto;max-width:800px;text-align:center}.value-points-grid{grid-gap:2.5rem;display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:3rem}.value-point{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;overflow:hidden;padding:2.5rem;position:relative;text-align:left;transition:all .3s ease}.value-point:before{background:linear-gradient(135deg,gold,#ffed4e);border-radius:12px 12px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.value-point:hover{background:#ffffff26;box-shadow:0 20px 60px #0000004d;transform:translateY(-8px)}.value-icon{display:block;font-size:3.5rem;line-height:1;margin-bottom:1.5rem}.value-point h4{color:#fff;font-size:1.4rem;font-weight:600;line-height:1.3;margin-bottom:1.5rem}.value-point p{color:#ffffffd9;font-size:1rem;font-weight:300;line-height:1.7}@media (max-width:1024px){.value-points-grid{gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.value-point{padding:2rem}.value-proposition-subtitle{font-size:1.2rem;margin-bottom:3rem}}@media (max-width:768px){.value-proposition-section{padding:4rem 0}.value-points-grid{gap:1.5rem;grid-template-columns:1fr}.value-point{padding:1.5rem;text-align:center}.value-point h4{font-size:1.2rem;margin-bottom:1rem}.value-icon{font-size:3rem;margin-bottom:1rem}.value-proposition-subtitle{font-size:1.1rem;margin-bottom:2rem}}@media (max-width:480px){.value-point{padding:1.25rem}.value-point h4{font-size:1.1rem}.value-point p{font-size:.95rem}.value-icon{font-size:2.5rem}}.metrics-overview{padding:6rem 0}.overview-content{margin:0 auto;max-width:1000px;padding:0 2rem;text-align:center}.metrics-showcase{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:3rem}.metric-highlight{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;padding:2rem}.metric-highlight h4{color:gold;font-size:1.2rem;font-weight:600;margin-bottom:1rem}.metric-highlight p{color:#fffc;font-weight:300;line-height:1.6}.cta-section{background:#0003;padding:6rem 0;text-align:center}.cta-content{margin:0 auto;max-width:800px;padding:0 2rem}.cta-content h3{color:#fff;font-size:2.5rem;font-weight:600;margin-bottom:1rem}.cta-content p{color:#ffffffe6;font-size:1.2rem;font-weight:300;margin-bottom:2.5rem}.cta-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.landing-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000004d;border-top:1px solid #ffffff1a}.footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 2fr;margin:0 auto;max-width:1200px;padding:3rem 2rem 2rem}.footer-brand h4{color:#fff;font-size:1.5rem;margin-bottom:.5rem}.footer-brand p{color:#ffffffb3;font-weight:300}.footer-links{display:flex;gap:3rem}.link-group h5{color:#fff;font-weight:600;margin-bottom:1rem}.link-group a,.link-group span{color:#ffffffb3;display:block;font-weight:300;margin-bottom:.5rem;text-decoration:none}.link-group a:hover{color:#fff;text-decoration:none}.footer-bottom{border-top:1px solid #ffffff1a;color:#fff9;font-weight:300;padding:1.5rem 2rem;text-align:center}@media (max-width:1024px){.hero-content{gap:3rem;grid-template-columns:1fr;text-align:center}.hero-title{font-size:3rem}}@media (max-width:768px){.landing-container{background-attachment:scroll}.header-content{flex-direction:column;gap:1rem;text-align:center}.brand-title{font-size:2rem}.hero-section{padding:4rem 0}.hero-title{font-size:2.5rem}.hero-description{font-size:1.1rem}.hero-actions{align-items:center;flex-direction:column}.cta-button{max-width:280px;width:100%}.section-title{font-size:2rem}.features-grid,.footer-content,.metrics-showcase{grid-template-columns:1fr}.footer-content{text-align:center}.footer-links{justify-content:center}.cta-actions{align-items:center;flex-direction:column}}@media (max-width:480px){.hero-title{font-size:2rem}.hero-actions{width:100%}.nav-btn{font-size:.9rem;padding:.5rem 1rem}.landing-nav{flex-direction:column;gap:.5rem;width:100%}}

/* !* ========================================================================== */.signup-form-wrapper{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fffffff2;border:1px solid #fff3;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-width:600px;padding:2rem;width:100%}.signup-header{margin-bottom:2rem;text-align:center}.signup-header h1{color:#2c5aa0;font-size:2.2rem;font-weight:600;margin-bottom:.5rem;text-shadow:0 2px 4px #0000001a}.signup-header h3{color:#555;font-size:1.1rem;font-weight:400;margin:0}.signup-form-content{text-align:left}.signup-form-content .form-section{background:none;border-radius:0;box-shadow:none;margin-bottom:1.5rem;padding:0}.signup-form-content .section-title{color:#333;font-size:1.1rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem}.signup-form-row{display:flex;flex-direction:row;gap:1rem}.signup-form-content .signup-form-field,.signup-form-row{margin-bottom:1rem}.signup-form-content .signup-form-field label{color:#333;display:block;font-weight:500;margin-bottom:.5rem}.signup-form-content .signup-form-field input,.signup-form-content .signup-form-field select{background-color:#ffffffe6;border:2px solid #ddd;border-radius:6px;font-size:1rem;padding:.75rem;transition:all .3s ease;width:100%}.signup-form-content .signup-form-field input:focus,.signup-form-content .signup-form-field select:focus{background-color:#fff;border-color:#2c5aa0;box-shadow:0 0 0 3px #2c5aa01a;outline:none}.signup-form-content .signup-form-field input.error{border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a}.signup-form-content .signup-form-field input.success{border-color:#28a745;box-shadow:0 0 0 3px #28a7451a}.signup-submit-btn{background:linear-gradient(135deg,#2c5aa0,#1e3f73);border:none;border-radius:8px;box-shadow:0 4px 15px #2c5aa04d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.5px;margin-bottom:1rem;padding:.875rem;text-transform:uppercase;transition:all .3s ease;width:100%}.signup-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#1e3f73,#14316b);box-shadow:0 6px 20px #2c5aa066;transform:translateY(-2px)}.signup-submit-btn:active{transform:translateY(0)}.signup-submit-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.signup-submit-btn.loading{background:#6c757d;color:#000}.signup-submit-btn.duplicate-company{background:linear-gradient(135deg,#ffc107,#e0a800);color:#000}.signup-login-link .landing-link{color:#666;font-weight:500;margin-top:1rem;text-align:center}.signup-login-link a{color:#2c5aa0;font-weight:600;text-decoration:none}.signup-login-link a:hover{text-decoration:underline}

/* !* ========================================================================== */.popup-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.popup-content{animation:slideIn .3s ease;background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:500px;padding:2rem;width:90%}.popup-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.popup-header h3{color:#333;font-weight:600;margin:0}.popup-close{background:none;border:none;color:#666;cursor:pointer;font-size:1.5rem;height:auto;padding:0;transition:color .2s ease;width:auto}.popup-close:hover{color:#333}.popup-body{color:#666;line-height:1.6;margin-bottom:1.5rem}.popup-body p{margin-bottom:1rem}.popup-body p:last-child{margin-bottom:0}.popup-content.admin-notification,.popup-footer{text-align:center}.popup-success-icon{animation:bounce .6s ease;color:#28a745;font-size:4rem;margin-bottom:1rem}@keyframes bounce{0%,20%,60%,to{transform:translateY(0)}40%{transform:translateY(-10px)}80%{transform:translateY(-5px)}}.popup-content.admin-notification h3{color:#333;font-weight:600;margin:0 0 1rem}@media (max-width:768px){.login-container,.signup-container{background-attachment:scroll;padding:1rem .5rem}.login-form-wrapper,.signup-form-wrapper{padding:1.5rem}.login-form-wrapper h1,.signup-header h1{font-size:1.8rem}.popup-content{margin:1rem;padding:1.5rem}.popup-success-icon{font-size:3rem}}.password-reset-modal{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.password-reset-content{animation:slideIn .3s ease;background-color:var(--card-background);border-radius:8px;box-shadow:var(--shadow);max-width:450px;padding:2rem;position:relative;width:100%}.password-reset-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.password-reset-header h3{color:var(--primary-color);font-size:1.3rem;font-weight:600;margin:0}.password-reset-close{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-light);cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:color .2s,background-color .2s;width:30px}.password-reset-close:hover{background-color:var(--hover-background);color:var(--text-color)}.password-reset-form{display:flex;flex-direction:column}.password-reset-form .form-group{margin-bottom:1.5rem}.password-reset-form .form-group:last-child{margin-bottom:0}.password-reset-form label{color:var(--text-color);display:block;font-weight:500;margin-bottom:.5rem}.password-reset-form input{border:1px solid var(--border-color);border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s,box-shadow .2s;width:100%}.password-reset-form input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #1a73e81a;outline:none}.password-reset-submit{background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;margin-top:1rem;padding:.75rem;transition:background-color .2s;width:100%}.password-reset-submit:hover:not(:disabled){background-color:var(--primary-dark)}.password-reset-submit:disabled{cursor:not-allowed;opacity:.6}.password-reset-description{color:var(--text-light);font-size:.95rem;line-height:1.5;margin-bottom:1.5rem}.forgot-password-link{margin-top:1rem;text-align:center}.forgot-password-link button{background:none;border:none;color:var(--primary-color);cursor:pointer;font-family:inherit;font-size:.9rem;padding:0;text-decoration:underline}.forgot-password-link button:hover{color:var(--primary-dark)}.password-reset-success{color:var(--success-color);text-align:center}.password-reset-success-icon{font-size:3rem}.password-reset-success h3,.password-reset-success-icon{color:var(--success-color);margin-bottom:1rem}.password-reset-success p{color:var(--text-color);line-height:1.5}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.password-reset-content{margin:1rem;padding:1.5rem}.password-reset-header h3{font-size:1.2rem}}.login-form select{background-color:#fff;background-color:var(--input-background,#fff);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);cursor:pointer;font-size:1rem;padding:.75rem;width:100%}.login-form select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #1a73e81a;outline:none}.mfa-verification-container{margin-top:1rem}.mfa-code-input,.mfa-method-selector{margin-bottom:1.5rem}.mfa-code-input label{color:var(--text-color);display:block;font-size:.95rem;font-weight:500;line-height:1.4;margin-bottom:.5rem}.mfa-back-link{margin-top:1rem;text-align:center}.mfa-back-link button{align-items:center;background:none;border:none;color:var(--primary-color);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.9rem;gap:.25rem;padding:0;text-decoration:none}.mfa-back-link button:hover{color:var(--primary-dark);text-decoration:underline}.login-button:disabled{cursor:not-allowed;opacity:.7}.login-button.mfa-verifying{color:#0000;position:relative}.login-button.mfa-verifying:after{animation:mfa-spinner 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;content:"";height:16px;left:50%;margin:-8px 0 0 -8px;position:absolute;top:50%;width:16px}@keyframes mfa-spinner{to{transform:rotate(1turn)}}.mfa-form-description{color:var(--text-light);font-size:.9rem;line-height:1.4;margin-bottom:1.5rem;text-align:center}.mfa-method-description{color:var(--text-light);font-size:.85rem;font-style:italic;margin-top:.25rem}@media (max-width:480px){.login-form-wrapper{max-width:350px;padding:1.5rem}.mfa-code-input label{font-size:.9rem}.mfa-back-link button{font-size:.85rem}}:root{--primary-color:#1a73e8;--primary-dark:#0d47a1;--primary-light:#e8f0fe;--secondary-color:#4caf50;--warning-color:#ff9800;--danger-color:#f44336;--error-dark:#b91c1c;--success-color:#4caf50;--info-color:#2196f3;--text-color:#333;--text-light:#666;--text-dark:#333;--background-color:#f5f7fa;--card-background:#fff;--input-background:#fff;--hover-background:#f1f5f9;--success-background:#f0fdf4;--success-border:#bbf7d0;--border-color:#e0e0e0;--border-dark:#9ca3af;--header-height:60px;--sidebar-width:250px;--shadow:0 2px 5px 0 #0000001a}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f7fa;background-color:var(--background-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.6}body,h1,h2,h3,h4,h5,h6{color:#333;color:var(--text-color)}h1,h2,h3,h4,h5,h6{font-weight:500;line-height:1.2;margin-bottom:1rem}a{color:#1a73e8;color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer}.actions{align-items:center;display:flex;gap:.5rem;padding:1.5rem}.app-container{display:flex;flex-direction:column;min-height:100vh}.content-container{flex:fit-content 1;padding:1rem}.description-italics{color:#666;color:var(--text-light);font-style:italic;margin-bottom:1rem}.-name{font-weight:500;margin-bottom:.5rem}@media (min-width:768px){.app-container{flex-direction:row}.content-container{box-sizing:border-box;margin-left:250px;margin-left:var(--sidebar-width);max-width:calc(100vw - 250px);max-width:calc(100vw - var(--sidebar-width));overflow-x:hidden;width:calc(100vw - 250px);width:calc(100vw - var(--sidebar-width))}}

/*!* ==========================================================================*/.btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.btn-primary{background:#2c5aa0;color:#fff}.btn-primary:hover:not(:disabled){background:#1e3f73}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn:disabled{cursor:not-allowed;opacity:.6}.add-item-button{background-color:#2196f3;background-color:var(--info-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:500;padding:.5rem;transition:background-color .2s}.add-item-button:hover{background-color:#0d47a1;background-color:var(--primary-dark)}.view-item-button{background-color:#4caf50;background-color:var(--secondary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:500;padding:.5rem}.view-item-button:hover:not(:disabled){background-color:#45a049}.add-item-button:disabled,.view-item-button:disabled{background-color:#666;background-color:var(--text-light);cursor:not-allowed}.save-button{background-color:#1a73e8;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s}.save-button:hover{background-color:#0d47a1;background-color:var(--primary-dark)}.save-button:disabled{cursor:not-allowed;opacity:.7}.save-button:disabled,.save-button:disabled:hover{background-color:#666;background-color:var(--text-light)}.submit-button{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem}.submit-button:hover:not(:disabled){background:#218838}.submit-button:disabled{cursor:not-allowed;opacity:.6}.cancel-button{background-color:initial;border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;color:#333;color:var(--text-color);cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.cancel-button:hover{background-color:#e0e0e0;background-color:var(--border-color)}.close-button{align-items:center;background:none;border:none;color:#666;color:var(--text-light);cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;width:30px}.close-button:hover{color:#333;color:var(--text-color)}.danger-button{background-color:#f44336;background-color:var(--danger-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;min-width:100px;padding:.75rem 1.5rem;transition:background-color .2s ease,transform .1s ease}.danger-button:hover{background-color:#b91c1c;background-color:var(--error-dark,#b91c1c);transform:translateY(-1px)}.danger-button:active{transform:translateY(0)}.delete-button{background:none;border:none;border-radius:4px;color:#dc3545;cursor:pointer;font-size:1rem;padding:.25rem}.delete-button:hover{background-color:#f443361a;color:#f44336;color:var(--danger-color)}.delete-button:focus{outline:2px solid #f44336;outline:2px solid var(--danger-color);outline-offset:2px}.upgrade-button{border:none;border-radius:6px;cursor:pointer;font-weight:600;padding:.75rem 1rem;transition:all .2s;width:100%}.upgrade-button:disabled{cursor:not-allowed;opacity:.6}.trial-button{background:#2196f3;color:#fff}.trial-button:hover:not(:disabled){background:#1976d2}.po-button{background:#ff9800;color:#fff}.po-button:hover:not(:disabled){background:#f57c00}.cc-button{background:#4caf50;color:#fff}.cc-button:hover:not(:disabled){background:#388e3c}.loading-spinner{align-items:center;color:#666;color:var(--text-light);display:flex;font-style:italic;height:200px;justify-content:center}.no-stages-message{background-color:#e8f0fe;background-color:var(--primary-light);border-radius:8px;color:#333;color:var(--text-color);padding:2rem;text-align:center}.navigation{align-items:center;background-color:#1a73e8;background-color:var(--primary-color);box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);color:#fff;display:flex;height:60px;height:var(--header-height);justify-content:space-between;padding:0 1.5rem;position:fixed;top:0;width:100%;z-index:1000}.navigation .logo{font-size:1.5rem;font-weight:700}.navigation .nav-links{display:none}.navigation .mobile-menu-button{background:none;border:none;color:#fff;display:block;font-size:1.5rem}.mobile-nav{background-color:#0d47a1;background-color:var(--primary-dark);left:0;position:fixed;top:60px;top:var(--header-height);transform:translateY(-100%);transition:transform .3s ease-in-out;width:100%;z-index:999}.mobile-nav.open{transform:translateY(0)}.mobile-nav .nav-link{border-bottom:1px solid #ffffff1a;color:#fff;display:block;padding:1rem 1.5rem}@media (min-width:768px){.navigation{align-items:flex-start;flex-direction:column;height:100vh;justify-content:flex-start;padding-top:2rem;width:250px;width:var(--sidebar-width)}.navigation .logo{margin-bottom:2rem;padding-left:1rem}.navigation .nav-links{display:flex;flex-direction:column;width:100%}.navigation .nav-link{align-items:center;border-left:3px solid #0000;color:#fff;display:flex;padding:.75rem 1.5rem;width:100%}.navigation .nav-link.active,.navigation .nav-link:hover{background-color:#ffffff1a;border-left-color:#fff}.navigation .nav-link i{margin-right:.75rem}.mobile-nav,.navigation .mobile-menu-button{display:none}}.user-info{border-top:1px solid #ffffff1a;margin-top:auto;padding:1rem 1.5rem;width:100%}.username{color:#fff}.login-form-wrapper{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fff;background-color:var(--card-background);border-radius:8px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);max-width:400px;padding:2rem;text-align:center;width:100%}.login-form-wrapper h1{color:#1a73e8;color:var(--primary-color);font-size:2.2rem;font-weight:600;margin-bottom:.5rem;text-shadow:0 2px 4px #0000001a}.login-form-wrapper h3{color:#666;color:var(--text-light);font-weight:400;margin-bottom:2rem}.login-form{text-align:left}.form-group{flex:content;margin-bottom:1.5rem}.form-group label{color:#333;color:var(--text-color);display:block;font-weight:500;margin-bottom:.5rem}.form-group input{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px}.form-group input,.login-button{font-size:1rem;padding:.75rem;width:100%}.login-button{background-color:#1a73e8;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;transition:background-color .2s}.login-button:hover{background-color:#0d47a1;background-color:var(--primary-dark)}.error-message{background-color:#f443361a;border-radius:4px;color:#f44336;color:var(--danger-color);margin-bottom:1rem}.error-message,.success-message{font-size:.9rem;font-weight:500;padding:.5rem}.success-message{background-color:#f0fdf4;background-color:var(--success-background,#f0fdf4);border:1px solid #bbf7d0;border:1px solid var(--success-border,#bbf7d0);border-radius:4px;color:#4caf50;color:var(--success-color);margin-bottom:1.5rem}.dashboard-container{box-sizing:border-box;contain:layout;display:flex;flex-direction:column;gap:1rem;max-width:100%;width:100%}.filter-panel{background-color:#fff;background-color:var(--card-background);border-radius:8px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);margin-bottom:1rem;padding:1.5rem}.filter-panel h2{font-size:1.5rem;margin-bottom:1.5rem}.filters-container{align-items:flex-end;display:flex;gap:15px;justify-content:space-between}.filters-group{display:flex;flex:1 1;gap:15px}.filter-item{flex:1 1;min-width:150px}.filter-item-wide{flex:2 1!important;min-width:200px!important}.date-filters{display:flex;flex:1.5 1;gap:8px}.filter-item-date{flex:1 1;min-width:120px}.filter-item-range{flex:0.7 1!important;min-width:100px!important}.filter-item label{display:block;font-weight:500;margin-bottom:.5rem}.filter-item label[for=chart-range]{display:inline-block;position:relative}.filter-item label[for=chart-range]:after{background-color:#1a73e8;background-color:var(--primary-color);border-radius:50%;color:#fff;content:"?";cursor:help;display:inline-block;font-size:12px;height:16px;line-height:16px;margin-left:5px;text-align:center;width:16px}.filter-item label[for=chart-range]:hover:before{background-color:#fff;background-color:var(--card-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);content:"Sets the Y-axis range as a percentage above and below the baseline values";font-size:.8rem;font-weight:400;left:0;padding:8px;position:absolute;top:100%;width:200px;z-index:10}.filter-item input.filter-item,.filter-item select{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;height:42px;padding:.75rem;width:100%}.filter-item select option{word-wrap:break-word;white-space:normal}.filter-item select[multiple]{height:120px}.filter-item input[type=number]{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;height:42px;padding:.75rem;width:100%}.filter-item input[type=number]:hover{border-color:#1a73e8;border-color:var(--primary-color);cursor:pointer}.filter-item input[type=number]::-webkit-inner-spin-button,.filter-item input[type=number]::-webkit-outer-spin-button{height:30px;opacity:1}.filter-item:has(input[type=number][min="5"][max="100"]){flex:0.5 1;min-width:100px}.filter-buttons{display:flex;flex-direction:column;gap:8px;min-width:120px}.apply-filters-btn{align-items:center;background-color:#1a73e8;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;height:42px;justify-content:center;padding:.75rem 1rem;transition:background-color .2s}.apply-filters-btn:hover{background-color:#0d47a1;background-color:var(--primary-dark)}.apply-filters-btn:disabled{background-color:#666;background-color:var(--text-light);cursor:not-allowed}.clear-filters-btn{align-items:center;background-color:initial;border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;color:#333;color:var(--text-color);cursor:pointer;display:flex;font-size:1rem;font-weight:500;height:42px;justify-content:center;padding:.75rem 1rem;transition:all .2s}.clear-filters-btn:hover{background-color:#e0e0e0;background-color:var(--border-color)}.clear-filters-btn:disabled{cursor:not-allowed;opacity:.6}.dashboard-grid{flex-direction:column;min-height:0}.charts-row,.dashboard-grid{box-sizing:border-box;display:flex;gap:1.5rem;width:100%}.charts-row{flex-shrink:0;margin-bottom:1.5rem}.chart-container{background-color:#fff;background-color:var(--card-background);border-radius:8px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);box-sizing:border-box;flex:1 1;min-width:0;padding:1.5rem}.chart-container .recharts-responsive-container{max-width:100%!important;min-width:0!important;width:100%!important}.average-values,.latest-values{box-sizing:border-box;flex:none;width:100%!important}.chart{cursor:pointer;height:100%;transition:box-shadow .2s}.chart:hover{box-shadow:0 2px 10px #0000001a}.chart h3{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color);font-size:1.1rem;margin-bottom:.75rem;padding-bottom:.5rem}.chart h3 .unit-indicator{font-size:.85rem}.no-chart-data{align-items:center;display:flex;height:100%;justify-content:center}.no-chart-data,.no-data-message{color:#666;color:var(--text-light);font-style:italic}.no-data-message{background-color:#fff;background-color:var(--card-background);border-radius:8px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);padding:3rem 1.5rem;text-align:center}.no-data-message p{color:#666;color:var(--text-light);margin:.5rem 0}.chart-info-tooltip{color:#1a73e8;color:var(--primary-color);cursor:help;display:inline-block;margin-left:.5rem;position:relative}.chart-info-tooltip:hover:after{background-color:#fff;background-color:var(--card-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);color:#333;color:var(--text-color);content:attr(data-tooltip);font-size:.8rem;font-weight:400;left:0;line-height:1.4;padding:.5rem;position:absolute;text-align:left;top:calc(100% + 5px);width:250px;z-index:10}.baseline-legend{align-items:center;color:#666;color:var(--text-light);display:flex;flex-wrap:wrap;font-size:.8rem;justify-content:space-between;margin-bottom:8px;margin-top:-8px}.baseline-legend-item{align-items:center;display:flex;flex:0 0 auto}.baseline-legend-line{border-top:2px dashed #888;height:2px;margin-right:5px;opacity:.7;width:15px}.chart-legend-center{display:flex;flex:1 1;flex-wrap:wrap;justify-content:center;margin:0 10px}.chart-legend-item{align-items:center;display:flex;margin:0 8px;white-space:nowrap}.chart-legend-color{display:inline-block;height:2px;margin-right:5px;width:12px}.chart-tips{color:#666;color:var(--text-light);flex:0 0 auto;font-size:.8rem;font-style:italic;margin-left:auto}.recharts-reference-line .recharts-text{font-size:10px;font-weight:500}.recharts-reference-line-line{stroke-opacity:.6}.recharts-tooltip-wrapper{z-index:1000}.recharts-default-tooltip{background-color:#fffffff2!important;border:1px solid #e0e0e0!important;border:1px solid var(--border-color)!important;border-radius:4px!important;box-shadow:0 2px 5px #0000001a!important;padding:8px 10px!important}.recharts-tooltip-label{font-weight:600!important;margin-bottom:5px!important}.recharts-line .recharts-line-curve{stroke-width:2px}.recharts-active-dot{cursor:pointer}.average-values-panel{height:100%;overflow-y:auto}.metrics-container{display:flex;flex-direction:column;gap:1.5rem}.stage-metrics{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;padding:1rem}.stage-metrics h4{background-color:#e8f0fe;background-color:var(--primary-light);border-radius:4px;font-size:1.1rem;margin-bottom:1rem;padding:.5rem}.metrics-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.metric-row{border-bottom:1px dashed #e0e0e0;border-bottom:1px dashed var(--border-color);display:flex;justify-content:space-between;padding:.25rem 0}.metric-label{font-weight:500}.metric-label,.metric-value{align-items:center;display:flex}.metric-value{font-family:monospace;font-size:1rem}.unit-suffix{color:#666;color:var(--text-light);font-weight:400;margin-left:.25rem}@media (min-width:992px){.metrics-container{flex-direction:row;flex-wrap:wrap}.stage-metrics{width:calc(50% - .75rem)}}.settings-page{background-color:#f5f5f5;margin:0 auto;max-width:1200px}.settings-description{background-color:#e8f0fe;background-color:var(--primary-light);border-left:4px solid #1a73e8;border-left:4px solid var(--primary-color);border-radius:8px;color:#333;color:var(--text-color);line-height:1.5;margin-bottom:1.5rem;padding:1rem}.settings-description strong{color:#1a73e8;color:var(--primary-color);font-weight:600}.status-message{border-radius:8px;font-weight:500;margin-bottom:1.5rem;padding:1rem}.status-message.success{background-color:#4caf501a;border:1px solid #4caf50;border:1px solid var(--success-color);color:#4caf50;color:var(--success-color)}.status-message.error{background-color:#f443361a;border:1px solid #f44336;border:1px solid var(--danger-color);color:#f44336;color:var(--danger-color)}.status-message.info{background-color:#2196f31a;border:1px solid #2196f3;border:1px solid var(--info-color);color:#2196f3;color:var(--info-color)}.status-message.warning{background-color:#ff98001a;border:1px solid #ff9800;border:1px solid var(--warning-color);color:#ff9800;color:var(--warning-color)}.train-selector{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.train-selector label{font-weight:500;margin-bottom:0}.train-selector select{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;padding:.5rem;width:200px}.stages-config-container{display:flex;flex-direction:column;gap:2rem}.stage-config-card{background-color:#fff;background-color:var(--card-background);border-radius:8px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);padding:1.5rem}.stage-config-card h2{border-bottom:2px solid #e8f0fe;border-bottom:2px solid var(--primary-light);font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.config-form{display:flex;flex-direction:column;gap:2rem}.form-section{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.form-section h2{font-size:1.75rem;font-weight:600;margin:0 0 .5rem}.form-section h2,.form-section h3{color:#1a73e8;color:var(--primary-color)}.form-section h3{align-items:center;display:flex;font-size:1.2rem}.form-section h3:before{background-color:#1a73e8;background-color:var(--primary-color);border-radius:2px;content:"";height:1.2rem;margin-right:.75rem;width:3px}.form-section p{color:#666;color:var(--text-light,#666);line-height:1.5;margin:0 0 2rem}.form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-field input,.form-field label{color:#333;color:var(--text-color,#333)}.form-field input{background-color:#fff;background-color:var(--input-background,#fff);border:1px solid #e0e0e0;border:1px solid var(--border-color,#e1e5e9);border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease}.form-field input:focus,.form-field select:focus{border-color:#1a73e8;border-color:var(--primary-color,#2563eb);box-shadow:0 0 0 2px #2c5aa01a;outline:none}.form-field input::placeholder{color:#666;color:var(--text-light,#9ca3af)}.form-field input.error{background-color:#f5f7fa;background-color:var(--background-color)}.form-field input.error,.form-field input.error:focus{border-color:#ff9800;border-color:var(--warning-color)}.form-field input.error:focus{box-shadow:0 0 0 3px #dc26261a}.field-error{color:#ff9800;color:var(--warning-color)}.field-error,.field-success{display:block;font-size:.75rem;font-weight:500;margin-top:.25rem}.field-success{color:#4caf50;color:var(--success-color)}.form-row{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.checkbox-row{flex-direction:row}.form-group.checkbox{align-items:center;display:flex;margin-bottom:0}.form-group.checkbox input{margin-right:.5rem;width:auto}.form-group.checkbox label{margin-bottom:0}.radio-group{gap:.5rem}.radio-option{align-items:flex-start;background-color:#fff;background-color:var(--card-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);margin-bottom:.5rem;padding:.75rem}.radio-option:hover{background-color:#e8f0fe;background-color:var(--primary-light)}.radio-option input{flex-shrink:0;margin-top:.2rem}.radio-option label{flex:1 1;line-height:1.4}.form-actions{align-items:center;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}
/*!* ==========================================================================*/.company-admin-container{margin:0 auto;max-width:1200px;padding:2rem}.admin-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.add-user-form{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin-bottom:2rem;padding:2rem}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-width:400px;padding:2rem;width:90%}.modal-content h3{color:#333;margin:0 0 1rem}.modal-content p{color:#666;line-height:1.5;margin:0 0 2rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.users-table{border:1px solid #dee2e6;border-radius:8px;overflow:hidden}.table-header{background:#f8f9fa;font-weight:600}.table-header,.table-row{border-bottom:1px solid #dee2e6;display:grid;grid-template-columns:1fr 1fr 1.5fr 1fr .8fr 1fr;padding:1rem}.table-row{align-items:center}.table-row:last-child{border-bottom:none}.table-row:hover{background:#f8f9fa}.inactive-users-list{border-top:2px solid #e0e0e0;border-top:2px solid var(--border-color);margin-top:3rem;padding-top:2rem}.inactive-users-list h3{align-items:center;color:#ff9800;color:var(--warning-color);display:flex;gap:.5rem;margin-bottom:1.5rem}.badge-count{background:#ff9800;background:var(--warning-color);border-radius:12px;color:#fff;font-size:.8rem;font-weight:700;min-width:1.5rem;padding:.2rem .6rem;text-align:center}.no-pending-users{background:#f1f5f9;background:var(--hover-background);border:1px dashed #e0e0e0;border:1px dashed var(--border-color);border-radius:8px;color:#666;color:var(--text-light);font-style:italic;padding:2rem;text-align:center}.inactive-users-table{background:#ff98000d;border:1px solid #ff9800;border:1px solid var(--warning-color);border-radius:8px;overflow:hidden}.inactive-users-table .table-header{background:#ff98001a;border-bottom:1px solid #ff9800;border-bottom:1px solid var(--warning-color);color:#333;color:var(--text-dark);font-weight:600}.inactive-row{background:#ff980005}.inactive-row:hover{background:#ff980014}@media (max-width:768px){.inactive-users-list{margin-top:2rem;padding-top:1.5rem}.badge-count{font-size:.7rem;padding:.15rem .5rem}.activate-button,.danger-button{font-size:.8rem;padding:.3rem .8rem}}

/*!* ==========================================================================*/.subscription-upgrade-container{margin:2rem auto;max-width:800px;padding:0 1rem}.subscription-card{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:2rem}.current-status{border-bottom:1px solid #eee;margin-bottom:2rem;padding-bottom:2rem}.status-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:1rem}.status-item{display:flex;flex-direction:column;gap:.5rem}.status-item label{color:#555;font-weight:600}.subscription-badge{border-radius:20px;font-size:.875rem;font-weight:600;max-width:fit-content;padding:.25rem .75rem;text-align:center}.subscription-badge.demo{background:gold;color:#b8860b}.subscription-badge.trial{background:#e3f2fd;color:#1976d2}.subscription-badge.credit_card,.subscription-badge.purchase_order{background:#e8f5e8;color:#2e7d32}.demo-notice{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;margin-bottom:2rem;padding:1.5rem}.demo-notice h4{color:#856404;margin:0 0 1rem}.upgrade-section h3{margin-bottom:1rem}.upgrade-options{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:1.5rem}.upgrade-option{border:1px solid #ddd;border-radius:8px;padding:1.5rem;text-align:center}.upgrade-option h4{color:#333;margin:0 0 .5rem}.upgrade-option p{color:#666;font-size:.9rem;margin:0 0 1.5rem}

/*!* ==========================================================================*/.train-stage-manager{max-width:1000px}.tsm-header{align-items:center;color:#fff;display:flex;justify-content:space-between;overflow:hidden;padding:1.2rem 1.5rem;position:relative;transition:all .3s;z-index:1}.tsm-header:before{background:linear-gradient(135deg,#0000,#ffffff1a 50%,#0000);bottom:0;content:"";left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .3s;z-index:-1}.tsm-header .actions{position:relative;z-index:10}.train-actions,.tsm-header .actions{align-items:center;display:flex;gap:.5rem}.train-info{color:#1a73e8;color:var(--primary-color);display:inline-block}.train-stage-number{flex:1 1}.train-name,.train-site,.train-stage-number{color:#1a73e8;color:var(--primary-color);font-size:1.2rem;font-weight:600}.stages-list h4{color:#333;color:var(--text-color);margin-bottom:1rem}.stages-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.stage-card{background-color:#f5f7fa;background-color:var(--background-color);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:6px;padding:1rem;position:relative}.stage-header{align-items:flex-start;display:flex;justify-content:left;margin-bottom:.5rem}.no-stages,.no-trains{background-color:#f5f7fa;background-color:var(--background-color);border-radius:8px;color:#666;color:var(--text-light);font-style:italic;padding:2rem;text-align:center}.form-group input,.form-group textarea{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;font-size:1rem;padding:.75rem;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#1a73e8;border-color:var(--primary-color);outline:none}

/*!* ==========================================================================*/.operating-data-manager{max-width:1200px}.units-info{color:#666;color:var(--text-light);font-size:.9rem;margin-top:.5rem}.selection-panel{align-items:end;background-color:#fff;background-color:var(--card-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;display:flex;gap:1rem;margin-bottom:2rem;padding:1.5rem}.form-group select{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;padding:.75rem;width:100%}.button-group{display:flex;flex-direction:column;gap:.5rem;white-space:nowrap}.data-entry-info{background-color:#e8f0fe;background-color:var(--primary-light);border-radius:4px;margin-bottom:1rem;padding:1rem}.data-entry-info p{font-size:.9rem;margin:0 0 .5rem}.data-entry-info p:last-child{margin-bottom:0}.data-summary{background-color:#e8f0fe;background-color:var(--primary-light);border-radius:4px;margin-bottom:1rem;padding:1rem}.data-summary p{font-size:.9rem;font-weight:500;margin:0}.data-table-container{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;margin-bottom:1rem;max-height:60vh;overflow-x:auto;overflow-y:auto}.data-table{border-collapse:collapse;min-width:1400px;width:100%}.data-table td,.data-table th{border:1px solid #e0e0e0;border:1px solid var(--border-color);font-size:.85rem;padding:.5rem;text-align:left;vertical-align:top}.data-table th{background-color:#f5f7fa;background-color:var(--background-color);font-weight:600;position:sticky;top:0;z-index:10}.data-table tbody tr:nth-child(2n){background-color:#e8f0fe;background-color:var(--primary-light)}.data-table tbody tr:hover{background-color:#e8f4f8}.data-table input{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:3px;font-size:.85rem;padding:.25rem;width:100%}.data-table input.error{background-color:#fdf2f2;border-color:#f44336;border-color:var(--danger-color)}.required-asterisk{color:#f44336;color:var(--danger-color)}.validation-errors,.validation-summary{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;margin-top:1rem;padding:1rem}.validation-summary h4{color:#f44336;color:var(--danger-color);margin:0 0 .5rem}.validation-summary ul{margin:0;padding-left:1.5rem}.validation-summary li{color:#f44336;color:var(--danger-color);margin-bottom:.25rem}.instructions-toggle{background-color:#4caf50;background-color:var(--secondary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;margin-top:.5rem;padding:.5rem 1rem}.instructions-toggle:hover{background-color:#45a049}.paste-instructions{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-bottom:1rem;padding:1rem}.paste-instructions h4{color:#1a73e8;color:var(--primary-color);margin:0 0 1rem}.instructions-content p{margin:0 0 .75rem}.instructions-content ol,.instructions-content ul{margin:0 0 .75rem;padding-left:1.5rem}.instructions-content li{margin-bottom:.25rem}.test-paste-btn{background-color:#17a2b8;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;margin:.5rem 0;padding:.5rem 1rem}.test-paste-btn:hover{background-color:#138496}.example-data{background-color:#f1f3f4;border:1px solid #d1d3d4;border-radius:4px;margin:.5rem 0;padding:.75rem}.example-data pre{word-wrap:break-word;font-size:.8rem;margin:0;white-space:pre-wrap}.pagination{align-items:center;display:flex;gap:1rem;justify-content:center;margin-top:1rem}.pagination-btn{background-color:#1a73e8;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem}.pagination-btn:hover:not(:disabled){background-color:#0d47a1;background-color:var(--primary-dark)}.pagination-btn:disabled{background-color:#666;background-color:var(--text-light);cursor:not-allowed}.pagination-info{color:#333;color:var(--text-dark);font-weight:500}.settings-tabs{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color);display:flex;margin-bottom:1.5rem}.settings-tabs .tab{border-bottom:3px solid #0000;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.settings-tabs .tab:hover{background-color:#e8f0fe;background-color:var(--primary-light)}.settings-tabs .tab.active{border-bottom-color:#1a73e8;border-bottom-color:var(--primary-color);color:#1a73e8;color:var(--primary-color)}@media (max-width:768px){.form-section{margin:1rem;padding:1.5rem}.form-grid{gap:1rem;grid-template-columns:1fr}.form-actions{align-items:stretch;flex-direction:column}.dialog{margin:1rem;max-width:calc(100vw - 2rem)}.dialog-actions,.settings-tabs{flex-direction:column}.settings-tabs{gap:0}.tab-button{border-right:none;justify-content:space-between;padding:.75rem 1rem}.tab-button,.tab-button.active{border-bottom:1px solid #e0e0e0}.tab-button.active{border-left:4px solid #2c5aa0}.settings-container{padding:0 .5rem}.settings-container h1{font-size:1.5rem;margin-bottom:1rem}}.unit-preferences-container{max-width:800px}.preferences-description{color:#666;color:var(--text-light);margin-bottom:1.5rem}.preferences-form{display:flex;flex-direction:column;gap:1.5rem}.preferences-section{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.preferences-section h3{color:#1a73e8;color:var(--primary-color);font-size:1.2rem;margin-bottom:1.5rem}.unit-description small{border-radius:3px;padding:.25rem .5rem}.unit-conversion-info,.unit-description small{background-color:#e8f0fe;background-color:var(--primary-light)}.unit-conversion-info{border-radius:8px;padding:1rem 1.5rem}.unit-conversion-info h4{color:#1a73e8;color:var(--primary-color);margin-bottom:.5rem}.unit-conversion-info ul{margin-left:1.5rem;margin-top:.5rem}.unit-conversion-info li{margin-bottom:.25rem}.chart h3{align-items:center;display:flex;justify-content:space-between}.chart h3 .unit-indicator{color:#666;color:var(--text-light);font-size:.9rem;font-weight:400}.unit-indicator-panel{background-color:#e8f0fe;background-color:var(--primary-light);border-radius:8px;margin-bottom:1.5rem;padding:.75rem 1rem}.unit-info{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.unit-badge{background-color:#fff;border:1px solid #1a73e8;border:1px solid var(--primary-color);border-radius:4px;color:#1a73e8;color:var(--primary-color);font-size:.9rem;padding:.25rem .5rem}.unit-change-link{margin-left:auto}.unit-display-panel{background-color:#f5f7fa;background-color:var(--background-color);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;margin-top:1.5rem;padding:1rem}.unit-display-panel .unit-info{align-items:center;display:flex;flex-wrap:wrap;font-size:.9rem;gap:.5rem}.unit-display-panel .unit-badge{background-color:#fff;background-color:var(--card-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;color:#333;color:var(--text-color);padding:.25rem .5rem}.unit-change-link a{color:#1a73e8;color:var(--primary-color);font-size:.9rem;text-decoration:none}.unit-change-link a:hover{text-decoration:underline}.chart-dialog-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.chart-dialog{background-color:#fff;background-color:var(--card-background);border-radius:8px;box-shadow:0 4px 20px #0003;display:flex;flex-direction:column;max-height:95vh;max-width:1200px;overflow:hidden;width:90%}.chart-dialog-header{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;padding:15px 20px;position:relative}.chart-dialog-header h2{color:#1a73e8;color:var(--primary-color);font-size:1.5rem;margin:0}.chart-dialog-header h3{color:#666;color:var(--text-light);font-size:1rem;font-weight:400;margin:5px 0 0}.close-dialog-btn{background:none;border:none;color:#666;color:var(--text-light);cursor:pointer;font-size:1.8rem;line-height:1;position:absolute;right:15px;top:10px}.close-dialog-btn:hover{color:#f44336;color:var(--danger-color)}.chart-dialog-content{flex:1 1;overflow:auto;padding:20px}.chart-dialog-chart-container{background-color:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;height:500px;width:100%}.trendline-controls{align-items:center;background-color:#f5f7fa;background-color:var(--background-color);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;display:flex;gap:15px;margin-bottom:15px;padding:10px}.extrapolation-selector,.trendline-selector,.window-selector{align-items:center;display:flex;gap:8px}.extrapolation-selector label,.trendline-selector label,.window-selector label{font-size:.9rem;font-weight:500;margin:0}.extrapolation-selector input,.trendline-selector select,.window-selector input{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;padding:.25rem .5rem}.trendline-descriptions{background-color:#e8f0fe;background-color:var(--primary-light);border-left:3px solid #1a73e8;border-left:3px solid var(--primary-color);border-radius:4px;margin-bottom:15px;padding:10px}.trendline-description-item{align-items:center;display:flex;font-size:.9rem;margin-bottom:5px}.trendline-description-item:last-child{margin-bottom:0}.trendline-color{display:inline-block;height:2px;margin-right:8px;width:12px}.chart-dialog-footer{align-items:center;background-color:#f5f7fa;background-color:var(--background-color);border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;padding:15px 20px}.export-options{display:flex;gap:10px}.export-btn{align-items:center;background-color:#fff;background-color:var(--card-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;display:flex;font-size:.9rem;gap:5px;padding:8px 12px;transition:all .2s}.export-btn:hover{background-color:#e8f0fe;background-color:var(--primary-light);border-color:#1a73e8;border-color:var(--primary-color)}.export-icon{font-size:1.2rem}.pdf-icon,.png-icon{color:#f44336;color:var(--danger-color)}.csv-icon,.excel-icon{color:#4caf50;color:var(--success-color)}.chart-dialog-legend-container{background-color:#f5f7fa;background-color:var(--background-color);border-radius:4px;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:15px;padding:10px}.chart-dialog-legend-item{align-items:center;display:flex;font-size:.9rem;gap:8px}.chart-dialog-legend-color{border-radius:2px;display:inline-block;height:3px;width:20px}.health-map-container{background-color:#fff;background-color:var(--card-background);border-radius:8px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);margin-bottom:2rem;padding:1.5rem}.health-map-container h2{border-bottom:2px solid #e8f0fe;border-bottom:2px solid var(--primary-light);font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.health-map-content{display:flex;flex-direction:column;gap:2rem}.health-map-container .loading-spinner{background-color:#fff;background-color:var(--card-background);border-radius:8px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);padding:3rem;text-align:center}.health-map-container .loading-spinner h3{color:#1a73e8;color:var(--primary-color);font-size:1.3rem;margin-bottom:1rem}.health-map-container .loading-spinner p{color:#666;color:var(--text-light);margin-bottom:2rem}.health-map-container .error-message{background-color:#fff;background-color:var(--card-background);border:2px solid #f44336;border:2px solid var(--danger-color);border-radius:8px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);padding:3rem;text-align:center}.health-map-container .error-message h3{color:#f44336;color:var(--danger-color);font-size:1.3rem;margin-bottom:1rem}.health-map-container .error-message p{color:#333;color:var(--text-color);margin-bottom:2rem}.health-map-container .error-message .btn{border:none;border-radius:6px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.health-map-container .error-message .btn-primary{background-color:#1a73e8;background-color:var(--primary-color);color:#fff}.health-map-container .error-message .btn-primary:hover{background-color:#0d47a1;background-color:var(--primary-dark);transform:translateY(-1px)}.analysis-info{background-color:#f5f7fa;background-color:var(--background-color);border-left:4px solid #1a73e8;border-left:4px solid var(--primary-color);border-radius:0 4px 4px 0;margin-bottom:1.5rem;padding:.75rem 1rem}.analysis-info p{color:#666;color:var(--text-light);margin:0}.analysis-info small{font-size:.85rem}@media (min-width:1200px){.health-map-content{flex-direction:row}.health-map{flex:3 1}.health-map-sidebar{flex:1 1;min-width:300px}}.health-map{display:flex;flex-direction:column;gap:2rem}.train-health-container{box-shadow:0 2px 4px #0000001a;overflow:hidden}.train-card,.train-health-container{border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px}.train-card{background-color:#fff;background-color:var(--card-background);box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.train-header{align-items:center;color:#fff;display:flex;justify-content:space-between;overflow:hidden;padding:1.2rem 1.5rem;position:relative;transition:all .3s}.train-header:before{background:linear-gradient(135deg,#0000,#ffffff1a 50%,#0000);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.train-health-container:hover .train-header:before{opacity:1}.train-header h3{font-size:1.2rem;font-weight:600;margin:0;text-shadow:0 1px 2px #0003}.train-status{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fff3;border:1px solid #ffffff1a;border-radius:4px;font-size:.9rem;font-weight:500;padding:.25rem .5rem}.stages-container{grid-gap:1.2rem;background:linear-gradient(135deg,#f8f9fa,#fff);display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));min-height:160px;padding:1.5rem}.stage-health{align-items:center;border:2px solid #0000;border-radius:8px;box-shadow:0 2px 8px #00000026;color:#fff;cursor:pointer;display:flex;flex-direction:column;height:120px;justify-content:center;position:relative;transition:all .3s ease;width:120px}.stage-health:hover{border-color:#ffffff4d;box-shadow:0 6px 20px #00000040;transform:translateY(-2px) scale(1.02)}.stage-health:active{transform:translateY(0) scale(.98)}.stage-health.loading:hover{border-color:#0000;box-shadow:0 2px 8px #00000026;transform:none}@keyframes shimmer{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.stage-name{font-size:.75rem;margin-top:2px;max-width:100px;opacity:.9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stage-number{font-size:2.5rem;font-weight:700;line-height:1;margin:.5rem}.stage-status{background-color:#0003;border-radius:4px;font-size:.8rem;font-weight:bolder;margin:.5rem;padding:.25rem .5rem;text-align:center}.no-stages{color:#666;color:var(--text-light);font-style:italic;padding:2rem;text-align:center;width:100%}.health-legend{background-color:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.health-legend h3{font-size:1.1rem;margin-bottom:1rem;margin-top:0}.legend-items{display:flex;flex-direction:column;gap:.75rem}.legend-item{align-items:center;display:flex;gap:.75rem}.legend-color{border-radius:4px;box-shadow:0 1px 3px #0003;height:24px;width:24px}.legend-label{font-size:.9rem}.health-guidance{background-color:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.health-guidance h3{font-size:1.1rem;margin-bottom:1rem;margin-top:0}.guidance-content p{font-size:.9rem;margin-top:0}.guidance-content ul{margin-bottom:0;padding-left:1.5rem}.guidance-content li{font-size:.85rem;line-height:1.4;margin-bottom:.5rem}@media (max-width:768px){.stages-container{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));padding:1rem}.stage-health{height:100px;width:100px}.stage-number{font-size:2rem}.stage-status{font-size:.7rem}}@media (max-width:480px){.health-map-content{gap:1rem}.stages-container{gap:.8rem;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));padding:.8rem}.stage-health{height:80px;width:80px}.stage-number{font-size:1.5rem}.stage-status{font-size:.6rem;padding:.2rem .4rem}}.stage-health:focus{outline:3px solid #e8f0fe;outline:3px solid var(--primary-light);outline-offset:2px}.stage-health[aria-disabled=true]{cursor:not-allowed;opacity:.5}@media print{.health-map-container{border:1px solid #ccc;box-shadow:none}.stage-health:hover{box-shadow:0 2px 8px #00000026;transform:none}.train-header:before{display:none}}.form-group input:invalid{border-color:#f44336;border-color:var(--danger-color);box-shadow:0 0 0 2px #f443361a}.form-group input:valid{border-color:#4caf50;border-color:var(--success-color)}.form-group input:focus{border-color:#1a73e8;border-color:var(--primary-color);box-shadow:0 0 0 2px #1a73e81a;outline:none}.calculate-button{background-color:#4caf50;background-color:var(--secondary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background-color .2s;white-space:nowrap}.calculate-button:hover{background-color:#45a049}.calculate-button:disabled{background-color:#666;background-color:var(--text-light)}.input-with-button{align-items:center;display:flex;gap:10px}.input-with-button input{flex:1 1}.status-message .status-main-message{font-weight:500;margin-bottom:.5rem}.status-message .status-details{background-color:#ffffff80;border-radius:4px;font-size:.85rem;margin-top:.5rem;padding:.5rem}.status-message .status-warnings{background-color:#ff98001a;border-left:3px solid #ff9800;border-left:3px solid var(--warning-color);border-radius:4px;margin-top:.5rem;padding:.5rem}.status-message .status-warnings ul{margin:.25rem 0 0 1rem;padding:0}.status-message .status-warnings li{color:#666;color:var(--text-light);font-size:.8rem;margin-bottom:.2rem}.status-message.calculation-info:before{font-size:1.1rem;margin-right:.5rem}.save-button.loading{color:#0000;position:relative}.save-button.loading:after{animation:spin 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;content:"";height:16px;left:50%;margin:-8px 0 0 -8px;position:absolute;top:50%;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.recalculation-status{background-color:#f8f9fa;border-left:4px solid;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.recalculation-status.success{background-color:#4caf500d;border-left-color:#4caf50;border-left-color:var(--success-color)}.recalculation-status.error{background-color:#f443360d;border-left-color:#f44336;border-left-color:var(--danger-color)}.recalculation-status.info{background-color:#2196f30d;border-left-color:#2196f3;border-left-color:var(--info-color)}.recalculation-header{align-items:center;display:flex;font-weight:600;margin-bottom:.75rem}.recalculation-header .status-icon{font-size:1.1rem;margin-right:.5rem}.recalculation-details{font-size:.9rem;line-height:1.4}.recalculation-details p{margin-bottom:.5rem}.recalculation-details p:last-child{margin-bottom:0}.recalculation-details strong{color:#333;color:var(--text-color);font-weight:600}.recalculation-warnings{background-color:#ff98001a;border-left:3px solid #ff9800;border-left:3px solid var(--warning-color);border-radius:4px;margin-top:.75rem;padding:.5rem}.recalculation-warnings ul{margin:.5rem 0 0 1rem;padding:0}.recalculation-warnings li{color:#666;color:var(--text-light);font-size:.85rem;margin-bottom:.25rem}.recalculation-progress{background-color:#f5f7fa;background-color:var(--background-color);border-radius:4px;font-family:monospace;font-size:.85rem;margin-top:.5rem;padding:.5rem}.recalculation-progress .progress-bar{background-color:#e0e0e0;border-radius:2px;height:4px;margin-top:.25rem;overflow:hidden;width:100%}.recalculation-progress .progress-fill{background-color:#4caf50;background-color:var(--success-color);height:100%;transition:width .3s ease}.form-group select[name=recalculationPeriodMonths]{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23666'%3E%3Cpath d='m7 10 5 5 5-5z'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1rem;padding-right:2.5rem}@keyframes recalculationSuccess{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.recalculation-status.success{animation:recalculationSuccess .3s ease-out}.form-group label[for=recalculationPeriodMonths]{display:inline-block;position:relative}.form-group label[for=recalculationPeriodMonths]:after{content:"ℹ️";cursor:help;font-size:.9rem;margin-left:.5rem}.form-group label[for=recalculationPeriodMonths]:hover:before{background-color:#fff;background-color:var(--card-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);color:#333;color:var(--text-color);content:"Longer periods may take more time to process but ensure all historical data is updated with new baseline values";font-size:.8rem;font-weight:400;left:0;line-height:1.4;padding:.5rem;position:absolute;text-align:left;top:100%;width:300px;z-index:10}.calculation-info-section{border-radius:4px;padding:1rem}.calculation-info-section p{color:#666;color:var(--text-light);margin-bottom:.5rem}.calculation-info-section ul{margin-bottom:.5rem}.calculation-info-section .note{margin-top:.5rem}@media (max-width:1200px){.filters-container{align-items:stretch;flex-direction:column}.filters-group{flex-wrap:wrap}.filter-item{flex-basis:calc(50% - 8px);flex-grow:1;flex-shrink:0;min-width:0}.filter-item:has(input[type=number][min="5"][max="100"]){flex-basis:calc(25% - 8px);flex-grow:1;flex-shrink:0}.filter-buttons{flex-direction:row;margin-top:15px}.filter-buttons button{flex:1 1}.charts-row{flex-direction:column}.chart-container{width:100%}.date-filters{flex-direction:row;width:100%}.filter-item-date,.filter-item-range,.filter-item-wide{flex:1 0 100%;min-width:0}}@media (max-width:768px){.filters-group{flex-direction:column}.filter-item{flex:1 0 100%}.baseline-legend{align-items:flex-start;flex-direction:column}.chart-legend-center{justify-content:flex-start;margin:5px 0}.chart-tips{margin-left:0;margin-top:5px}.export-options{flex-wrap:wrap}.chart-dialog-footer{flex-direction:column;gap:15px}.chart-dialog-legend-container{flex-direction:row;justify-content:center;max-width:100%;overflow-x:auto;padding:5px 0}.chart-dialog-legend-item{align-items:center;display:flex;margin:5px 15px;white-space:nowrap}.chart-dialog-legend-color{display:inline-block;height:3px;margin-right:8px;width:20px}.chart-dialog-chart-container .recharts-legend-wrapper{display:none!important}.chart-dialog-chart-container .recharts-wrapper{margin-top:10px}.filter-item input[type=number]{width:100%}.filter-item:has(input[type=number][min="5"][max="100"]){flex:1 0 100%}.form-group{flex:1 1}.radio-group{flex-direction:row;gap:1.5rem}.recalculation-status{margin-bottom:1rem;padding:.75rem}.recalculation-header{align-items:flex-start;flex-direction:column;margin-bottom:.5rem}.recalculation-header .status-icon{margin-bottom:.25rem}.recalculation-details{font-size:.85rem}.status-message .status-details,.status-message .status-warnings{font-size:.8rem}.input-with-button{align-items:stretch;flex-direction:column}.calculate-button{margin-top:.5rem}}.section-description{background-color:#1a73e80d;border-left:3px solid #1a73e8;border-left:3px solid var(--primary-color);border-radius:0 4px 4px 0;color:#666;color:var(--text-light);font-size:.9rem;font-style:italic;line-height:1.5;margin-bottom:1.5rem;padding:.75rem}.normalization-info{background-color:#f5f7fa;background-color:var(--background-color);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;margin:1rem 0;padding:1rem}.normalization-info h4{color:#1a73e8;color:var(--primary-color);font-size:1rem;margin-bottom:.5rem}.normalization-info p{color:#666;color:var(--text-light);font-size:.85rem;line-height:1.4;margin-bottom:1rem}.normalization-info p:last-child{margin-bottom:0}.calculation-info-section{background-color:#e8f0fe;background-color:var(--primary-light);border-left:4px solid #1a73e8;border-left:4px solid var(--primary-color);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.calculation-info-section h4{color:#1a73e8;color:var(--primary-color);font-size:1.1rem;margin-bottom:.75rem}.calculation-info-section p{color:#333;color:var(--text-color);font-size:.9rem;line-height:1.4;margin-bottom:.75rem}.calculation-info-section ul{color:#666;color:var(--text-light);font-size:.85rem;margin-bottom:.75rem;margin-left:1.5rem}.calculation-info-section li{line-height:1.3;margin-bottom:.25rem}.calculation-info-section .note{background-color:#ffffffb3;border-radius:4px;color:#666;color:var(--text-light);font-size:.85rem;font-style:italic;margin-top:.75rem;padding:.5rem}.form-group label.required:after{color:#f44336;color:var(--danger-color);content:" *";font-weight:700}.unit-description{margin-top:.5rem}.unit-description,.unit-description small{color:#666;color:var(--text-light);font-style:italic}.unit-description small{background-color:#00000008;border-left:2px solid #1a73e8;border-left:2px solid var(--primary-color);border-radius:4px;display:block;line-height:1.3;margin-top:.4rem;padding:.4rem .6rem}.radio-group{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.radio-option{align-items:center;border-radius:4px;display:flex;padding:.5rem;transition:background-color .2s}.radio-option:hover{background-color:#1a73e80d}.radio-option input{margin-right:.75rem;width:auto}.radio-option label{cursor:pointer;font-weight:500;margin-bottom:0}.nested-inputs{background-color:#f1f5f9;background-color:var(--hover-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;display:flex;flex-direction:column;gap:.75rem;margin-left:1.5rem;margin-top:1rem;padding:1rem}.nested-inputs .form-field{margin-bottom:0}.nested-inputs .form-field label{font-size:.8rem;font-weight:500;margin-bottom:.25rem}.nested-inputs .form-field input{font-size:.9rem;padding:.5rem}.nested-inputs .field-description{color:#666;color:var(--text-light);font-size:.75rem;line-height:1.3;margin-top:.25rem}@media (max-width:768px){.section-description{font-size:.85rem;padding:.5rem}.normalization-info{padding:.75rem}.normalization-info h4{font-size:.9rem}.normalization-info p{font-size:.8rem}.calculation-info-section{padding:1rem}.calculation-info-section h4{font-size:1rem}.nested-inputs{flex-direction:row;flex-wrap:wrap;gap:1rem}.nested-inputs .form-field{flex:1 1;min-width:200px}}.status-message.calculation-info{align-items:flex-start;background-color:#4caf501a;border:1px solid #4caf50;border:1px solid var(--success-color);color:#4caf50;color:var(--success-color);display:flex;padding:1rem}.status-message.calculation-info:before{content:"🧮";flex-shrink:0;font-size:1.2rem;margin-right:.75rem}html{scroll-behavior:smooth}.form-group input:focus,.form-group select:focus{border-color:#1a73e8;border-color:var(--primary-color);box-shadow:0 0 0 3px #1a73e81a;outline:none}.form-section h3{margin-bottom:1.5rem;padding-bottom:.75rem;position:relative}.form-section h3:after{background-color:#1a73e8;background-color:var(--primary-color);border-radius:1px;bottom:0;content:"";height:2px;left:0;position:absolute;width:50px}.admin-badge{border-radius:8px;padding:.2rem .4rem}.admin-badge,.admin-badge-mobile{background-color:#ff9800;background-color:var(--warning-color);color:#fff;font-size:.7rem;font-weight:700;margin-left:.5rem;text-transform:uppercase}.admin-badge-mobile{border-radius:6px;padding:.15rem .3rem}.mobile-user-role,.user-role{color:#fffc;display:block;font-size:.8rem;font-style:italic;margin-top:.2rem}.mobile-user-role{padding:0 1.5rem}.mobile-username{display:block;font-weight:500;padding:0 1.5rem}.mobile-user-info{border-top:1px solid #ffffff1a;margin-top:1rem;padding:1rem 0}.tab-badge{border-radius:6px;font-size:.7rem;font-weight:700;margin-left:.5rem;padding:.2rem .4rem;text-transform:uppercase}.tab-badge.admin-only{background-color:#ff9800;background-color:var(--warning-color);color:#fff}.permission-denied{background-color:#fff;background-color:var(--card-background);border:1px solid #f44336;border:1px solid var(--danger-color);border-radius:8px;margin:2rem 0;padding:2rem;text-align:center}.permission-denied h3{color:#f44336;color:var(--danger-color);font-size:1.2rem;margin-bottom:1rem}.permission-denied p{color:#333;color:var(--text-color);line-height:1.5;margin-bottom:1rem}.permission-denied strong{color:#f44336;color:var(--danger-color);font-weight:600}.permission-denied-config{background-color:#ff98001a;border:1px solid #ff9800;border:1px solid var(--warning-color);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.permission-message{align-items:center;display:flex;flex-direction:column;text-align:center}.permission-message h4{color:#ff9800;color:var(--warning-color);font-size:1rem;margin-bottom:.5rem}.permission-message p{color:#333;color:var(--text-color);font-size:.9rem;line-height:1.4;margin:0}.permission-message strong{color:#ff9800;color:var(--warning-color);font-weight:600}.view-only-badge{background-color:#2196f3;background-color:var(--info-color);border-radius:4px;color:#fff;font-size:.8rem;font-weight:400;margin-left:1rem;padding:.25rem .5rem;text-transform:uppercase}.config-form input:disabled,.config-form select:disabled,.config-form textarea:disabled{background-color:#f8f9fa;border-color:#e9ecef;color:#666;color:var(--text-light);cursor:not-allowed}.config-form input:disabled:focus,.config-form select:disabled:focus,.config-form textarea:disabled:focus{border-color:#e9ecef;box-shadow:none}.config-form input[type=checkbox]:disabled,.config-form input[type=radio]:disabled{cursor:not-allowed;opacity:.6}.calculate-button:disabled,.config-form input[type=checkbox]:disabled+label,.config-form input[type=radio]:disabled+label{color:#666;color:var(--text-light);cursor:not-allowed}.calculate-button:disabled{background-color:#e9ecef;opacity:.6}.calculate-button:disabled:hover{background-color:#e9ecef}.form-section.view-only{position:relative}.form-section.view-only:before{background-color:#2196f3;background-color:var(--info-color);border-radius:4px;color:#fff;content:"👁️ View Only";font-size:.7rem;padding:.2rem .5rem;position:absolute;right:1rem;top:-.5rem;z-index:1}.status-message.permission-error{align-items:flex-start;background-color:#f443361a;border:1px solid #f44336;border:1px solid var(--danger-color);color:#f44336;color:var(--danger-color);display:flex;padding:1rem}.status-message.permission-error:before{content:"🚫";flex-shrink:0;font-size:1.2rem;margin-right:.75rem}.user-info{align-items:flex-start;display:flex;flex-direction:column}.username{font-weight:500;margin-bottom:.2rem}@media (max-width:768px){.admin-badge,.tab-badge{font-size:.6rem;padding:.15rem .3rem}.view-only-badge{font-size:.7rem;margin-left:.5rem;margin-top:.25rem}.permission-denied{margin:1.5rem 0;padding:1.5rem}.permission-denied h3{font-size:1.1rem}.permission-denied p,.permission-message h4{font-size:.9rem}.permission-message p{font-size:.8rem}.form-section.view-only:before{font-size:.6rem;padding:.15rem .3rem;right:.5rem;top:-.3rem}}.config-form input:disabled:focus,.config-form select:disabled:focus{outline:2px solid #2196f3;outline:2px solid var(--info-color);outline-offset:2px}.config-form input:disabled:hover,.config-form select:disabled:hover{position:relative}.config-form input:disabled:hover:after,.config-form select:disabled:hover:after{word-wrap:break-word;background-color:#fff;background-color:var(--card-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;bottom:100%;box-shadow:0 2px 5px 0 #0000001a;box-shadow:var(--shadow);color:#333;color:var(--text-color);content:"View only - Contact administrator to make changes";font-size:.8rem;left:0;padding:.5rem;position:absolute;white-space:normal;width:200px;z-index:10}.config-form.view-only .form-section h3{color:#2196f3;color:var(--info-color);position:relative}.config-form.view-only .form-section h3:after{color:#666;color:var(--text-light);content:" (View Only)";font-size:.8rem;font-style:italic;font-weight:400}.config-form input,.config-form select,.config-form textarea{transition:all .2s ease}.permission-denied,.permission-denied-config{animation:fadeInPermission .3s ease-out}@keyframes fadeInPermission{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-page.admin-mode{border-left:4px solid #ff9800;border-left:4px solid var(--warning-color)}.settings-page.viewer-mode{border-left:4px solid #2196f3;border-left:4px solid var(--info-color)}.nav-link.admin-required{position:relative}.nav-link.admin-required:after{content:"🔒";font-size:.7rem;opacity:.7;position:absolute;right:.2rem;top:.2rem}.admin-only{display:none}.user-admin .admin-only{display:inline;display:initial}.viewer-only{display:none}.user-viewer .viewer-only{display:inline;display:initial}.role-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:.8rem;font-weight:500;gap:.25rem;letter-spacing:1px;max-width:fit-content;padding:.2rem .5rem;text-align:center;text-transform:uppercase}.role-badge.admin{background-color:#ff9800;background-color:var(--warning-color);color:#fff}.role-badge.admin:before{content:"👑";font-size:.8rem}.role-badge.viewer{background-color:#2196f3;background-color:var(--info-color);color:#fff}.role-badge.viewer:before{content:"👁️";font-size:.8rem}.dialog-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.dialog{background:#fff;background:var(--card-background,#fff);border-radius:8px;box-shadow:0 10px 25px #00000026;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.dialog-small{max-width:400px}.dialog-large{max-height:99vh;max-width:1600px;width:95%}.dialog-header{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e1e5e9);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem 1.5rem 0}.dialog-header h3{color:#333;color:var(--text-color,#333);font-size:1.25rem;font-weight:600;margin:0}.dialog-footer{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color);display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem}.dialog-content{color:#333;color:var(--text-color,#333);line-height:1.6;padding:0 1.5rem}.dialog-content p{margin:0 0 1rem}.dialog-actions{border-top:1px solid var(--border-color,#e1e5e9);gap:.75rem;margin-top:1.5rem;padding:1.5rem}.cancel-btn{background-color:#f5f7fa;background-color:var(--background-color,#f8fafc);border:1px solid #e0e0e0;border:1px solid var(--border-color,#d1d5db);border-radius:4px;color:#333;color:var(--text-color,#374151);cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s ease,border-color .2s ease}.cancel-btn:hover{background-color:#f1f5f9;background-color:var(--hover-background,#f1f5f9);border-color:#9ca3af;border-color:var(--border-dark,#9ca3af)}.user-mfa-status-display{background-color:#f5f7fa;background-color:var(--background-color);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:6px;margin-bottom:1rem;padding:1rem}.user-mfa-status-display strong{color:#333;color:var(--text-color)}.user-mfa-methods-list{margin-top:1rem}.user-mfa-methods-list h4{color:#333;color:var(--text-color);font-size:1rem;font-weight:600;margin-bottom:1rem}.user-mfa-method-item{align-items:center;background-color:#fff;background-color:var(--card-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.75rem;transition:background-color .2s ease}.user-mfa-method-item:hover{background-color:#f1f5f9;background-color:var(--hover-background)}.user-mfa-method-item strong{color:#333;color:var(--text-color);font-size:.95rem}.user-mfa-method-item div:first-child{flex:1 1}.user-mfa-method-info{color:#666;color:var(--text-light);font-size:.9rem}.user-mfa-setup-section{margin-top:1.5rem}.user-mfa-setup-section h4{color:#333;color:var(--text-color);font-size:1rem;font-weight:600;margin-bottom:1rem}.user-mfa-setup-buttons{display:flex;flex-wrap:wrap;gap:1rem}.user-mfa-setup-buttons button{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.25rem;transition:background-color .2s ease}.user-mfa-setup-buttons .btn-primary{background-color:#1a73e8;background-color:var(--primary-color);color:#fff}.user-mfa-setup-buttons .btn-primary:hover:not(:disabled){background-color:#0d47a1;background-color:var(--primary-dark)}.user-mfa-setup-buttons .btn-secondary{background-color:#666;background-color:var(--text-light);color:#fff}.user-mfa-setup-buttons .btn-secondary:hover:not(:disabled){background-color:#9ca3af;background-color:var(--border-dark)}.user-mfa-setup-buttons button:disabled{cursor:not-allowed;opacity:.6}.profile-form-field{margin-bottom:1.5rem}.profile-form-field label{color:#333;color:var(--text-color);display:block;font-size:.95rem;font-weight:500;margin-bottom:.5rem}.profile-form-field input,.profile-form-field select{background-color:#fff;background-color:var(--input-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;color:#333;color:var(--text-color);font-size:1rem;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.profile-form-field input:focus,.profile-form-field select:focus{border-color:#1a73e8;border-color:var(--primary-color);box-shadow:0 0 0 3px #1a73e81a;outline:none}.profile-form-field input.error,.profile-form-field select.error{border-color:#f44336;border-color:var(--danger-color);box-shadow:0 0 0 3px #f443361a}.profile-field-error{color:#f44336;color:var(--danger-color);display:block;font-size:.85rem;font-weight:500;margin-top:.25rem}.profile-form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}@media (max-width:768px){.profile-form-grid{grid-template-columns:1fr}.user-mfa-setup-buttons{flex-direction:column}}.profile-form-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.profile-danger-button{background-color:#f44336;background-color:var(--danger-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s ease}.profile-danger-button:hover:not(:disabled){background-color:#b91c1c;background-color:var(--error-dark)}.profile-danger-button:disabled{cursor:not-allowed;opacity:.6}.totp-qr-display{margin:1rem 0;text-align:center}.totp-qr-display img{background-color:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;max-width:200px;padding:.5rem}.totp-secret-display{color:#333;color:var(--text-color);padding:.5rem;word-break:break-all}.recovery-codes-display,.totp-secret-display{background-color:#f5f7fa;background-color:var(--background-color);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;font-family:Courier New,monospace;font-size:.9rem}.recovery-codes-display{line-height:1.6;padding:1rem}.recovery-codes-display div{background-color:#fff;background-color:var(--card-background);border-radius:2px;margin-bottom:.25rem;padding:.25rem}.mfa-warning-message{align-items:flex-start;background-color:#ff98001a;border:1px solid #ff9800;border:1px solid var(--warning-color);border-radius:4px;color:#ff9800;color:var(--warning-color);display:flex;gap:.5rem;margin-bottom:1rem;padding:1rem}.mfa-warning-message:before{content:"⚠️";flex-shrink:0;font-size:1.1rem}.mfa-warning-message strong{color:#ff9800;color:var(--warning-color);font-weight:600}.mfa-setup-dialog{max-width:600px}.mfa-setup-instructions{color:#333;color:var(--text-color);line-height:1.6;margin-bottom:1.5rem}.mfa-setup-instructions ol{margin-left:1.5rem;margin-top:.5rem}.mfa-setup-instructions li{margin-bottom:.5rem}.mfa-status-loading{align-items:center;color:#666;color:var(--text-light);display:flex;justify-content:center;padding:2rem}.mfa-status-loading:before{animation:spin 1s linear infinite;border:2px solid #e0e0e0;border-top:2px solid #1a73e8;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);content:"";height:20px;margin-right:.5rem;width:20px}.mfa-action-primary{background-color:#1a73e8;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.25rem;transition:background-color .2s ease}.mfa-action-primary:hover:not(:disabled){background-color:#0d47a1;background-color:var(--primary-dark)}.mfa-action-secondary{background-color:initial;border:1px solid #1a73e8;border:1px solid var(--primary-color);border-radius:4px;color:#1a73e8;color:var(--primary-color);cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.25rem;transition:all .2s ease}.mfa-action-secondary:hover:not(:disabled){background-color:#1a73e8;background-color:var(--primary-color);color:#fff}.mfa-action-danger{background-color:#f44336;background-color:var(--danger-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s ease}.mfa-action-danger:hover:not(:disabled){background-color:#b91c1c;background-color:var(--error-dark)}.mfa-status-enabled{align-items:center;background-color:#4caf50;background-color:var(--success-color);border-radius:12px;color:#fff;display:inline-flex;font-size:.8rem;font-weight:500;gap:.25rem;padding:.25rem .5rem}.mfa-status-enabled:before{content:"🔒";font-size:.9rem}.mfa-status-disabled{align-items:center;background-color:#ff9800;background-color:var(--warning-color);border-radius:12px;color:#fff;display:inline-flex;font-size:.8rem;font-weight:500;gap:.25rem;padding:.25rem .5rem}.mfa-status-disabled:before{content:"🔓";font-size:.9rem}.profile-mfa-section{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color);margin-top:2rem;padding-top:2rem}@media (max-width:480px){.user-mfa-method-item{align-items:flex-start;flex-direction:column;gap:.5rem}.user-mfa-method-item button{align-self:flex-end}.profile-form-actions{flex-direction:column}.profile-form-actions button{width:100%}}.webauthn-setup-dialog{max-width:550px;min-width:400px}.webauthn-setup-dialog .dialog-header{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.webauthn-setup-dialog .dialog-close{background:none;border:none;border-radius:4px;color:#666;color:var(--text-light);cursor:pointer;font-size:1.5rem;padding:.25rem;transition:background-color .2s ease}.webauthn-setup-dialog .dialog-close:hover:not(:disabled){background-color:#f1f5f9;background-color:var(--hover-background);color:#333;color:var(--text-color)}.webauthn-status{align-items:flex-start;border-radius:6px;display:flex;font-size:.95rem;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.webauthn-status.supported{background-color:#4caf501a;border:1px solid #4caf504d;color:#4caf50;color:var(--success-color)}.webauthn-status.not-supported{background-color:#f443361a;border:1px solid #f443364d;color:#f44336;color:var(--danger-color)}.webauthn-status-icon{flex-shrink:0;font-size:1.2rem;margin-top:.1rem}.webauthn-status strong{display:block;font-weight:600;margin-bottom:.25rem}.webauthn-setup-instructions{color:#333;color:var(--text-color);line-height:1.6;margin-bottom:1.5rem}.webauthn-setup-instructions p{color:#333;color:var(--text-color);margin-bottom:1rem}.webauthn-setup-instructions ol{margin-left:1.5rem;margin-top:.5rem}.webauthn-setup-instructions li{color:#333;color:var(--text-color);margin-bottom:.75rem}.webauthn-nickname-field{margin-bottom:1.5rem}.webauthn-nickname-field label{color:#333;color:var(--text-color);display:block;font-size:.95rem;font-weight:500;margin-bottom:.5rem}.webauthn-nickname-field input{background-color:#fff;background-color:var(--input-background);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:4px;color:#333;color:var(--text-color);font-size:1rem;padding:.75rem;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.webauthn-nickname-field input:focus{border-color:#1a73e8;border-color:var(--primary-color);box-shadow:0 0 0 3px #1a73e81a;outline:none}.webauthn-nickname-field input:disabled{cursor:not-allowed;opacity:.6}.webauthn-nickname-field .field-help{color:#666;color:var(--text-light);display:block;font-size:.85rem;font-style:italic;margin-top:.25rem}.webauthn-loading{align-items:center;display:flex;flex-direction:column;padding:2rem 1rem;text-align:center}.webauthn-loading-spinner{animation:webauthn-spinner 1s linear infinite;border:3px solid #e0e0e0;border-top:3px solid #1a73e8;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:40px;margin-bottom:1rem;width:40px}.webauthn-loading-text{color:#333;color:var(--text-color)}.webauthn-loading-text strong{display:block;font-size:1rem;margin-bottom:.5rem}.webauthn-loading-text div{color:#666;color:var(--text-light);font-size:.9rem}.webauthn-compatibility-info{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color);margin-top:1.5rem;padding-top:1rem}.webauthn-compatibility-info details{cursor:pointer}.webauthn-compatibility-info summary{color:#333;color:var(--text-color);font-weight:500;margin-bottom:.5rem;-webkit-user-select:none;user-select:none}.webauthn-compatibility-info ul{margin-left:1rem;margin-top:.5rem}.webauthn-compatibility-info li{color:#333;color:var(--text-color);font-size:.9rem;margin-bottom:.5rem}.webauthn-compatibility-info strong{color:#1a73e8;color:var(--primary-color)}.webauthn-result{padding:2rem 1rem;text-align:center}.webauthn-result.success{color:#4caf50;color:var(--success-color)}.webauthn-result.error{color:#f44336;color:var(--danger-color)}.webauthn-result-icon{font-size:3rem;line-height:1;margin-bottom:1rem}.webauthn-result-message{color:#333;color:var(--text-color);font-size:1.2rem;font-weight:600;margin-bottom:1rem}.webauthn-result-details{color:#333;color:var(--text-color);font-size:.95rem;line-height:1.5;margin:0 auto;max-width:400px}.mfa-method-display{align-items:center;display:flex;gap:.75rem}.mfa-method-display.webauthn{border-radius:4px;margin:-.5rem;padding:.5rem}.mfa-method-icon,.webauthn-method-icon{flex-shrink:0;font-size:1.2rem}.webauthn-method-icon{color:#1a73e8;color:var(--primary-color)}.button-icon{font-size:1rem;margin-right:.5rem}.button-spinner{animation:button-spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;display:inline-block;height:14px;margin-right:.5rem;width:14px}.dialog-actions{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color);display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem}.dialog-actions button{align-items:center;border-radius:6px;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}@keyframes webauthn-spinner{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes button-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:600px){.webauthn-setup-dialog{margin:1rem;max-width:95vw;min-width:auto}.webauthn-setup-instructions ol{margin-left:1rem}.dialog-actions{flex-direction:column}.dialog-actions button{justify-content:center;width:100%}.mfa-method-display,.webauthn-status{flex-direction:column;text-align:center}.mfa-method-display{gap:.5rem}}