@font-face { font-family: 'RobotoCondensed'; font-style: normal; font-weight: 400; font-display: swap; src: url("../fonts/RobotoCondensed-Regular.woff2") format('woff2'), url("../fonts/RobotoCondensed-Regular.woff") format('woff') } @font-face { font-family: 'RobotoCondensed'; font-style: normal; font-weight: 700; font-display: swap; src: url("../fonts/RobotoCondensed-Bold.woff2") format('woff2'), url("../fonts/RobotoCondensed-Bold.woff") format('woff') } @font-face { font-family: 'RobotoCondensed'; font-style: normal; font-weight: 800; font-display: swap; src: url("../fonts/RobotoCondensed-ExtraBold.woff2") format('woff2'), url("../fonts/RobotoCondensed-ExtraBold.woff") format('woff') } html { box-sizing: border-box; overflow-x: hidden } *, *::before, *::after { box-sizing: inherit; padding: 0; margin: 0 } body { padding: 0; margin: 0 } body { font-family: "RobotoCondensed", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; color: #2C2C2C } main { background-color: #f1f5f9; position: relative; overflow-x: hidden } button { all: unset; cursor: pointer } .container { padding: 0 15px; width: 100%; max-width: 1320px; margin: 0 auto } br[data-mce-bogus="1"] { display:none; } section { margin-bottom: -1px; } h1 { color: #111; font-weight: 800 } h2, h3, h4, h5 { color: #111; font-weight: 700 } .logo-text { font-size: 24px; font-weight: 700; line-height: 110%; color: #111; text-transform: uppercase; text-decoration: unset; transition: all 0.5s ease } header .logo-text { display: flex; align-items: center; justify-content: center; gap: 5px } .logo-text img { width: 32px; height: 32px } .error-msg { font-size: 16px; font-weight: 700; color: red; margin: 3px auto auto 0 } .header-wrap, .header-wrap .hamburger, .header-wrap .hamburger .line, .mobile-menu__wrap .menu { display: flex; align-items: center } header { background-color: #FFF; box-shadow: 0 5px 15px 0 #0c4a6e1A; position: fixed; z-index: 999; width: 100% } header a { text-decoration: unset } .header-wrap { justify-content: space-between } .header-wrap.mob { padding: 12px 0; position: relative; z-index: 9; } .mobile-menu__wrap { display: flex; flex-direction: column; position: fixed; align-items: center; width: 100%; height: calc(100vh - 50px); top: 50px; right: 0; transform: translateX(110%); padding: 0 15px; transition: all 0.5s ease; background: #FFF; padding-bottom: 20px } @supports (padding:env(safe-area-inset-bottom)) { .mobile-menu__wrap { padding-bottom: max(120px, calc(20px + env(safe-area-inset-bottom) + 44px)) } } .mobile-menu__wrap.active { transform: translateX(0) } .mobile-menu__wrap .menu, .mobile-menu__wrap .header-btn__wrap { margin-top: auto } .mobile-menu__wrap .menu { flex-direction: column; width: 100% } .mobile-menu__wrap .menu a { font-size: 18px; font-weight: 400; line-height: 140%; padding: 4px 8px; color: #2C2C2C; text-align: center; width: 100%; transition: all 0.5s ease } .mobile-menu__wrap .menu a:not(:last-child) { margin-bottom: 16px } header .menu a.active, header .menu a:hover { color: #f59e0b } img { width: 100%; height: auto } h2, h3 { font-size: 26px; line-height: 110% } .content-wrap { padding: 30px 0 64px 0 } .half.left { margin-bottom: 32px } .leadform { position: relative } .leadform .consent-text a { color: inherit; font-size: inherit; line-height: inherit; transition: all 0.5s ease } .leadform .consent-text a:hover { color: #f59e0b } .orange-btn { text-transform: uppercase } .orange-btn { display: block; text-decoration: unset; font-size: 24px; font-weight: 400; line-height: 28px; color: #FFF; padding: 16px 0; text-align: center; width: 100%; background-color: #f59e0b; border: 1px solid #f59e0b; border-radius: 8px; transition: all 0.5s ease } .orange-btn:hover { background: #d9770624; color: #f59e0b } .header-wrap .hamburger { flex-direction: column; width: 16px; height: 18px; gap: 6px; cursor: pointer } .header-wrap .hamburger .line { background-color: #111; width: 100%; height: 2px; border-radius: 2px } .header-btn__wrap { display: block; width: 100% } .header-wrap.mob .logo { display: flex; align-items: center; justify-content: flex-start } .header-wrap.mob .hamburger .line { transform: translateY(0) rotate(0); opacity: 1; transition: all 0.5s ease } .header-wrap.mob.opened .hamburger .line:first-child { transform: translateY(10px) rotate(45deg) } .header-wrap.mob.opened .hamburger .line:nth-child(2) { transform: translateY(2px) rotate(-45deg) } .header-wrap.mob.opened .hamburger .line:last-child { opacity: 0 } footer { padding: 64px 0; background-color: #FFF; border-top: 1px solid #f59e0b } footer a { text-decoration: unset } footer .two-col, footer .two-col .main, footer .two-col .legal { display: flex; align-items: flex-start; justify-content: flex-start; } footer .two-col .logo, footer .two-col > p, footer .two-col .main, footer .two-col .legal { width: 50% } footer .logo.two-col { align-items: flex-end; justify-content: space-between; margin-bottom: 32px } footer .logo.two-col .logo-text { font-size: 21px; padding-right: 50px; color: #111 } footer .logo.two-col p, footer .logo.two-col .logo-text { line-height: 120%; font-weight: 700 } footer .logo.two-col p { font-size: 18px; margin: 0; color: #2C2C2C } footer .footer-menu { margin-bottom: 16px } footer .two-col .main { padding: 30px 0; border-right: 1px solid #d9770624 } footer .two-col .main, footer .two-col .legal { flex-direction: column } footer .two-col .legal { padding: 30px 30px 30px 10px } footer .footer-menu a { font-size: 18px; line-height: 120%; color: #2C2C2C; transition: all 0.5s ease; overflow-wrap: anywhere; display: block; } footer .footer-menu a.active, footer .footer-menu a:hover { color: #f59e0b } footer .footer-menu a:not(:last-child) { margin-bottom: 20px } footer .copyright { font-size: 18px; line-height: 120%; text-align: center; margin-bottom: 24px } footer .soc-links, footer .soc-links a { display: flex; align-items: center; justify-content: center } footer .soc-links { gap: 32px } footer .soc-links a { background-color: #f59e0b; width: 44px; height: 44px; padding: 11px; border-radius: 50%; transition: all 0.5s ease } footer .soc-links a:hover { background: #d9770624 } footer .soc-links a:hover img { filter: invert(50%) sepia(100%) saturate(1000%) hue-rotate(-10deg) brightness(90%) contrast(90%) } footer .footer-menu a { hyphens: auto; word-break: normal; overflow-wrap: break-word } #content { overflow: hidden; padding-top: 70px; } @media (min-width: 1023px) { #content { padding-top: 150px; } } .bg { background-color: #0c4a6e } .bg-elem:before { content: ""; position: absolute; display: block; top: 0; left: 0; z-index: -1; width: 100%; height: 100%; background-color: #0c4a6e; border-radius: 16px } .tns-outer { padding: 0 !important } .tns-outer [hidden] { display: none !important } .tns-outer [aria-controls], .tns-outer [data-action] { cursor: pointer } .tns-slider { -webkit-transition: all 0s; -moz-transition: all 0s; transition: all 0s } .tns-slider > .tns-item { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box } .tns-horizontal.tns-subpixel { white-space: nowrap } .tns-horizontal.tns-subpixel > .tns-item { display: inline-block; vertical-align: top; white-space: normal } .tns-horizontal.tns-no-subpixel:after { content: ''; display: table; clear: both } .tns-horizontal.tns-no-subpixel > .tns-item { float: left } .tns-horizontal.tns-carousel.tns-no-subpixel > .tns-item { margin-right: -100% } .tns-no-calc { position: relative; left: 0 } .tns-gallery { position: relative; left: 0; min-height: 1px } .tns-gallery > .tns-item { position: absolute; left: -100%; -webkit-transition: transform 0s, opacity 0s; -moz-transition: transform 0s, opacity 0s; transition: transform 0s, opacity 0s } .tns-gallery > .tns-slide-active { position: relative; left: auto !important } .tns-gallery > .tns-moving { -webkit-transition: all 0.25s; -moz-transition: all 0.25s; transition: all 0.25s } .tns-autowidth { display: inline-block } .tns-lazy-img { -webkit-transition: opacity 0.6s; -moz-transition: opacity 0.6s; transition: opacity 0.6s; opacity: 0.6 } .tns-lazy-img.tns-complete { opacity: 1 } .tns-ah { -webkit-transition: height 0s; -moz-transition: height 0s; transition: height 0s } .tns-ovh { overflow: hidden } .tns-visually-hidden { position: absolute; left: -10000em } .tns-transparent { opacity: 0; visibility: hidden } .tns-fadeIn { opacity: 1; filter: alpha(opacity=100); z-index: 0 } .tns-normal, .tns-fadeOut { opacity: 0; filter: alpha(opacity=0); z-index: -1 } .tns-vpfix { white-space: nowrap } .tns-vpfix > div, .tns-vpfix > li { display: inline-block } .tns-t-subp2 { margin: 0 auto; width: 310px; position: relative; height: 10px; overflow: hidden } .tns-t-ct { width: 2333.3333333%; width: -webkit-calc(100% * 70 / 3); width: -moz-calc(100% * 70 / 3); width: calc(100% * 70 / 3); position: absolute; right: 0 } .tns-t-ct:after { content: ''; display: table; clear: both } .tns-t-ct > div { width: 1.4285714%; width: -webkit-calc(100% / 70); width: -moz-calc(100% / 70); width: calc(100% / 70); height: 10px; float: left } .error { position: relative; z-index: 1; padding: 130px 0 150px 0 } .error:before, .error:after { position: absolute } .error .content-wrap { display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 24px; padding: 0 } .error .content-wrap h1, .error .content-wrap p { margin: 0 } .error .content-wrap h1 { font-size: 150px; line-height: 100%; color: #2C2C2C } .error .content-wrap p { font-size: 18px; line-height: 140% } .error .content-wrap a.orange-btn { padding: 16px 32px; width: auto } .thanks { margin: 0 auto 0 auto; padding: 80px 0 } .thanks .content-wrap, .thanks .content-wrap .text-wrap { display: flex; align-items: center; justify-content: center; flex-direction: column } .thanks .content-wrap { gap: 60px; max-width: 650px; margin: auto } .thanks .content-wrap * { text-align: center } .thanks .content-wrap img { width: 98px; height: 78px; margin: auto } .thanks .content-wrap h1 { font-size: 50px; line-height: 110% } .thanks .content-wrap .text-wrap { gap: 16px; max-width: 600px } .thanks .content-wrap .text-wrap p { font-size: 18px; line-height: 140% } .thanks .content-wrap .text-wrap b { font-weight: 800 } .thanks .content-wrap .orange-btn { padding: 26px 28px; max-width: 380px } footer a { font-size: 18px; line-height: 120%; color: #2C2C2C; transition: all 0.5s ease; } footer a:hover { color: #f59e0b; } .iti { width: 100%; } @media only screen and (min-width: 1023px) { .thanks { margin: 0 auto 0 auto; } } @media only screen and (min-width: 1279px) { .error .content-wrap { gap: 50px } .error .content-wrap h1 { font-size: 250px } .error .content-wrap a.orange-btn { padding: 26px 122px } } @media only screen and (max-width: 1023px) { .desk { display: none } } @media only screen and (min-width: 767px) { .content-wrap .half { margin: 0 } .container { padding: 0 30px } h2, h3 { font-size: 50px } header .header-wrap.desk { padding: 20px 0 } header .header-wrap.desk .menu { display: flex; align-items: center; justify-content: center; gap: 8px } header .header-wrap.desk .menu a { font-size: 18px; line-height: 120%; color: #2C2C2C; padding: 4px 8px; transition: all 0.5s ease } header .header-wrap.desk .menu a.active, header .header-wrap .lang-selector a.current, header .header-wrap.desk .menu a:hover { color: #f59e0b } header .header-wrap.desk .orange-btn { min-width: 212px } header .header-wrap .lang-selector .list-toggle { left: 5px; top: 35px } } @media only screen and (min-width: 1023px) { html body main .mob, .mobile-menu__wrap { display: none } .header-wrap .lang-selector { margin: 0 } .header-wrap .lang-selector:hover .list-toggle { opacity: 1; visibility: visible } .header-wrap .lang-selector:hover a.current:after { transform: rotate(180deg) } footer .footer-wrap { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap } footer .footer-wrap .copyright { order: 4; width: 100%; margin: 60px 0 0 0 } footer .logo.two-col { flex-direction: column; align-items: flex-start; margin-bottom: 0 } footer .logo.two-col .logo-text { padding: 0 } footer .logo.two-col p { width: 100%; font-weight: 400 } footer .footer-menu { flex-direction: column; margin-bottom: 0; max-width: 500px; width: 100% } footer .two-col .main, footer .two-col .legal { flex-direction: row; justify-content: center; width: 100%; flex-wrap: wrap; gap: 10px; } footer .two-col .legal { padding: 20px 0 0 0; gap: 20px } footer .two-col .main { border-right: unset; border-bottom: 1px solid #f59e0b; padding: 0 0 20px 0 } footer .footer-menu a:not(:last-child) { margin-bottom: 0 } footer { border: unset } }
/* ===== Additions for new pages / FAQ / forms ===== */
.faq-section { padding: 60px 0; background-color: #f1f5f9 }
.faq-section h2 { font-size: 28px; line-height: 110%; margin-bottom: 24px; text-align: center }
.faq-item { background:#fff; border-radius:14px; box-shadow:0 4px 14px rgba(12,74,110,.06); margin-bottom:14px; overflow:hidden; border:1px solid #e2e8f0 }
.faq-question { padding:18px 22px; font-size:18px; font-weight:700; color:#0c4a6e; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:16px; user-select:none }
.faq-question:hover { color:#0369a1 }
.faq-question .faq-toggle { width:28px; height:28px; border-radius:50%; background:#0369a1; color:#fff; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:18px; font-weight:700; transition:.3s }
.faq-item.active .faq-toggle { transform:rotate(45deg); background:#f59e0b }
.faq-answer { max-height:0; overflow:hidden; transition:max-height .35s ease, padding .35s ease; padding:0 22px }
.faq-item.active .faq-answer { max-height:600px; padding:0 22px 18px 22px }
.faq-answer p { font-size:16px; line-height:150%; color:#2C2C2C; margin-bottom:10px }
.faq-answer p:last-child { margin-bottom:0 }

/* Page hero (sub-pages) */
.page-hero { background:linear-gradient(135deg,#0c4a6e 0%,#0369a1 100%); color:#fff; padding:70px 0 60px; text-align:center }
.page-hero h1 { color:#fff; font-size:38px; line-height:110%; margin-bottom:14px; font-weight:800 }
.page-hero p { color:#cbe4f3; font-size:18px; line-height:140%; max-width:760px; margin:0 auto }
@media (min-width:768px) { .page-hero { padding:100px 0 80px } .page-hero h1 { font-size:50px } }

/* Standard content block */
.text-content { padding:50px 0; background:#fff }
.text-content .container { max-width:880px }
.text-content h2 { font-size:24px; line-height:115%; color:#0c4a6e; margin:32px 0 14px; font-weight:800 }
.text-content h3 { font-size:20px; line-height:120%; color:#0369a1; margin:24px 0 10px; font-weight:700 }
.text-content p { font-size:17px; line-height:155%; margin-bottom:16px; color:#2C2C2C }
.text-content ul, .text-content ol { padding-left:24px; margin-bottom:18px }
.text-content li { font-size:17px; line-height:150%; margin-bottom:8px; color:#2C2C2C }
@media (min-width:768px) { .text-content h2 { font-size:30px } .text-content h3 { font-size:23px } }

/* Generic card grid */
.cards-grid { display:grid; grid-template-columns:1fr; gap:18px; margin:24px 0 }
@media (min-width:768px) { .cards-grid { grid-template-columns:repeat(2,1fr) } }
@media (min-width:1023px) { .cards-grid.three { grid-template-columns:repeat(3,1fr) } }
.cards-grid .card { background:#fff; padding:24px; border-radius:16px; border:1px solid #e2e8f0; box-shadow:0 4px 14px rgba(12,74,110,.06) }
.cards-grid .card h3 { color:#0c4a6e; font-size:19px; margin-bottom:10px; font-weight:700 }
.cards-grid .card p { color:#2C2C2C; font-size:16px; line-height:145% }

/* Team page */
.team-grid { display:grid; grid-template-columns:1fr; gap:24px; margin-top:32px }
@media (min-width:768px) { .team-grid { grid-template-columns:repeat(2,1fr) } }
@media (min-width:1023px) { .team-grid { grid-template-columns:repeat(3,1fr) } }
.team-card { background:#fff; padding:28px 22px; border-radius:18px; text-align:center; border:1px solid #e2e8f0; box-shadow:0 6px 20px rgba(12,74,110,.08) }
.team-card .avatar { width:84px; height:84px; border-radius:50%; background:linear-gradient(135deg,#0369a1,#0c4a6e); display:flex; align-items:center; justify-content:center; color:#fff; font-size:30px; font-weight:800; margin:0 auto 16px }
.team-card h3 { color:#0c4a6e; font-size:20px; margin-bottom:4px; font-weight:800 }
.team-card .role { color:#f59e0b; font-size:14px; font-weight:700; margin-bottom:12px; text-transform:uppercase; letter-spacing:.5px }
.team-card p { font-size:15px; line-height:150%; color:#2C2C2C }

/* Contact page */
.contact-info { display:grid; grid-template-columns:1fr; gap:16px; margin:24px 0 }
@media (min-width:768px) { .contact-info { grid-template-columns:repeat(3,1fr) } }
.contact-info .info-card { background:#fff; padding:22px; border-radius:14px; text-align:center; border:1px solid #e2e8f0 }
.contact-info .info-card .icon { width:48px; height:48px; border-radius:50%; background:#0369a124; color:#0369a1; display:flex; align-items:center; justify-content:center; margin:0 auto 12px; font-size:20px; font-weight:800 }
.contact-info .info-card h3 { color:#0c4a6e; font-size:17px; margin-bottom:6px }
.contact-info .info-card a, .contact-info .info-card p { font-size:16px; color:#0369a1; text-decoration:none; font-weight:600 }

/* Sign-in form */
.auth-page { background:#f1f5f9; padding:60px 15px; min-height:60vh }
.auth-card { max-width:460px; margin:0 auto; background:#fff; padding:36px 28px; border-radius:18px; box-shadow:0 12px 40px rgba(12,74,110,.10) }
.auth-card h1 { font-size:28px; color:#0c4a6e; margin-bottom:8px; text-align:center }
.auth-card .subtitle { font-size:15px; color:#475569; text-align:center; margin-bottom:24px }
.auth-card input { width:100%; padding:14px 16px; border:1px solid #cbd5e1; border-radius:10px; font-size:16px; margin-bottom:14px; font-family:inherit; color:#0c4a6e; background:#fff }
.auth-card input:focus { outline:none; border-color:#0369a1; box-shadow:0 0 0 3px #0369a126 }
.auth-card .auth-link { text-align:center; margin-top:14px; font-size:14px; color:#475569 }
.auth-card .auth-link a { color:#0369a1; font-weight:700; text-decoration:none }

/* Risk disclosure */
.risk-disclosure { background:#0c4a6e; color:#cbe4f3; padding:32px 0; font-size:13px; line-height:150%; border-top:3px solid #f59e0b }
.risk-disclosure .container { max-width:1100px }
.risk-disclosure h3 { color:#f59e0b; font-size:15px; margin-bottom:10px; text-transform:uppercase; letter-spacing:.5px; font-weight:800 }
.risk-disclosure p { margin-bottom:8px; color:#cbe4f3 }

/* Trading view widget container */
.market-widget { background:#0c4a6e; padding:50px 0; color:#fff }
.market-widget h2 { color:#fff; text-align:center; margin-bottom:24px; font-size:26px }
.market-widget .widget-grid { display:grid; grid-template-columns:1fr; gap:14px; max-width:880px; margin:0 auto }
@media (min-width:600px) { .market-widget .widget-grid { grid-template-columns:repeat(2,1fr) } }
@media (min-width:1023px) { .market-widget .widget-grid { grid-template-columns:repeat(3,1fr); max-width:1100px } }
.market-widget .widget-grid > div { background:#082037; border-radius:12px; padding:8px }

/* Intl-tel-input flag selector – ensure flags load from /images/ */
.iti__flag { background-image: url("/images/flags.webp") }
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .iti__flag { background-image: url("/images/flags@2x.webp") }
}
.iti--separate-dial-code .iti__selected-flag { background-color: #f8fafc }
.iti__country-list { font-family: inherit; max-width: 320px }

/* Hide form preloader cleanly */
.form-preloader-orange { display:none !important }

/* Footer extras */
footer .footer-legal-note { text-align:center; font-size:13px; color:#64748b; margin-top:18px; padding:0 20px }

/* === Layout fixes for AR build === */
/* Constrain image sizes inside half.right wrappers (register sections) */
.register .half.right img { max-width: 100%; max-height: 420px; width: auto; height: auto; object-fit: contain; display: block; margin: 0 auto }
.cta .half.right img { max-width: 100%; max-height: 420px; width: auto; height: auto; object-fit: contain; display: block; margin: 0 auto }

/* Register.last .content-wrap.bg should have dark BG */
.register.last .content-wrap.bg { background-color: #0c4a6e; border-radius: 16px; color: #fff }
.register.last .content-wrap.bg h3 { color: #fff }
.register.last .content-wrap.bg .consent-text, .register.last .content-wrap.bg .consent-text p { color: #fff }
.register.last .content-wrap.bg .consent-text a { color: #f59e0b; font-weight: 700 }

/* Register row-7 H3 readability — visible white on dark or dark on light depending on viewport */
.register:not(.no-bg):not(.last) .half.left h3 { color: #fff; font-size: 28px; line-height: 1.2 }
@media (max-width: 767px) { .register:not(.no-bg):not(.last) .half.left h3 { color: #0c4a6e } }

/* Register no-bg heading layout */
.register.no-bg .content-wrap { display: flex; flex-direction: column; align-items: center }
.register.no-bg .heading { text-align: center; margin-bottom: 24px; max-width: 800px }
.register.no-bg .heading h3 { color: #0c4a6e; font-size: 26px; margin-bottom: 10px }
.register.no-bg .heading p { color: #475569; font-size: 16px; line-height: 150% }
.register.no-bg .leadform { max-width: 560px; width: 100%; background: #fff; padding: 24px; border-radius: 14px; box-shadow: 0 8px 30px rgba(12,74,110,.08); border: 1px solid #e2e8f0 }
.register.no-bg .leadform input { padding: 14px 16px; border: 1px solid #cbd5e1; border-radius: 10px; font-size: 15px; margin-bottom: 10px; width: 100%; color: #0c4a6e }
.register.no-bg .leadform input:focus { outline: none; border-color: #0369a1 }
.register.no-bg .leadform .orange-btn { margin: 10px 0 12px 0; width: 100% }
.register.no-bg .leadform .consent-text p { font-size: 12px; color: #64748b; margin: 0; text-align: center }

/* Ensure CTA text doesn't overflow the rotated dark card */
.cta .left.bg-elem { padding: 50px 40px !important; min-height: auto }
.cta .text-cta p { color: #f1f5f9 !important; font-size: 16px; line-height: 150% }
@media (min-width: 768px) { .cta .left.bg-elem { padding: 60px 50px !important } }

/* Sub-page hero: protect against any oversized images */
.page-hero img { max-width: 200px; width: auto; height: auto }
.text-content img { max-width: 100%; width: auto; height: auto; display: block; margin: 0 auto }

/* Global safety net for orphan images outside structured containers (only kicks in when image has no parent constraint) */
section img:not([class]):not(.bg-img):not(.rating-img):not(.stars) { max-width: 200px; height: auto }
.list-wrap li img, .partners-slider .p-slide img, .opportunities-slider .p-slide img, .benefits-slider .p-slide img, .card-img .wrap-img img, .reviews .rating img, .review .rating img { max-width: none }



/* =====================================================================
   UNIFIED FORM STYLING — same look for ALL .leadform on the site
   ===================================================================== */

/* Hide all hidden inputs so they don't contribute to flex layout */
.leadform input[type="hidden"] { display: none !important; position: absolute !important; }

/* Kill any rotation/transform pseudo-elements that source CSS adds */
.leadform:before,
.register .leadform:before,
.cta .left.bg-elem:before,
.register .content-wrap:before {
  transform: none !important;
}
.register:not(.no-bg):not(.last) .content-wrap:before { display: none !important; }

/* The form itself — uniform dark navy rounded panel everywhere */
.leadform {
  background-color: #0c4a6e !important;
  border-radius: 16px !important;
  padding: 28px 24px !important;
  margin: 0 auto !important;
  max-width: 520px !important;
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  gap: 12px !important;
  box-shadow: 0 8px 30px rgba(12, 74, 110, 0.15) !important;
  position: relative;
  z-index: 1;
  box-sizing: border-box;
}
@media (min-width: 768px) {
  .leadform { padding: 32px 28px !important; }
}

/* Form preloader hidden (source script may show it during submit) */
.leadform .form-preloader-orange { display: none; }

/* All visible inputs: full width, centered, identical styling */
.leadform input[type="text"],
.leadform input[type="email"],
.leadform input[type="tel"] {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 14px 16px !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: 10px !important;
  background-color: #ffffff !important;
  color: #0c4a6e !important;
  font-size: 15px !important;
  font-family: inherit !important;
  box-sizing: border-box !important;
}
.leadform input::placeholder { color: #94a3b8 !important; }
.leadform input:focus {
  outline: none !important;
  border-color: #f59e0b !important;
  box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.2) !important;
}

/* intl-tel-input wraps the tel input — make sure it's full width */
.leadform .iti { width: 100% !important; display: block !important; }
.leadform .iti input { width: 100% !important; }

/* The amber CTA button — uniform full width */
.leadform button.orange-btn,
.leadform .orange-btn {
  width: 100% !important;
  margin: 6px 0 14px 0 !important;
  padding: 14px 16px !important;
  border-radius: 10px !important;
  background-color: #f59e0b !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  letter-spacing: 0.3px !important;
  border: none !important;
  cursor: pointer !important;
  display: block !important;
  text-align: center !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  box-sizing: border-box !important;
}
.leadform button.orange-btn:hover,
.leadform .orange-btn:hover {
  background-color: #d97706 !important;
}

/* Consent text — uniform light blue on dark with amber links */
.leadform .consent-text,
.leadform .consent-text p {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  color: #cbe4f3 !important;
  text-align: center !important;
}
.leadform .consent-text a {
  color: #f59e0b !important;
  font-weight: 700 !important;
  text-decoration: underline !important;
}

/* Error message hidden by default */
.leadform .error-msg.hide { display: none !important; }

/* =====================================================================
   Headings above forms — uniform dark-navy color, left-aligned by default
   ===================================================================== */
.register .half.left h2,
.register .half.left h3 {
  color: #0c4a6e !important;
  font-size: 28px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  margin: 0 0 16px 0 !important;
  padding: 0 !important;
  text-align: left !important;
}
@media (min-width: 768px) {
  .register .half.left h2,
  .register .half.left h3 { font-size: 34px !important; }
}
.register .half.left > p {
  color: #475569 !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  margin: 0 0 20px 0 !important;
  text-align: left !important;
}

/* For .register.no-bg (centered single-column variant) */
.register.no-bg .heading h3,
.register.no-bg .heading h2 {
  color: #0c4a6e !important;
  font-size: 26px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  margin: 0 0 12px 0 !important;
  text-align: center !important;
}
@media (min-width: 768px) {
  .register.no-bg .heading h3,
  .register.no-bg .heading h2 { font-size: 32px !important; }
}
.register.no-bg .heading p {
  color: #475569 !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
  text-align: center !important;
  margin: 0 auto 24px auto !important;
  max-width: 620px !important;
}

/* =====================================================================
   Layout of register sections
   ===================================================================== */

/* Mobile: stack vertically */
.register:not(.no-bg):not(.last) .content-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 24px !important;
  padding: 32px 16px !important;
  background: transparent !important;
}
.register:not(.no-bg):not(.last) .content-wrap .half {
  width: 100% !important;
  max-width: 520px !important;
  margin: 0 auto !important;
  flex: none !important;
}
.register:not(.no-bg):not(.last) .half.left {
  display: block !important;
}

/* Desktop ≥768: side by side, half.left and half.right */
@media (min-width: 768px) {
  .register:not(.no-bg):not(.last) .content-wrap {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 56px !important;
    padding: 56px 24px !important;
  }
  .register:not(.no-bg):not(.last) .content-wrap .half {
    width: auto !important;
    flex: 0 1 460px !important;
    max-width: 460px !important;
    margin: 0 !important;
  }
  .register:not(.no-bg):not(.last) .half.left {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: center !important;
  }
  .register:not(.no-bg):not(.last) .half.right {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
}

/* Illustration in half.right — constrained size */
.register .half.right img,
.register .half.right .bg-img {
  max-width: 100% !important;
  max-height: 360px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  display: block !important;
  margin: 0 auto !important;
}

/* register.no-bg: centered, single column, no halves */
.register.no-bg .content-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 40px 16px !important;
  background: transparent !important;
}
.register.no-bg .heading {
  width: 100% !important;
  max-width: 620px !important;
  margin: 0 auto 24px auto !important;
}

/* register.last — dark wrap with H3 + form + image inside */
.register.last .content-wrap {
  background-color: #0c4a6e !important;
  border-radius: 16px !important;
  padding: 32px 24px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 24px !important;
}
@media (min-width: 768px) {
  .register.last .content-wrap {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 48px 40px !important;
    gap: 48px !important;
  }
  .register.last .content-wrap .half {
    flex: 1 1 0 !important;
    width: auto !important;
    max-width: 460px !important;
  }
}
.register.last .content-wrap h3 {
  color: #ffffff !important;
  font-size: 24px !important;
  line-height: 1.3 !important;
  margin: 0 0 16px 0 !important;
  text-align: left !important;
}
@media (min-width: 768px) {
  .register.last .content-wrap h3 { font-size: 28px !important; }
}
.register.last .leadform {
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
}
.register.last .leadform .consent-text { text-align: left !important; }
.register.last .half.right img { max-height: 240px !important; }

/* Sticky header fix for the section anchor #form */
.register[id="form"] { scroll-margin-top: 80px; }

/* =====================================================================
   BUILD STAMP v8 — visible amber prefix in footer copyright
   ===================================================================== */
footer .copyright::before {
  content: "BUILD v8 · ";
  color: #f59e0b;
  font-weight: 800;
}

/* === Bigger hamburger hit-area for reliable mobile tap === */
.header-wrap.mob .hamburger {
  width: 44px !important;
  height: 44px !important;
  padding: 12px 7px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: stretch !important;
  cursor: pointer !important;
  position: relative !important;
  z-index: 1000 !important;
  background: transparent !important;
  border: none !important;
  -webkit-tap-highlight-color: rgba(245, 158, 11, 0.3) !important;
  touch-action: manipulation !important;
}
.header-wrap.mob .hamburger .line {
  display: block !important;
  width: 100% !important;
  min-height: 3px !important;
  height: 3px !important;
  flex: 0 0 3px !important;
  background: #0c4a6e !important;
  border-radius: 4px !important;
  transition: all 0.3s ease !important;
}
.header-wrap.mob .hamburger .line:not(:last-child) {
  margin-bottom: 5px !important;
}
.header-wrap.mob.opened .hamburger .line:first-child {
  transform: translateY(7px) rotate(45deg) !important;
}
.header-wrap.mob.opened .hamburger .line:nth-child(2) {
  opacity: 0 !important;
}
.header-wrap.mob.opened .hamburger .line:last-child {
  transform: translateY(-7px) rotate(-45deg) !important;
}

/* Ensure mobile-menu__wrap is properly positioned and styled */
.mobile-menu__wrap {
  position: fixed !important;
  z-index: 999 !important;
  top: 60px !important;
  right: 0 !important;
  width: 100% !important;
  height: calc(100vh - 60px) !important;
  background: #ffffff !important;
  transform: translateX(110%) !important;
  transition: transform 0.4s ease !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  padding: 24px 16px !important;
  box-sizing: border-box !important;
}
.mobile-menu__wrap.active {
  transform: translateX(0) !important;
}
.mobile-menu__wrap .menu {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 20px !important;
  width: 100% !important;
  margin: 24px 0 auto 0 !important;
}
.mobile-menu__wrap .menu a {
  font-size: 18px !important;
  color: #0c4a6e !important;
  text-decoration: none !important;
  padding: 8px 16px !important;
  font-weight: 500 !important;
}
.mobile-menu__wrap .menu a.active {
  color: #f59e0b !important;
  font-weight: 700 !important;
}
.mobile-menu__wrap .header-btn__wrap {
  width: 100% !important;
  margin-top: auto !important;
  padding-bottom: 32px !important;
}
.mobile-menu__wrap .header-btn__wrap .orange-btn {
  display: block !important;
  width: 100% !important;
  padding: 14px 16px !important;
  background: #f59e0b !important;
  color: #fff !important;
  text-align: center !important;
  border-radius: 10px !important;
  text-decoration: none !important;
  font-weight: 700 !important;
  font-size: 16px !important;
}

/* Hide mobile menu wrap on desktop */
@media (min-width: 1023px) {
  .mobile-menu__wrap {
    display: none !important;
  }
  .header-wrap.mob {
    display: none !important;
  }
}
@media (max-width: 1022px) {
  .header-wrap.desk {
    display: none !important;
  }
}

/* Update build stamp to v9 so user knows code is fresh */
footer .copyright::before {
  content: "BUILD v10 · " !important;
}
