/*
================================================================
  1. General Body & Link Styles
================================================================
*/
body { font-family:'Open Sans', sans-serif; font-size:18px; color:#000; margin:0;  overflow-x: hidden; }
a { color:#11506b; text-decoration: none }
a:focus,
a:active { color:#11506b }
a:hover { text-decoration:underline; color:#11506b }

/*
================================================================
  2. Global Utility & Helper Classes
================================================================
*/
.color-primary-blue { color:#62c9e3 }
.color-primary-grey { color:#3d4040 }
.color-primary-green { color:#8dc63f }
.color-secondary-blue { color:#10506B }
.color-secondary-grey { color:#adb6bb }
.color-secondary-orange { color:#ef9221 }
.color-secondary-green { color:#092F31 }
.color-tertiary-grey { color: #333}
.color-transparent-white { color: rgba(255, 255, 255, 0.8)}

.bg-primary-blue { background-color:#62c9e3 }
.bg-primary-grey { background-color:#3d4040 }
.bg-primary-green { background-color:#8CC63E }
.bg-secondary-blue { background-color:#10506B }
.bg-secondary-grey { background-color:#adb6bb }
.bg-secondary-orange { background-color:#ef9221 }
.bg-secondary-green { background-color: #092F31; }
.bg-secondary-green-gradient { background-color: #092F31; color: white; position: relative; overflow: hidden; /* Important for positioning context */ padding-top: 5rem; padding-bottom: 5rem; }
.bg-secondary-green-gradient::before { top: -20%; right: -20%; background: radial-gradient(circle, rgba(141, 198, 63, 0.3) 0%, rgba(141, 198, 63, 0.1) 50%, transparent 70%); }
.bg-secondary-green-gradient::after { bottom: -20%; left: -20%; background: radial-gradient(circle, rgba(141, 198, 63, 0.2) 0%, rgba(141, 198, 63, 0.05) 50%, transparent 70%); }

.border-primary-blue { border: 3px solid #62c9e3; border-radius:5px; padding: 10px; }
.border-primary-green { border: 3px solid #8CC63E; border-radius:5px; padding: 10px; }
.border-secondary-orange { border: 3px solid #ef9221; border-radius:5px; padding: 10px; }

.btn { border-radius: 6px; transition: all 0.3s ease; }
.btn:hover { color:#fff; text-decoration:none }
.btn-medium { padding: 0.75rem 1.5rem; font-weight: bold; }
.btn-large { padding: 1rem 2.5rem; text-decoration: none; font-weight: bold; font-size: 1.1rem; }
.btn-primary-blue { color:#fff; background-color: #63C7E1; border: 2px solid #63C7E1;}
.btn-primary-blue:hover { background-color:#fff; color: black; }
.btn-primary-green { color:#fff; background-color:#8dc63f; border: 2px solid #8DC63F;}
.btn-primary-green:hover { background-color:#fff; color: black; }
.btn-primary-grey { color:#fff; background-color:#1C1F23 }
.btn-primary-grey:hover { background-color: #8DC63F; border-color: #8DC63F; }
.btn-secondary-blue { color:#fff; background-color:#11506b }
.btn-secondary-blue:hover { background-color:#003a4d }
.btn-secondary-grey { color:#fff; background-color:#adb6bb }
.btn-secondary-grey:hover { background-color:#73777b }
.btn-secondary-orange { color:#fff; background-color:#ef9221; border: 2px solid #ef9221; }
.btn-secondary-orange:hover { background-color:#fff; color: black; }
.btn-black { background-color: #131314; color: #fff; }
.btn-black:hover { background-color: #8DC63F; color: #fff; border-color: #8DC63F; }
.btn-white { color:#8dc63f; background-color:#fff }
.btn-white:hover { color:#8dc63f; background-color:#eee }
.btn-red { color:#fff; background-color:#EF2020 }
.btn-red:hover { color:#fff; background-color:#a31717 }
.btn-outline-blue { color:#62c9e3; border: 2px solid #62c9e3 }
.btn-outline-blue:hover { color:#fff; background-color:#62c9e3; border-color:#62c9e3 }
.btn-outline-green { color:#8dc63f; border: 2px solid #8DC63F; }
.btn-outline-green:hover { color:#fff; background-color:#8dc63f; border-color:#8dc63f }
.btn-outline-red { color:#EF2020; border: 2px solid #EF2020 }
.btn-outline-red:hover { color:#fff; background-color:#EF2020; border-color:#EF2020 }
.btn-toggle { padding: 5px 20px 5px 20px; margin: 5px; width: 150px; text-align: center;}
.btn-back { display:block; width:33px; height:33px; text-indent:-9999px; overflow:hidden; background:url(../images/icon_back.png) no-repeat }
.btn-back:hover { transform: scale(1.03) }
.btn-back:active { transform: scale(.98) }
.btn-delete:hover { transform: scale(1.03) }
.btn-delete:active { transform: scale(.98) }

.section-title { font-size: 50px;}
.card-title { color: #333; font-size: 1.5rem; font-weight: bold; margin-bottom: 20px; }

/* Tooltips */
.tooltip-inner { width: max-content; max-width: 450px; background-color: #10506B; color: white; text-align: left;
                 padding: 6px 10px; border-radius: 5px; font-family:'Open Sans', sans-serif; font-size: 18px; }
.bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow::before,
.tooltip.bs-tooltip-top .tooltip-arrow::before { border-top-color: #10506B; }
.tooltip.bs-tooltip-bottom .tooltip-arrow::before { border-bottom-color: #10506B; }
.tooltip.bs-tooltip-start .tooltip-arrow::before { border-left-color: #10506B; }
.tooltip.bs-tooltip-end .tooltip-arrow::before { border-right-color: #10506B; }

/* Tooltips */
.tooltip-inner { width: max-content; max-width: 450px; background-color: #10506B; color: white; text-align: left;
                 padding: 6px 10px; border-radius: 5px; font-family:'Open Sans', sans-serif; font-size: 18px; }
.bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow::before,
.tooltip.bs-tooltip-top .tooltip-arrow::before { border-top-color: #10506B; }
.tooltip.bs-tooltip-bottom .tooltip-arrow::before { border-bottom-color: #10506B; }
.tooltip.bs-tooltip-start .tooltip-arrow::before { border-left-color: #10506B; }
.tooltip.bs-tooltip-end .tooltip-arrow::before { border-right-color: #10506B; }

/* Tooltips */
.tooltip-inner { width: max-content; max-width: 450px; background-color: #10506B; color: white; text-align: left;
                 padding: 6px 10px; border-radius: 5px; font-family:'Open Sans', sans-serif; font-size: 18px; }
.bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow::before,
.tooltip.bs-tooltip-top .tooltip-arrow::before { border-top-color: #10506B; }
.tooltip.bs-tooltip-bottom .tooltip-arrow::before { border-bottom-color: #10506B; }
.tooltip.bs-tooltip-start .tooltip-arrow::before { border-left-color: #10506B; }
.tooltip.bs-tooltip-end .tooltip-arrow::before { border-right-color: #10506B; }

/* Page Layout */
.page { display:flex; flex-direction:column; min-height:100vh; background:#DFE4E8 }
.page main { display:flex; flex-direction:column; justify-content:center; flex-grow:1; align-items:center; text-align:center }

/*
================================================================
  3. General Page & Component Styles
================================================================
*/
/* Landing Page - Header */
.landing-header { z-index: 10; background-color: rgba(255, 255, 255, 0.5); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(8px); /* Safari support */ }
.landing-header .buttons .btn { width: 134px; padding: 5px 20px; margin: 0 12px; font-size: 14px; }
.section.intro { width: 100%; padding: 150px 0 85px; position: relative; z-index: 0; overflow: hidden; /* Added to contain the video */ }
.background-video { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); min-width: 100%; min-height: 100%; width: auto; height: auto; z-index: -1; }
.section.intro .container { position: relative; z-index: 2; }
.section.intro::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(255, 255, 255, 0.6); /* white overlay with opacity */ z-index: 1; }
.section.intro .intro-title { font-weight: 400; font-family: "Neue Haas Grotesk Text Pro", "sans-serif"; font-size: 60px; line-height: 55px; max-width: 1000px; width: 100%; z-index: 50px; position: relative; z-index: 2; }
.section.intro .intro-text { font-weight: 400; font-size: 20px; line-height: 28px; max-width: 800px; z-index: 20px; position: relative; z-index: 2; }
/* Landing Page - Trusted By / Logos Section */
.trusted-by-section { background: linear-gradient(to bottom, #F1FEE0, #CDF5FF); padding: 80px 0; font-family: 'Inter', sans-serif; }
.trusted-content-wrapper { position: relative; margin-top: 30px; }
.logos-box { transform: translateY(64px); padding: 125px 20px; background-image: url('../images/logo-box.png'); background-position: center; background-size: contain; background-repeat: no-repeat; position: relative; z-index: 2; }
.logos-container { background-color: #ffffff; border-radius: 24px; transform: translateY(42px); padding: 40px; overflow: hidden; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05); width: 85vw; max-width: 1300px; margin: 0 auto; position: relative; z-index: 2; }
.logos-track { display: inline-block; vertical-align: middle; white-space: nowrap; animation: scroll-logos 20s linear infinite; }
@keyframes scroll-logos { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.logo-item { display: inline-block; margin-right: 30px; transition: transform 0.3s ease; }
.logo-item:hover { transform: translateY(-10px); }
.logo-item img { max-height: 45px; max-width: 130px; width: auto; height: auto; object-fit: contain; }
/* Landing Page - Features Section */
.features-section { position: relative; height: 95vh; overflow: hidden;}
.features-section::before, .features-section::after { content: ''; position: absolute; width: 750px; height: 600px; border-radius: 50%; z-index: 1; }
.features-section .container { position: relative; z-index: 5; }
.features-header { margin-bottom: 4rem; }
.split-left { position: relative; }
.features-content { justify-content: end;}
.split-right { width: 50%; }
.feature-img-fig { position: absolute; inset: 0; display: grid; place-items: center; opacity: 1; pointer-events: none; }
.feature-img { width: 450px; height: 450px; object-fit: cover; opacity: 1; overflow: hidden; }
.feature-card { flex: 1; margin-bottom: 10vh; min-height: 350px; border-radius: 15px; padding: 30px 40px; backdrop-filter: blur(1px); border: 1px solid rgba(255, 255, 255, 0.2); background: linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.9) 100%);}
.feature-card li::before { content: '•'; position: absolute; left: 0; color: #8DC63F; font-weight: bold; }
.feature-card li { position: relative; padding-left: 25px; margin-bottom: 12px; line-height: 1.5; color: #555; }
.feature-title { color: #8DC63F; font-weight: bold; margin-bottom: 20px; }
.feature-list { list-style: none; padding: 0; margin-bottom: 25px; }
.feature-card-inactive {border: 1px solid rgba(9, 47, 49, 0.5); }
.feature-card-inactive::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 15px; background: linear-gradient(135deg, rgba(9, 47, 49, 0.4) 0%, rgba(9, 47, 49, 0.25) 100%); pointer-events: none; }
.features-section .container { display: flex; flex-direction: column; }
#features-sync-mobile { display: none; }

/* Landing Page - How It Works Section */
.how-it-works-section { background-color: #f8f9fa; padding: 150px 0; }
.work-card { background: linear-gradient(170deg, #F1FEE0 0%, #CDF5FF 100%); border-radius: 20px; padding: 60px 30px; text-align: center; height: 100%; 
    border: none; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1); transition: transform 0.3s ease, box-shadow 0.3s ease; position: relative; overflow: hidden; cursor: default; }
.work-card:hover { transform: translateY(-5px); box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15); }
.card-icon-container { margin-bottom: 0px; min-height: 80px; }
.card-icon { max-width: 100px; height: auto; border-radius: 1px; }
.card-description { font-size: 1rem; line-height: 1.6; margin-bottom: 10px; }
/* Landing Page - Explore Apps Section */
.explore-apps-section::before, .features-section::after { content: ''; position: absolute; width: 750px; height: 600px; border-radius: 50%; z-index: 1; }
.explore-apps-section .container { position: relative; z-index: 5; }
.app-card { background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 15px; padding: 30px; height: 100%; display: flex; align-items: center; gap: 20px; backdrop-filter: blur(10px); transition: all 0.3s ease; cursor: default; }
.app-card:hover { background: rgb(255, 255, 255); border-color: rgba(141, 198, 63, 0.4)s; transform: translateY(-2px); box-shadow: 0 10px 25px rgba(99, 252, 53, 0.6); }
.app-card:hover, .app-card:hover * { color: black; }
.app-icon { flex-shrink: 0; }
.app-image { width: 60px; height: 60px; border-radius: 10px; object-fit: cover; }
.app-content { flex: 1; }
.app-title { color: white; font-size: 1.1rem; font-weight: bold; margin-bottom: 8px; line-height: 1.3; }
.app-description { color: rgba(255, 255, 255, 0.8); font-size: 0.9rem; line-height: 1.4; margin-bottom: 0; }
/* Landing Page - Custom Vision Section */
.custom-vision-section { background-color: #f8f9fa; padding: 20px 150px; }
.text-content { flex:1; padding-right: 40px; padding-bottom: 30px; }
.button-content { flex-shrink: 0; padding-left: 40px; border-left: 1px solid #e0e0e0; border-bottom: 1px solid #e0e0e0; height: 234px; }
.vision-header { display: flex; flex-direction:row; gap: 5px; text-align: center; position: relative; }
.vision-title { line-height: 1.2; padding: 30px; margin: 0; border-bottom: 1px solid #e0e0e0; margin-bottom: 2rem; }
.last-img { width: 100%; max-width: 600px; margin: 0 auto; overflow: hidden; }
.last-img img { width: 100%; height: auto; display: block; object-fit: contain; border-radius: 8px; box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
/* Landing Page - Footer Section */
.footer-section { padding: 60px 0 20px 0; color: #b0bec5; font-size: 16px; }
.footer-content { max-width: 1400px; margin: 0 auto; padding: 0 20px; }
.footer-main { flex-wrap: wrap; gap: 40px; margin-bottom: 40px; }
/* .footer-left { flex: 1; min-width: 250px; } */
.footer-logo-img { width: 150px; height: auto }
.footer-center { display: flex; gap: 80px; flex-wrap: wrap; }
.footer-link { color: #b0bec5; text-decoration: none; transition: color 0.3s ease; }
.footer-link:hover { color: white; text-decoration: none; }
.footer-link:focus, .footer-link:active { color: white; }

.footer-right { display: flex; flex-direction: column; align-items: flex-end; gap: 20px; }
.footer-line { width: 1px; color: white; height: 110px; background: white; }
.contact-link { color: #7bc142; text-decoration: none; font-weight: 500; }
.contact-link:hover { color: #6aa835; text-decoration: none; }
.footer-section .copyright { font-size: 0.85em; }

/* Footer */
.footer { padding: 1.5rem 0 0.75rem; margin-top: 1rem; font-size: 14px; color: #092F31;}
.footer .copyright { margin-bottom: 4px; font-size: 0.85em; }
.footer img { margin: 8px; }
.footer .policy-nav.vertical {display: none; flex-direction: column;}
.footer-link-dark { color: #092F31; text-decoration: none; transition: color 0.3s ease; }
.footer-link-dark:hover { color: #b0bec5; text-decoration: none; }
.footer-link-dark:focus, .footer-link:active { color: white; }

/* Error */
.error {padding: 100px; display:flex; flex-direction:column; justify-content:center; flex-grow:1; align-items:center; text-align:center}
.error h1 {font-weight: 700; font-size: 100px; line-height: 80px; width: 100%;}
.error h2 {font-weight: 600; font-size: 40px; line-height: 80px; width: 100%;}
.error h3 {font-weight: 500; font-size: 20px; line-height: 36px; width: 100%;}

/* Cookie Bar */
.cookie-bar { position: fixed; width: 100%; bottom:0; text-align:center; color: #b0bec5; padding: 20px 0px;
              font-weight: 500; box-shadow: 0 -0.25rem 1rem rgba(9, 47, 49, 0.5);}
.cookie-bar a { display: inline-block; padding:5px 10px; margin: 0px 20px; border:1px solid #ADB6BB; width: 225px; color: white; text-decoration: none; }

/* Policies */
.section.policies .title { margin:2rem 0 }
.section.policies .title h2 { margin:0 0 0 1.125rem }
.section.policies input,
.section.policies .cookie-form-text { display:block; padding:5px 10px; border:1px solid #ADB6BB; }
.section.policies .cookie-group-form { display:flex; }
.section.policies .cookie-group table {margin: 20px 0px; width: 100%; }
.section.policies .cookie-group tr,
.section.policies .cookie-group td { text-align:left; padding: 5px 20px; border:1px solid #dee2e6; }
.section.policies .cookie-group th { font-weight: bold; width: 200px;}

/*
================================================================
  4. Application: Accounts (Login, Settings, etc.)
================================================================
*/
.accounts .h1 { font-size:48px }
.accounts .h2 { font-size:36px }
.accounts .h3 { font-size:24px }
.accounts .card { width:670px; margin:40px auto; padding:40px; border-radius:40px }
.accounts .card.wide { width:830px }
.accounts .card.half { width:600px; margin:0 30px 60px }
.accounts .card-body { width:425px; padding:0; margin:0 auto }
.accounts .card .app-logo { max-height:85px; margin:0 auto 60px }
.accounts .card .btn { margin-top:60px; padding:15px 60px; font-size:24px }
.accounts .card .forget-pass { margin-top:45px }
.accounts .text-signup { margin:30px auto 0; font-size:24px }
.accounts .text-signup a:hover { color:#8dc63f }
.accounts .card form p { margin:0; text-align:left }
.accounts .card form p + p { margin-top:20px }
.accounts .card label { margin-bottom:5px; color:#5C6166 }
.accounts .card label + input,
.accounts .card label + textarea { display:block; width:100%; padding:7.5px 20px; border:1px solid #ADB6BB; border-radius:2rem }
.accounts .card-body form select { background: linear-gradient(45deg, transparent 50%, #131314 50%), linear-gradient(135deg, #131314 50%, transparent 50%), linear-gradient(to right, #bec8cd, #bec8cd); background-position: calc(100% - 21px) calc(1em + 2px), calc(100% - 16px) calc(1em + 2px), 100% 0; background-size: 5px 6px, 5px 6px, 2.5em 3.5em; background-repeat: no-repeat; -moz-box-sizing: border-box; -webkit-appearance: none; -moz-appearance: none; display: block; width: 100%; padding: 7.5px 20px; border: 1px solid #ADB6BB; border-radius: 2rem;}
.accounts .card-body form p select:focus-visible { outline: 1px solid #8CC63E; }
.accounts .card input:focus:not(.btn),
.accounts .card select:focus { outline:1px solid #8CC63E; padding:7.5px 20px; box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(141, 198, 63, 0.6) }
.accounts .card input.checkbox {outline: None; box-shadow: None;}
.accounts .card .title { margin:0 0 25px -70px }
.accounts .card.half .title { margin:0 0 50px 0 }
.accounts .card h2 { margin:0 0 0 15px }
.accounts .card.half h2 { margin:0 }
.accounts .card ul { margin:.5rem 0 0; list-style-type: None; }
.accounts .card ul li { font-size:14px; text-align:left; color:#5C6166 }
.accounts .card ul.errorlist li { color: red; }
.accounts .card input.dropdown { border-radius; }
.accounts .signup .card { width:670px; margin:10px auto; padding:40px; border-radius:40px }
.accounts .signup .card .country-select-flag { display: none; }
.accounts .signup .card .terms { display: flex; gap: 20px; }
.accounts .signup .card .btn { margin-top:20px; padding:10px 40px; font-size:20px }
.accounts .settings .title { margin:2rem 0 }
.accounts .settings .title h2 { margin:0 0 0 1.125rem }
.accounts .settings .card-body .title h2 { margin:0; }
.accounts .settings .dropdown { right: 1rem }
.accounts .settings .dropdown button { color: #000; text-decoration: none; }
.accounts .settings .card .btn { margin:30px 0 0 0; padding:10px 40px; font-size:18px; }
.accounts .home .card { min-height:30vh }
.accounts .home .card-body { display:flex; width:auto; align-items:center }
.accounts .home .btn { margin:0 1rem }

/*
================================================================
  5. Application: Tools & Dashboards
================================================================
*/
.app main { display:flex; flex-direction:column; justify-content:flex-start; flex-grow:1; align-items:flex-start; text-align:left }
.app .header .app-logo { max-height:70px }
.app .header .dropdown { position:absolute; right:1rem }
.app .header .dropdown button { color:#000; text-decoration:none }
.app .tools-list { justify-content:flex-start }
.app .tools-list .container { max-width:1600px }
.app .tools-list .categories { width:100%; margin-bottom:60px; background:#fff }
.app .tools-list .categories > .container { display:flex; justify-content:center }
.app .tools-list .categories a { padding:1rem 2rem; text-decoration:none }
.app .tools-list .categories a.is-active { font-weight:700; box-shadow:inset 0 -5px 0 0 #63C7E1 }
.app .tools-list .tiles { width:100%; text-align:left }
.app .tools-list .tiles .container { display:flex; flex-wrap:wrap }
.app .tools-list .tiles .tile { display:flex; width:25%; min-width: 300px; padding:.5rem }
.app-card { background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 15px; padding: 30px; height: 100%; display: flex; align-items: center; gap: 20px; backdrop-filter: blur(10px); transition: all 0.3s ease; cursor: default; }
.app-card:hover, .app-card:hover * { color: black; }
.app .tools-list .tile .card { margin:0; width:auto; padding:1rem; color:#5C6166; border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 15px; padding: 30px; height: 100%; display: flex; align-items: center; gap: 20px; backdrop-filter: blur(10px); transition: all 0.3s ease; }
.app .tools-list .tile .card:hover { background: rgb(9, 47, 49, .85); border-color: rgba(9, 47, 49, 0.4); transform: translateY(-2px); box-shadow: 0 10px 25px rgba(9, 47, 49, 0.6); }
.app .tools-list .tile .card:hover , .app .tools-list .tile .card:hover  * { color: #f8f9fa; }
.app .tools-list .tile .card-body { width:100%; gap: 20px; }
.app .tools-list .tile img { max-width:95px; }
.app .tools-list .tile .card-title { font-size:1rem; font-weight:700; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; margin-bottom: 8px; }
.app .tools-list .tile .card-title a { color:#000; text-decoration: none; }
.app .tools-list .tile .card-text,
.app .tools-list .tile small { font-size:.875rem; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; }
.multiline-text { white-space: pre-wrap }
.app .upload-page .container { min-width:992px; }
.app .upload-page .title { margin:2rem 0 }
.app .upload-page .title h2 { margin:0 0 0 1.125rem }
.app .upload-page .card.half { width:50%; margin:0 1rem 0 0 }
.app .upload-page .card.half + .card.half { margin:0 0 0 1rem }
.app .upload-page .card.half .card-body { padding:1.5rem 3rem }
.app .upload-page .upload label { float:left; clear:left; vertical-align:middle; min-width:20%; line-height:46px; margin-bottom:1rem; color:#5C6166 }
.app .upload-page .upload label + input[type="text"] { display:flex; width:80%; margin-bottom:1.5rem; padding:10px 20px; color:#5C6166; border:1px solid #ADB6BB; border-radius:2rem }
.app .upload-page .upload label ~ label { margin-bottom:0 }
.app .upload-page .upload input:focus { outline:1px solid #8CC63E }
.app .upload-page .upload input[type="file"] { font-size:.875rem; color:#5C6166 }
.app .upload-page .upload input[type="file"]::-webkit-file-upload-button { font-weight:700; padding:10px 20px; margin-right:.5rem; color:#fff; font-size:1rem; background-color:#62c9e3; cursor:pointer; border:2px solid transparent; border-radius:6px; }
.app .upload-page .upload input[type="file"]::-webkit-file-upload-button:hover { background-color:#fff; color:#5C6166; border-color:#62c9e3; }
.app .upload-page .upload input[type="submit"] { float:right; padding:10px 20px }
.app .upload-page .status h3 { font-size:24px; display:flex; align-items: center; }
.app .upload-page .status span:before { content:''; display:inline-block; vertical-align:middle; width:159px; height:159px; margin-right:1rem; background-repeat:no-repeat }
.app .upload-page .status span.error,
.app .upload-page .status span.success { padding: 25px; }
.app .upload-page .status span.success:before { background-image:url(../images/status_success.png) }
.app .upload-page .status div.in-progress { width: 159px; height: 159px; border-width: 1em;}
.app .upload-page .status button.btn-cancel-exec { height: 40px; }
.app .upload-page .status span.error:before { background-image:url(../images/status_error.png) }
.app .upload-page .status span.no-script:before { display:none }
.app .upload-page .executions-table th { font-weight:400 }
.app .upload-page .executions-table th[scope="col"] { color:#adb6bb }
.app .upload-page .executions-table tbody { border-top:1px solid #dee2e6 }
.app .upload-page .executions-table > :not(caption) > * > * { padding:.75rem 1rem }
.app .upload-page .executions-table .btn-delete { width:38px; height:38px; text-indent:-9999px; background:url(../images/icon_bin.png) no-repeat; border:0 }
.app .upload-page .modal-dialog .modal-footer .btn { font-weight:700; padding:10px 30px }
.app .upload-page .modal-dialog .modal-footer > * { margin:.25rem .75rem }
.app .upload-page.dashboards .upload label { margin:0 1rem 0 0; min-width:auto }
.app .upload-page.dashboards .card.half .card-body img { height: 42px; aspect-ratio: 1; }
.app .upload-page.dashboards .accordion img { height: 42px; aspect-ratio: 1; }
.app .dashboard .title { margin:2rem 0 }
.app .dashboard .title h2 { margin:0 0 0 1.125rem }
.app .dashboard .page { max-width:2000px; min-width:750px; }
.app .dashboard .metadata-container { display: grid; grid-template-columns: 225px auto; justify-items: start; justify-self: center; height: min-content;}
.app .dashboard .report { max-width:1200px; font-size:16px; text-align: justify;}
.app .dashboard .report .text { padding: 0 50px 0 50px; width: 100%; }
.app .dashboard .report .plots > div { height: 550px }
.app .dashboard .par-coord { width: 80%; }
.app .dashboard .table td,
.app .dashboard .table tr,
.app .dashboard .table th { text-align: center; font-weight: normal;}
.app .dashboard .table td:first-child,
.app .dashboard .table th:first-child { text-align: left }
.app .dashboard .table-bordered td:first-child,
.app .dashboard .table-bordered th:first-child { text-align: center }
.app .dashboard .data-table td,
.app .dashboard .data-table tr,
.app .dashboard .data-table th { text-align: center; font-weight: normal;}
.app .dashboard .leed-table { padding: 5px; margin: 20px 10px 20px 10px; border-collapse: collapse;}
.app .dashboard .leed-table tr { font-size: 14px; font-weight: normal; text-align: left; }
.app .dashboard .leed-table .section-title { background-color: #d8d8d8; font-weight: bold; font-size: 16px; border: solid gray 1px; height: 24px;}
.app .dashboard .leed-table .points { border: solid gray 1px; height: 24px; width: 35px; text-align: center;}
.app .dashboard .emir .data-table { page-break-inside: avoid; }
.app .dashboard .emir .data-table th,
.app .dashboard .emir .data-table td { border: 1px solid black; word-wrap: break-word; }
.app .dashboard .emir .data-table th { background: #10506b; color: white; font-weight: bold; }
.app .dashboard .emir .data-table td { padding: 0in .05in 0in .05in; }
.app .dashboard .emir .data-table td.str { text-align: left; }
.app .dashboard .emir .data-table td.num { text-align: right; }
.app .dashboard .emir .data-table td.null-value { text-align: center; }
.app .dashboard .emir .data-table tr.row-total { font-weight: bold; }
.app .dashboard .executions-table td:nth-child(2),
.executions-table th:nth-child(2) { text-align: left; width: 40% }
.app .dashboard .card-group { justify-content:space-evenly; }
.app .dashboard .card.half { width:50%; margin:0 1rem 0 0; padding: 5px; }
.app .dashboard .info-card { display: flex; flex-direction: column; justify-content: center; align-items: center; margin: 10px; padding: 25px; }
.app .dashboard .dash-layout { display: flex; flex-direction: row; font-size:16px; }
.app .dashboard .dash-col { display: flex; flex-direction: column; justify-content: space-between; width:50% }
.app .dashboard .bnp-dash-layout > h3,
.app .dashboard .bnp-dash-layout p,
.app .dashboard .bnp-dash-layout ul { grid-column: 1 / 3;}
.app .dashboard .bnp-dash-layout .grid-table-large { grid-column: 1 / 3; width: 75%; }
.app .dashboard .bnp-dash-layout .grid-table-small { grid-column: 1 / 3; max-width: 50%; }
.app .dashboard .bnp-dash-layout .grid-table-large table td { text-align: right; min-width: 125px; }
.app .dashboard .bnp-dash-layout .grid-table-large table td:first-child { min-width: 150px; }
.app .dashboard .bnp-dash-layout .grid-table-small table td { text-align: right; width: 200px; }
.app .dashboard .bnp-dash-layout .grid-table-small table th { max-width: 250px; }
.app .dashboard .bnp-dash-layout table th { font-weight: bold;}
.app .dashboard .subsection { margin: 10px;}
.app .dashboard .bnp-dash-layout .subsection { margin: 10px; display: grid; grid-template-columns: 1fr 1fr; }
.app .dashboard .bnp-dash-layout .subsection .subsection {  grid-column: 1 / 3; }
.app .dashboard .bnp-dash-layout .subsection .full-width {  grid-column: 1 / 3; }
.app .dashboard .button-console { margin: 10px; display: grid; grid-template-columns: auto 675px; }
.app .dashboard .indicators .info-card { background: #dfe4e7; margin: 10px; padding: 20px 10px; }
.app .dashboard form {display:flex; justify-content:center; align-items:center; column-gap: 10px; }
.app .dashboard #id_filter_opt { display:flex; flex-direction:row; flex-wrap:wrap; justify-content:flex-start; column-gap: 20px; }
.app .dashboard .public-url-list-table th { font-weight:700 }
.app .dashboard .public-url-list-table th { font-weight:400 }
.app .dashboard .public-url-list-table th[scope="col"] { color:#adb6bb }
.app .dashboard .public-url-list-table tbody { border-top:1px solid #dee2e6 }
.app .dashboard .public-url-list-table > :not(caption) > * > * { padding:.75rem 1rem }
.app .dashboard .btn-create-link { padding:10px 20px; font-weight:700; margin: 1rem; }
.app .dashboard .btn-delete { width:38px; height:38px; text-indent:-9999px; background:url(../images/icon_bin.png) no-repeat; border:0 }
.app .dashboard .btn-copy { color: #212529 }
.app .dashboard .btn-copy:focus { box-shadow: none; }
.app .dashboard .btn-copy img:hover { transform: scale(1.03) }
.app .dashboard .btn-copy img:active { transform: scale(.98) }
.app .dashboard .btn-copy img { width: 30px;}

/*
================================================================
  6. Dashboard-Specific Styles
================================================================
*/
/* Multiple Energy Results */
.app .dashboard .metadata-container-no-min-content { display: grid; grid-template-columns: 225px auto; justify-items: start; justify-self: center; }

/* B&P V2.0 and CBECC Energy Results */
.id_savings_type_opt_0 { color:#EF9120; border: 2px solid #EF9120; }
.id_savings_type_opt_0:hover { color: #fff; background-color: #EF9120; box-shadow: 0px 0px 4px #EF9120; }
.btn-check:checked + .id_savings_type_opt_0 { color: #fff; background-color: #EF9120; box-shadow: 0px 0px 4px #EF9120; }
.id_savings_type_opt_1 { color:#8DC63F; border: 2px solid  #8DC63F; }
.id_savings_type_opt_1:hover { color: #fff; background-color: #8DC63F; box-shadow: 0px 0px 4px #8DC63F; }
.btn-check:checked + .id_savings_type_opt_1 { color: #fff; background-color: #8DC63F; box-shadow: 0px 0px 4px #8DC63F; }
.id_savings_type_opt_2 { color:#63C7E1; border: 2px solid  #63C7E1; }
.id_savings_type_opt_2:hover { color: #fff; background-color: #63C7E1; box-shadow: 0px 0px 4px #63C7E1; }
.btn-check:checked + .id_savings_type_opt_2 { color: #fff; background-color: #63C7E1; box-shadow: 0px 0px 4px #63C7E1; }
.id_savings_type_opt_3 { color:#5C6266; border: 2px solid  #5C6266; }
.id_savings_type_opt_3:hover { color: #fff; background-color: #5C6266; box-shadow: 0px 0px 4px #5C6266; }
.btn-check:checked + .id_savings_type_opt_3 { color: #fff; background-color: #5C6266; box-shadow: 0px 0px 4px #5C6266; }

/* CBECC */
.indicators .pass { color:#008000; }
.indicators .warn { color:#f2c200; }
.indicators .fail { color:#ff0000; }
.qaqc {display: grid; grid-template-columns: 75px 1fr; align-items: center; margin-bottom: 12px; }
.app .dashboard .bnp-dash-layout .qaqc p { grid-column: 2 / 3; }
.btn-toggle { padding: 5px 10px; }

/* CBECC */
.indicators .pass { color:#008000; }
.indicators .warn { color:#f2c200; }
.indicators .fail { color:#ff0000; }
.qaqc {display: grid; grid-template-columns: 75px 1fr; align-items: center; margin-bottom: 12px; }
.app .dashboard .bnp-dash-layout .qaqc p { grid-column: 2 / 3; }

/* CBECC */
.indicators .pass { color:#008000; }
.indicators .warn { color:#f2c200; }
.indicators .fail { color:#ff0000; }
.qaqc {display: grid; grid-template-columns: 75px 1fr; align-items: center; margin-bottom: 12px; }
.app .dashboard .bnp-dash-layout .qaqc p { grid-column: 2 / 3; }

/* EMIR */
.zeve-header { display: flex; flex-direction: row; justify-content: space-between; align-items: center; width: 100%; padding: 0in 0in 0in 0.25in; margin: 0.2in 0 0.2in 0; background: linear-gradient(130deg, #15526C 40%, 68%, #FFFFFF 80%); }
.emir-subheader { font-weight: bold; color: #10506B; break-after:avoid; margin-top: 8px; }
.emir .table-notes { margin-top: 16px; }
.emir .col-xxs {width: 50px;}
.emir .col-xs {width: 75px;}
.emir .col-s {width: 100px;}
.emir .col-m {width: 150px;}
.emir .col-l {width: 200px;}
.emir .col-xl {width: 250px;}
.emir .col-xxl {width: 350px;}
.emir .col-xxxl {width: 450px;}
.emir .caption { font-style: italic; color: #10506b; margin: 1em 0 0 0; break-after: avoid; }
.emir a.btn-outline-blue { border: none; }
.emir a:focus, a:active { color:#11506b; text-decoration: none; }
.emir a:hover { color:#fff; background-color:#62c9e3; border-color:#62c9e3; text-decoration: none; }

/*
================================================================
  7. Global Media Queries & Responsive Design
================================================================
*/
@media (max-width: 1550px) {
    .section-title { font-size: 40px;}
    .section.intro {background-position-x: -287px;}
    .section.intro .page-title {font-size: 50px; line-height: 62px;max-width: 870px;}
    .app .dashboard .toggle-field {display: flex; flex-direction: column;}
    .app .dashboard .button-console { grid-template-columns: auto 175px; margin-bottom: -15px;}
    .app .dashboard .bnp-dash-layout .subsection { display: flex; flex-direction: column; }
    .app .dashboard .bnp-dash-layout .grid-table-large { width: 100%; }
    .app .dashboard .bnp-dash-layout .grid-table-small { width: 75%; }
    .id_savings_type_opt_0:after { top: 5px; right: 175px; }
    .id_savings_type_opt_1:after { top: 50px; right: 175px; }
    .id_savings_type_opt_2:after { top: 85px; right: 175px; }
    .id_savings_type_opt_3:after { top: 130px; right: 175px; }
    .logos-container { padding: 20px; max-width: 1200px; }
    .text-content { padding-right: 0; padding-bottom: 30px; }
    .button-content { padding-left: 0; border-left: none; border-bottom: none; width: 100%; height: auto; padding: 30px 0; }
    .vision-container, .vision-header { flex-direction: column; margin: 0; }
}

@media (max-width: 1200px) {
    .section-title { font-size: 35px;}
    .section.intro {background-position-x: -494px;}
    .section.intro .page-title {font-size: 40px; line-height: 57px;max-width: 870px;}
    .section.signup { padding: 90px 0;}
    .footer .policy-nav.vertical {display: flex;}
    .footer .policy-nav.horizontal {display: none;}
    .app .dashboard .dash-layout { display: flex; flex-direction: column; justify-content: center; align-items: center; }
    .app .dashboard .dash-col {width:100%; }
    .app .dashboard .bnp-dash-layout .grid-table-small { width: 100%; }
    .features-header { margin-bottom: 1.5rem; }
    #features-sync { display: none; }
    #features-sync-mobile { display: block; }
    .features-section { height: 100%; }
    .feature-card { max-width: 600px; }
    .app-card { padding: 25px; }
    .custom-vision-section { padding: 20px 40px; }
    .footer-right img { width: 200px; }
    .footer-center { gap: 40px; }
}


@media (max-width: 992px) {
    .section.intro {background-position-x: -265px; padding: 120px 0 70px;}
    .section.intro .page-title { font-size: 34px; line-height: 48px; max-width: 610px; }
    .section.intro .intro-title { font-size: 50px; line-height: 1.1; }
    .section.intro .intro-text { font-size: 18px; }
    .section.intro p {font-size: 16px;}
    .section.intro img {width: 50px;}
    .section.intro .text {  font-size: 18px; line-height: 30px; }
    .section-title { font-size: 30px;}
    .logos-box { transform: translateY(0); padding: 20px; background-image: none; }
    .how-it-works-section { padding: 100px 0; }
    .work-card { padding: 35px 25px; margin-bottom: 20px; }
    .feature-title { font-size: 1.6rem; }
    .app-card { padding: 20px; gap: 15px; }
    .app-title { font-size: 1rem; }
    .app-description { font-size: 0.85rem; }
    .site-logo { width: 65px; }
    .features-section { padding-top: 3rem; padding-bottom: 3rem; }
    .feature-list { font-size: 0.95rem; min-height: auto; }
    .features-section .h5 { font-size: 1em; }
    .feature-card { margin-bottom: 2rem; max-width: 500px; padding: 25px;}
    .custom-vision-section { padding: 20px; }
    .footer-main { flex-direction: column; align-items: center; text-align: center; }
    .footer-right { align-items: center; text-align: center; }
    .footer-line { display: none; }
}

@media (max-width: 768px) {
    .section.intro { background-position-x: -322px; padding: 50px 0; }
    .section.intro .page-title { font-size: 30px; line-height: 43px; }
    .section.intro .text { font-size: 16px; line-height: 28px; }
    .section-title { font-size: 26px; }
    .login-user-info { display: none; }
    .trusted-by-section { padding: 40px 0; }
    .logos-box { transform: translateY(0); padding: 20px; background-image: none; }
    .logos-container { transform: translateY(0); margin-top: 40px; }
    .logo-item img { max-height: 35px; }
    .feature-title { font-size: 1.3rem; }
    .how-it-works-section { padding: 60px 0; }
    .how-it-works-section .row > div:last-child .work-card { margin-bottom: 0; }
    .card-description { font-size: 0.95rem; }
    .card-icon-container { min-height: 60px; margin-bottom: 20px; }
    .card-icon { max-width: 80px; }
    .app-card { padding: 20px; flex-direction: column; text-align: center; gap: 15px; margin-bottom: 20px; }
    .app-image { width: 50px; height: 50px; }
    .text-content { border-bottom: none; padding-right: 0; }
}

@media (max-width: 576px) {
    .landing-header .buttons {flex-direction: column;}
    .landing-header .buttons .btn { width: 130px; padding: 7px 30px; margin: 4px 12px; }
    .section.intro { background-position-x: unset; padding: 100px 0 50px; }
    .section.intro .intro-title { font-size: 38px; }
    .section.intro .intro-text { font-size: 16px; line-height: 1.5; }
    .how-it-works-section { padding: 80px 0; }
    .app-card { flex-direction: column; text-align: center; padding: 18px; gap: 12px; }
    .app-title { font-size: 0.95rem; }
    .app-description { font-size: 0.85rem; }
    .footer-section { padding: 40px 0 20px 0; }
    .footer-center { flex-direction: column; gap: 30px; align-items: center; }
}