@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Roboto:wght@400;500;600;700&display=swap");

.vanilla-roi-ready .roi-wrap { display: block !important; }
.roi-wrap, .roi-wrap * { font-family: "Inter", sans-serif; }
.roi-wrap { background: #f7fafc; color: #0f172a; }
body > header > div:last-child { display: none !important; }
body > header { background: #001615 !important; }
body > header > .container { width: calc(100% - 144px) !important; max-width: 1296px !important; margin-right: auto !important; margin-left: auto !important; padding-top: 16px !important; padding-bottom: 16px !important; }
body > header .logo img { height: 36px !important; }
body > header nav ul { padding: 4px 6px !important; }
body > header nav ul > li { height: 32px !important; padding-right: 18px !important; padding-left: 18px !important; line-height: 32px !important; }
body > header .dropdown-btn { width: 36px !important; height: 36px !important; padding: 8px !important; border: 0 !important; background: transparent url("/roi-calculator/globe.svg") center / 20px 20px no-repeat !important; }
body > header .dropdown-btn img, body > header .dropdown-btn #selected-language { display: none !important; }
.vrc-partner-link { color: #fff; font-size: 14px; font-weight: 500; white-space: nowrap; }
.vrc-hero { box-sizing: border-box; height: 606px; margin: 0 !important; padding: 149px 20px 0 !important; background: radial-gradient(ellipse 70% 45% at 50% 100%, rgba(28,241,223,.28), transparent 70%), #001615; color: #fff; text-align: center; }
.vrc-hero-inner { max-width: 760px; margin: auto; }
.vrc-fourcast { width: 200px; height: 45px; display: flex; align-items: center; gap: 10px; margin: 0 auto 20px; }
.vrc-fourcast img:first-child { width: 45px !important; height: 45px !important; }
.vrc-fourcast img:last-child { width: 145px !important; height: 26px !important; }
.vrc-hero h1 { margin: 0 0 16px; color: transparent; background: linear-gradient(180deg,#fff,rgba(255,255,255,.7)); background-clip: text; -webkit-background-clip: text; font-family: "Roboto",sans-serif; font-size: 62px; font-weight: 400; line-height: 72px; letter-spacing: 0; }
.vrc-hero h1 strong { display: block; color: transparent; background: linear-gradient(180deg,#3beee2,rgba(5,161,148,.7)); background-clip: text; -webkit-background-clip: text; font-family: "Roboto",sans-serif; font-size: 72px; font-weight: 500; line-height: 72px; }
.vrc-hero p { width: 692px; margin: 0 auto; color: #c6c6c6; font-family: "Roboto",sans-serif; font-size: 19.5px; font-weight: 400; line-height: 28px; }
#setupSection > section:nth-child(2) { padding: 0 20px 80px; background: #f7fafc; }
#setupSection > section:nth-child(2) > .container { width: 100% !important; max-width: 1088px !important; margin: -107px auto 0; padding: 0; transform: none; border: 1px solid #dbe5e9; border-radius: 17px; background: #fff; box-shadow: 0 18px 38px rgba(0,52,48,.15); overflow: hidden; }
.vrc-shell { display: grid; grid-template-columns: 320px minmax(0,1fr); min-height: 659px; }
.vrc-aside { display: flex; flex-direction: column; gap: 28px; padding: 32px; background: #003d38; color: #fff; }
.vrc-aside-logo { width: 100px; height: 23px; display: flex; align-items: center; gap: 5px; margin-bottom: 22px; }
.vrc-aside-logo img:first-child { width: 23px !important; height: 23px !important; }
.vrc-aside-logo img:last-child { width: 72px !important; height: 13px !important; }
.vrc-aside h3 { margin-bottom: 8px; color: #fff; font-size: 18px; font-weight: 700; }
.vrc-aside p { color: #d5e0df; font-size: 12px; line-height: 1.6; }
.vrc-metrics { display: grid; gap: 16px; }
.vrc-metric { min-height: 60px; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 16px; border: 1px solid rgba(255,255,255,.05); border-radius: 12px; background: rgba(0,22,21,.5); font-size: 12px; font-weight: 400; }
.vrc-metric strong { color: #2c958c; font-size: 18px; }
.vrc-metric strong.red { color: #ef4444; }
.vrc-metric strong.pill { padding: 3px 7px; border: 1px solid rgba(44,149,140,.3); border-radius: 5px; background: rgba(44,149,140,.1); font-size: 11px; }
.vrc-metric i { display: block; width: 96px; height: 12px; border-radius: 4px; background: rgba(44,149,140,.12); }
.vrc-privacy { display: none; }
.vrc-privacy b { width: 28px; height: 28px; display: grid; place-items: center; flex: 0 0 auto; border-radius: 50%; background: rgba(44,149,140,.15); color: #2c958c; }
.vrc-main { display: flex; flex-direction: column; min-width: 0; padding: 32px 32px 0; }
.vrc-stepper { display: grid; grid-template-columns: repeat(4,1fr); margin-bottom: 32px; }
.vrc-stepper button { position: relative; display: flex; flex-direction: column; align-items: center; gap: 7px; border: 0; color: #94a3b8; background: transparent; font-size: 11px; font-weight: 600; cursor: pointer; }
.vrc-stepper button:not(:last-child)::after { content: ""; position: absolute; top: 15px; left: calc(50% + 26px); width: calc(100% - 52px); height: 2px; background: #e2e8f0; }
.vrc-stepper b { position: relative; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; z-index: 1; border: 2px solid #dbe4ee; border-radius: 50%; background: #fff; color: #94a3b8; font-size: 13px; line-height: 1; }
.vrc-stepper .active, .vrc-stepper .complete { color: #2c958c; }
.vrc-stepper .active b, .vrc-stepper .complete b { border-color: #2c958c; color: #2c958c; }
.vrc-stepper .complete b { background: #2c958c; color: transparent; }
.vrc-stepper .complete b::after { content: "✓"; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); color: #fff; font-size: 15px; line-height: 1; }
.vrc-step-head h2 { margin: 0 0 4px; color: #0f172a; font-size: 18px; font-weight: 700; }
.vrc-step-head p { margin-bottom: 20px; color: #64748b; font-size: 13px; }
.vrc-panel { display: none; }
.vrc-panel.active { display: grid; gap: 20px; }
.vrc-step-card, #setupSection .roi-card { padding: 0; border: 0; border-radius: 0; background: transparent; box-shadow: none; }
#setupSection .roi-card:hover { border-color: transparent; box-shadow: none; }
#setupSection .fleet-grid { grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 20px; }
#setupSection .fleet-btn { display: flex; min-height: 86px; justify-content: center; border: 1px solid #e2e8f0; border-radius: 12px; background: #fff; color: #64748b; font-size: 13px; }
#setupSection .fleet-btn svg { color: #94a3b8; }
#setupSection .fleet-btn:hover, #setupSection .fleet-btn.active { border-color: #2c958c; background: #e8f8f4; color: #15998e; box-shadow: none; }
#setupSection .fleet-btn:hover svg, #setupSection .fleet-btn.active svg { color: #15998e; }
#setupSection .roi-label, #setupSection .sl-lbl { color: #0f172a; font-size: 12px; font-weight: 700; }
#setupSection .roi-input, #setupSection .roi-select { min-height: 58px; border: 1px solid #e2e8f0; border-radius: 12px; background: #fff; color: #4b5563; font-family: "Inter",sans-serif; font-weight: 800; }
#setupSection .roi-input:focus, #setupSection .roi-select:focus { border-color: #2c958c; background: #fff; box-shadow: 0 0 0 4px rgba(44,149,140,.1); }
#setupSection .sw.has-icon { color: #94a3b8; }
#setupSection .sw.has-icon .sw-icon { color: #2c958c; }
#setupSection .ipfx, #setupSection .ipsfx, #setupSection .sl-val { color: #64748b; }
#setupSection .four-col, #setupSection .two-col { grid-template-columns: repeat(2,minmax(0,1fr)); }
#setupSection .vrc-panel[data-step="3"] .roi-card { padding-bottom: 20px; border-bottom: 1px solid #e2e8f0; }
#setupSection .vrc-panel[data-step="3"] .roi-card::before { content: "Variable costs per kilometre"; display: block; margin-bottom: 16px; color: #0f172a; font-size: 13px; font-weight: 700; }
#setupSection .vrc-panel[data-step="3"] .roi-card:last-child::before { content: "Fixed monthly costs"; }
#setupSection .shr, #setupSection .avnote { display: none; }
#setupSection .roi-info-bar { margin: 0; border: 1px solid #c3dcff; border-radius: 10px; background: #eaf3ff; color: #47617f; }
.vrc-target { display: grid; gap: 8px; color: #0f172a; font-size: 12px; font-weight: 700; }
.vrc-target select { min-height: 48px; padding: 0 14px; border: 1px solid #dbe4ee; border-radius: 8px; color: #64748b; background: #fff; }
.vrc-footer { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin: auto -32px 0; padding: 24px; border-top: 1px solid #e2e8f0; background: #f7fafc; }
.vrc-footer > div { display: flex; align-items: center; gap: 12px; }
.vrc-footer span { color: #94a3b8; font-size: 11px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.vrc-footer strong { padding: 2px 8px; border-radius: 4px; background: rgba(44,149,140,.1); color: #2c958c; font-size: 11px; font-weight: 800; text-transform: uppercase; }
.vrc-footer strong[data-confidence="medium"] { background: rgba(245,158,11,.12); color: #b45309; }
.vrc-footer strong[data-confidence="low"] { background: rgba(239,68,68,.1); color: #dc2626; }
.vrc-footer button { min-width: 92px; padding: 15px 20px; border: 1px solid #dbe4ee; border-radius: 10px; background: #fff; color: #64748b; font-family: "Roboto",sans-serif; font-size: 14px; font-weight: 500; cursor: pointer; }
.vrc-footer #vrcNext { border-color: rgba(255,255,255,.14); background: linear-gradient(4deg,#198a81 17.5%,#23bbad); color: #fff; box-shadow: inset 0 1px 3px rgba(255,255,255,.25); }
#snapshotSection { min-height: 100vh; padding: 0 20px 70px; background: linear-gradient(to bottom,#001615 0 606px,#fff 606px); }
#snapshotSection > section { margin: 0 !important; padding: 149px 0 0; }
#snapshotSection > section > .container { width: 100% !important; max-width: 1240px !important; margin-right: auto !important; margin-left: auto !important; padding: 0; }
#snapshotSection .snap-top { display: block; margin: 0 auto; text-align: center; }
#snapshotSection .snap-top > div { max-width: 954px; margin: 0 auto; }
.vrc-snapshot-brand { width: 200px; height: 50px; display: flex; align-items: center; gap: 12px; margin: 0 auto 20px; }
.vrc-snapshot-brand img:first-child { width: 50px !important; height: 50px !important; }
.vrc-snapshot-brand img:last-child { width: 138px !important; height: 26px !important; }
#snapshotSection .snap-top h2 { margin: 0; color: transparent; background: linear-gradient(180deg,#fff,rgba(255,255,255,.7)); background-clip: text; -webkit-background-clip: text; font-family: "Roboto",sans-serif; font-size: 62px; font-weight: 400; line-height: 72px; letter-spacing: 0; }
#snapshotSection .snap-top h2 strong { display: block; color: transparent; background: linear-gradient(180deg,#3beee2,rgba(5,161,148,.7)); background-clip: text; -webkit-background-clip: text; font-size: 72px; font-weight: 500; }
#snapshotSection .snap-top p { max-width: 692px; margin: 16px auto 0; color: #c6c6c6; font-family: "Roboto",sans-serif; font-size: 19.5px; line-height: 28px; }
#snapshotSection .back-btn { display: none; }
#snapshotSection .snap-cards { grid-template-columns: repeat(5,minmax(0,1fr)); gap: 16px; margin: 43px 0 64px; }
#snapshotSection .snap-card { position: relative; box-sizing: border-box; min-height: 160px; padding: 32px; border: 1px solid #eceff3; border-radius: 12px; background: #fff; box-shadow: 0 2px 4px rgba(13,13,18,.04); }
#snapshotSection .snap-card-lbl { min-height: 16px; margin-bottom: 22px; color: #94a3b8; font-size: 12px; font-weight: 700; letter-spacing: .6px; line-height: 16px; }
#snapshotSection .snap-card-val { margin-bottom: 4px; color: #0f172a; font-size: 30px; line-height: 36px; }
#snapshotSection .snap-card-val .unit, #snapshotSection .eff-total { color: #94a3b8; font-size: 14px; font-weight: 700; }
#snapshotSection .snap-card-sub { color: #64748b; font-size: 12px; font-weight: 500; line-height: 18px; }
#snapshotSection .vrc-target-card { display: none; }
#snapshotSection .vrc-score-card { grid-column: auto; }
#snapshotSection .vrc-monthly-loss-card .snap-card-val { color: #16a34a; }
#snapshotSection #snapYearlyLoss { color: #ef4444; }
#snapshotSection .vrc-score-card .snap-card-lbl { display: flex; align-items: center; justify-content: space-between; }
#snapshotSection .vrc-score-card .eff-badge { position: absolute; top: 32px; right: 32px; margin: 0; padding: 4px 7px !important; font-size: 12px; letter-spacing: .6px; line-height: 18px; text-transform: uppercase; }
.vrc-score-track { height: 24px; overflow: hidden; margin-top: 8px; border-radius: 6px; background: #e5e7eb; }
.vrc-score-track i { display: block; width: 20%; height: 100%; background: #2c958c; }
.vrc-loss-grid { display: grid; grid-template-columns: 320px minmax(0,1fr); gap: 100px; align-items: center; margin: 0 0 128px; }
.vrc-loss-copy h3 { margin: 0 0 14px; color: #111827; font-size: 32px; font-weight: 800; line-height: 34px; letter-spacing: -.8px; }
.vrc-loss-copy > p { margin: 0 0 72px; color: #8aa0bb; font-size: 14px; font-weight: 500; line-height: 21px; }
#snapshotSection .snap-insight { display: block; margin: 0; padding: 16px; border: 0; border-radius: 4px; background: rgba(2,47,43,.1); color: #000; font-size: 18px; line-height: 21px; box-shadow: inset 0 2px 4px rgba(0,0,0,.05); }
#snapshotSection .snap-insight svg { display: none; }
#snapshotSection .snap-insight strong { color: #198a81 !important; }
.vrc-loss-chart { height: 368px; padding: 25px; border: 1px solid rgba(255,255,255,.05); border-radius: 16px; background: #022f2b; box-shadow: 0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1); }
.vrc-chart-head { display: flex; align-items: center; justify-content: space-between; color: #90a1b9; font-size: 14px; font-weight: 600; }
.vrc-chart-head b { display: flex; align-items: center; gap: 8px; font-weight: 600; }
.vrc-chart-head i { width: 12px; height: 12px; border-radius: 50%; background: #2c958c; }
.vrc-bars { height: 286px; display: grid; grid-template-columns: repeat(5,1fr); gap: 28px; align-items: end; padding: 28px 22px 0; background-image: repeating-linear-gradient(to bottom,rgba(255,255,255,.045),rgba(255,255,255,.045) 1px,transparent 1px,transparent 48px); }
.vrc-bars > div { height: 100%; display: flex; flex-direction: column; justify-content: flex-end; align-items: center; }
.vrc-bars > div > i { width: 58px; min-height: 3px; border-radius: 6px 6px 0 0; background: #233e70; transition: height .35s ease; }
.vrc-bars > div.primary > i { background: #2c958c; }
.vrc-bars span { min-height: 42px; margin-top: 9px; color: #8da2bb; font-size: 9px; font-weight: 600; line-height: 12px; text-align: center; }
.vrc-bars small { color: #516b86; font-size: 8px; }
#snapshotSection .locked-card { position: relative; min-height: 614px; overflow: hidden; padding: 49px 32px 60px; border: 1px solid #cbe0fb; border-radius: 12px; background: #001615; box-shadow: 0 1px 3px rgba(0,0,0,.1); }
#snapshotSection .locked-card::before { content: ""; position: absolute; z-index: 2; inset: 0; background: linear-gradient(to bottom,rgba(44,149,140,.1),rgba(2,47,43,.25),rgba(44,149,140,.32)); pointer-events: none; }
#snapshotSection .locked-card::after { content: ""; position: absolute; z-index: 3; top: 0; right: 0; left: 0; height: 4px; background: linear-gradient(90deg,transparent,#2c958c,transparent); opacity: .3; }
#snapshotSection .locked-card h3 { position: relative; z-index: 1; margin: 0; color: transparent; background: linear-gradient(180deg,#3beee2,rgba(5,161,148,.7)); background-clip: text; -webkit-background-clip: text; font-family: "Roboto",sans-serif; font-size: 62px; font-weight: 500; line-height: 88px; }
#snapshotSection .locked-card h3 span { color: transparent; background: linear-gradient(180deg,#fff,rgba(255,255,255,.7)); background-clip: text; -webkit-background-clip: text; font-weight: 400; }
#snapshotSection .locked-card > p { position: relative; z-index: 1; max-width: 692px; margin: 0 auto 34px; color: #c6c6c6; font-family: "Roboto",sans-serif; font-size: 19.5px; line-height: 28px; }
#snapshotSection .blur-grid { position: relative; z-index: 1; gap: 24px; margin: 0; opacity: .35; filter: blur(2px); }
#snapshotSection .blur-card { min-height: 140px; padding: 25px; border: 1px solid #c3dcff; border-radius: 16px; background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.1); }
#snapshotSection .blur-card-lbl { margin: 32px 0 10px; color: #0f2e53; font-size: 14px; font-weight: 700; }
#snapshotSection .blur-card-val, #snapshotSection .blur-card-sub { height: 8px; overflow: hidden; border-radius: 4px; background: #e2ecf8; color: transparent; filter: none; }
#snapshotSection .blur-card-sub { width: 54%; margin-top: 8px; }
#snapshotSection .locked-card .analyze-btn { position: absolute; z-index: 4; bottom: 124px; left: 50%; width: auto; min-width: 224px; margin: 0; padding: 16px 20px; transform: translateX(-50%); font-family: "Roboto",sans-serif; font-size: 20px; line-height: 20px; box-shadow: 0 -3px 9px #23bbad; }
.vrc-site-footer { min-height: 660px; padding: 60px 20px 0; background: #001615 !important; color: #fff; font-family: "Inter",sans-serif; }
.vrc-site-footer-inner { max-width: 1240px; margin: auto; }
.vrc-footer-cta { height: 140px; display: flex; align-items: center; justify-content: space-between; padding: 0 48px; border: 1px solid #5b6664; border-radius: 8px; background: rgba(66,79,78,.42); }
.vrc-footer-cta h2 { margin: 0; color: #fff; font-size: 23px; font-weight: 600; line-height: 1.65; }
.vrc-footer-cta h2 strong { color: #079b90; font-weight: 600; }
.vrc-footer-cta a { padding: 16px 21px; border: 1px solid rgba(255,255,255,.16); border-radius: 10px; background: linear-gradient(4deg,#198a81 17.5%,#23bbad); color: #fff; font-size: 13px; font-weight: 600; }
.vrc-footer-grid { display: grid; grid-template-columns: 2.3fr repeat(4,1fr); gap: 44px; margin-top: 60px; }
.vrc-footer-grid h3 { margin: 0 0 24px; color: #fff; font-size: 15px; font-weight: 500; }
.vrc-footer-grid a { display: block; margin-bottom: 18px; color: #8d9998; font-size: 14px; }
.vrc-footer-grid .teal { color: #009f94; }
.vrc-footer-brand img { width: 100px; height: auto; margin-bottom: 12px; }
.vrc-footer-brand p { margin: 0 0 46px; color: #7d8988; font-size: 16px; }
.vrc-footer-brand h3 { margin-bottom: 14px; font-size: 16px; font-weight: 600; }
.vrc-footer-brand form { display: flex; gap: 8px; }
.vrc-footer-brand input { width: 325px; height: 50px; padding: 0 16px; border: 0; border-radius: 10px; background: #142c2a; color: #fff; }
.vrc-footer-brand button { height: 50px; padding: 0 22px; border: 1px solid rgba(255,255,255,.16); border-radius: 9px; background: linear-gradient(4deg,#198a81 17.5%,#23bbad); color: #fff; cursor: pointer; }
.vrc-footer-bottom { display: flex; align-items: center; justify-content: space-between; margin-top: 44px; padding: 30px 0 50px; border-top: 1px solid rgba(255,255,255,.08); color: #899392; font-size: 13px; }
.vrc-footer-bottom div { display: flex; gap: 24px; font-weight: 700; text-transform: uppercase; }
@media (max-width: 900px) { .vrc-shell { grid-template-columns: 1fr; } .vrc-aside { display: none; } #snapshotSection .snap-cards { grid-template-columns: repeat(2,minmax(0,1fr)); } .vrc-loss-grid { grid-template-columns: 1fr; gap: 30px; } .vrc-loss-copy > p { margin-bottom: 24px; } }
@media (max-width: 640px) { .vrc-hero { height: auto; padding: 120px 16px 120px !important; } .vrc-hero h1, .vrc-hero h1 strong { font-size: 38px; line-height: 44px; } .vrc-hero p { width: auto; font-size: 14px; line-height: 21px; } .vrc-main { padding: 20px 16px 0; } .vrc-stepper span { display: none; } .vrc-footer { margin: auto -16px 0; padding: 16px; } #setupSection .fleet-grid { grid-template-columns: repeat(2,1fr); } #setupSection .four-col, #setupSection .two-ir, #setupSection .dropdowns-row { grid-template-columns: 1fr; } #snapshotSection { padding: 0 12px 50px; background: linear-gradient(to bottom,#001615 0 590px,#fff 590px); } #snapshotSection > section { padding-top: 120px; } #snapshotSection .snap-top h2, #snapshotSection .snap-top h2 strong { font-size: 38px; line-height: 44px; } #snapshotSection .snap-top p { width: auto; font-size: 14px; line-height: 21px; } #snapshotSection .snap-cards { grid-template-columns: 1fr; gap: 14px; margin-top: 45px; } .vrc-loss-grid { margin-bottom: 44px; } .vrc-loss-copy h3 { font-size: 28px; line-height: 31px; } .vrc-loss-chart { height: 330px; padding: 16px 8px; overflow: hidden; } .vrc-chart-head { padding: 0 8px; font-size: 10px; } .vrc-bars { height: 270px; gap: 8px; padding-inline: 4px; } .vrc-bars > div > i { width: 32px; } #snapshotSection .locked-card { min-height: 650px; padding: 40px 16px; } #snapshotSection .locked-card h3 { font-size: 38px; line-height: 46px; } #snapshotSection .locked-card > p { font-size: 14px; line-height: 21px; } #snapshotSection .blur-grid { grid-template-columns: 1fr 1fr; gap: 12px; } #snapshotSection .blur-card { min-height: 120px; padding: 16px; } #snapshotSection .locked-card .analyze-btn { bottom: 70px; font-size: 16px; } .vrc-site-footer { padding: 40px 16px; } .vrc-footer-cta { height: auto; align-items: flex-start; gap: 24px; padding: 28px; flex-direction: column; } .vrc-footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; } .vrc-footer-brand { grid-column: 1 / -1; } .vrc-footer-brand input { width: 100%; } }

@media (max-width: 640px) {
    body > header > .container {
        width: calc(100% - 24px) !important;
    }

    #setupSection > section:nth-child(2) {
        padding-bottom: 48px;
    }

    #setupSection > section:nth-child(2) > .container {
        margin-top: -72px;
    }

    #setupSection .vrc-panel [style*="grid-template-columns:1fr 1fr"] {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    .vrc-footer {
        flex-wrap: wrap;
    }

    .vrc-footer > div:last-child {
        width: 100%;
    }

    .vrc-footer button {
        flex: 1 1 0;
    }

    #snapshotSection .locked-card .analyze-btn {
        width: calc(100% - 32px);
        min-width: 0;
        white-space: normal;
    }

    .vrc-footer-brand form,
    .vrc-footer-bottom {
        align-items: stretch;
        flex-direction: column;
    }

    .vrc-footer-brand button {
        flex: 0 0 auto;
    }
}

/* ===== STEP VALIDATION ===== */
#setupSection .roi-input.is-invalid,
#setupSection .roi-select.is-invalid {
    border-color: #ef4444;
    background: #fef2f2;
}

#setupSection .roi-input.is-invalid:focus,
#setupSection .roi-select.is-invalid:focus {
    border-color: #ef4444;
    box-shadow: 0 0 0 4px rgba(239, 68, 68, .12);
}

#setupSection .roi-field.is-invalid .roi-label {
    color: #b91c1c;
}

#setupSection .vrc-field-error {
    display: none;
    margin-top: 6px;
    color: #b91c1c;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.4;
}

#setupSection .roi-field.is-invalid .vrc-field-error {
    display: block;
}

.vrc-step-error {
    display: none;
    margin: 0 0 18px;
    padding: 12px 16px;
    border: 1px solid #fecaca;
    border-radius: 10px;
    background: #fef2f2;
    color: #b91c1c;
    font-size: 13px;
    line-height: 1.5;
}

.vrc-step-error.show {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.vrc-step-error > svg {
    flex-shrink: 0;
    margin-top: 2px;
    color: #dc2626;
}

.vrc-step-error b {
    display: block;
    font-weight: 700;
    margin-bottom: 2px;
    color: #991b1b;
}

.vrc-step-error span {
    color: #b91c1c;
}
