/* VETInnovate Platform v2.4.0 - Theme-proof */
:root{--vi:#1e3a5f;--vi-lt:#2a5080;--vi-acc:#2196F3;--vi-txt:#333;--vi-txt2:#666;--vi-bdr:#e0e0e0;--vi-bg:#f5f7fa;--vi-w:#fff;--vi-r:10px;--vi-sh:0 2px 12px rgba(0,0,0,.06);--vi-sh2:0 6px 24px rgba(0,0,0,.10)}

/* MOBILE HEADER - hamburger icon fix + row alignment */
@media(max-width:1024px){
    .elementor-menu-toggle{border:none !important;background:none !important;padding:6px !important;cursor:pointer !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;width:40px !important;height:40px !important;min-width:0 !important;min-height:0 !important}
    .elementor-menu-toggle svg.e-font-icon-svg{display:block !important;width:24px !important;height:24px !important;fill:var(--vi) !important}
    .elementor-menu-toggle .elementor-menu-toggle__icon--open{display:block !important}
    .elementor-menu-toggle .elementor-menu-toggle__icon--close{display:none !important}
    .elementor-menu-toggle[aria-expanded="true"] .elementor-menu-toggle__icon--open{display:none !important}
    .elementor-menu-toggle[aria-expanded="true"] .elementor-menu-toggle__icon--close{display:block !important}
}

/* FORCE white background during page transitions (prevents orange flash) */
html,body{background-color:#fff !important}
::view-transition-old(root),::view-transition-new(root){background-color:#fff !important}

/* HIDE WordPress page title on plugin pages */
body.page .entry-title,
body.page .page-title,
body.page article > header,
body.page .entry-header{display:none !important}

/* KILL red/theme outlines on all vi elements */
.vi-auth-page *:focus,
.vi-auth-page *:active,
.vi-dashboard *:focus,
.vi-dashboard *:active,
.vi-form-wrap *:focus,
.vi-form-wrap *:active,
.vi-placeholder-page *:focus,
.vi-placeholder-page *:active,
.vi-assess-form-wrap *:focus,
.vi-assess-form-wrap *:active,
.vi-assess-results *:focus,
.vi-assess-results *:active{outline:none !important;box-shadow:none !important}
.vi-auth-page a,.vi-auth-page a:focus,.vi-auth-page a:active,
.vi-dashboard a,.vi-dashboard a:focus,.vi-dashboard a:active,
.vi-form-wrap a,.vi-form-wrap a:focus,.vi-form-wrap a:active,
.vi-placeholder-page a,.vi-placeholder-page a:focus,.vi-placeholder-page a:active{outline:none !important;box-shadow:none !important;text-decoration:none !important}
.vi-auth-page button,.vi-auth-page button:focus,.vi-auth-page button:active,
.vi-submit,.vi-submit:focus,.vi-submit:active,
.vi-btn,.vi-btn:focus,.vi-btn:active{outline:none !important;box-shadow:none !important}
/* Re-add focus for inputs */
.vi-auth-form .vi-f input:focus,
.vi-auth-form .vi-f select:focus,
.vi-field input:focus,
.vi-field select:focus{box-shadow:0 0 0 3px rgba(33,150,243,.12) !important}
/* Keyboard focus-visible indicators for all interactive elements */
.vi-submit:focus-visible,
.vi-btn:focus-visible,
.vi-auth-tab:focus-visible,
.vi-pw-toggle:focus-visible,
.vi-header-btn:focus-visible,
.vi-lang-btn:focus-visible,
.vi-link-sm:focus-visible,
.vi-check input:focus-visible,
.vi-assess-rating__circle:focus-visible{outline:2px solid var(--vi-acc) !important;outline-offset:2px !important}

/* AUTH PAGE - break out of theme container */
.vi-auth-page{width:100vw !important;max-width:100vw !important;margin-left:calc(-50vw + 50%) !important;padding:48px 20px !important;box-sizing:border-box !important;display:flex !important;justify-content:center !important}
.vi-auth-card{display:grid !important;grid-template-columns:1fr 1px 1.2fr !important;background:var(--vi-w) !important;border-radius:var(--vi-r) !important;box-shadow:var(--vi-sh) !important;overflow:hidden !important;width:100% !important;max-width:1060px !important}
.vi-auth-col{padding:40px 36px !important}
.vi-auth-title{font-size:1.35rem !important;font-weight:700 !important;color:var(--vi) !important;margin:0 0 6px !important;padding:0 !important;border:none !important;background:none !important}
.vi-auth-sub{font-size:.85rem !important;color:var(--vi-txt2) !important;margin:0 0 22px !important;line-height:1.55 !important;padding:0 !important}
.vi-auth-form{display:flex !important;flex-direction:column !important;gap:16px !important}
.vi-auth-form .vi-f{display:flex !important;flex-direction:column !important;gap:4px !important}
.vi-auth-form .vi-f label{font-size:.82rem !important;font-weight:600 !important;color:var(--vi-txt2) !important;background:none !important;border:none !important;padding:0 !important;margin:0 !important;line-height:1.4 !important;display:block !important}
.vi-auth-form .vi-f input[type="text"],
.vi-auth-form .vi-f input[type="email"],
.vi-auth-form .vi-f input[type="password"],
.vi-auth-form .vi-f select{width:100% !important;padding:9px 12px !important;font-size:.9rem !important;border:1.5px solid var(--vi-bdr) !important;border-radius:6px !important;background:var(--vi-w) !important;color:var(--vi-txt) !important;box-sizing:border-box !important;height:auto !important;min-height:0 !important;margin:0 !important;outline:none !important;-webkit-appearance:none !important;line-height:1.4 !important}
.vi-auth-form .vi-f-half{display:grid !important;grid-template-columns:1fr 1fr !important;gap:12px !important}
.vi-auth-form .vi-f-row{display:flex !important;align-items:center !important;justify-content:space-between !important;flex-wrap:wrap !important;gap:8px !important}
.vi-req{color:#e53935 !important}
.vi-hint{font-size:.75rem !important;color:var(--vi-txt2) !important;margin-top:2px !important}

/* PASSWORD TOGGLE - class-based visibility */
.vi-pw{position:relative !important;display:flex !important;align-items:center !important}
.vi-pw input{width:100% !important;padding-right:40px !important}
.vi-pw-toggle{position:absolute !important;right:10px !important;top:50% !important;transform:translateY(-50%) !important;background:none !important;border:none !important;cursor:pointer !important;padding:4px !important;color:var(--vi-txt2) !important;display:flex !important;align-items:center !important;line-height:1 !important;width:auto !important;height:auto !important;min-width:0 !important;min-height:0 !important;border-radius:4px !important;margin:0 !important}
.vi-pw-toggle:hover{color:var(--vi) !important}
.vi-pw-eye,.vi-pw-eye-off{width:18px !important;height:18px !important}
/* Hide eye icon via class - reliable regardless of other CSS */
.vi-pw-hidden{display:none !important}

/* SUBMIT BUTTON */
.vi-submit{width:100% !important;padding:11px !important;background:var(--vi) !important;color:var(--vi-w) !important;border:none !important;border-radius:7px !important;font-size:.93rem !important;font-weight:600 !important;cursor:pointer !important;transition:background .2s !important;line-height:1.4 !important;letter-spacing:0 !important;text-transform:none !important;outline:none !important}
.vi-submit:hover{background:var(--vi-lt) !important}
.vi-submit:disabled{opacity:.6 !important;cursor:not-allowed !important}

/* DIVIDER */
.vi-auth-divider{display:flex !important;flex-direction:column !important;align-items:center !important;justify-content:center !important;padding:40px 0 !important}
.vi-auth-divider-line{flex:1 !important;width:1px !important;background:var(--vi-bdr) !important}
.vi-auth-divider span{padding:10px 0 !important;font-size:.75rem !important;color:var(--vi-txt2) !important;font-weight:600 !important;letter-spacing:.06em !important}

/* TABS - hidden desktop, shown mobile */
.vi-auth-tabs{display:none !important}
.vi-auth-tab{flex:1 !important;padding:13px !important;border:none !important;background:var(--vi-bg) !important;font-size:.9rem !important;font-weight:600 !important;color:var(--vi-txt2) !important;cursor:pointer !important;outline:none !important}
.vi-auth-tab--active{background:var(--vi-w) !important;color:var(--vi) !important;box-shadow:inset 0 -2px 0 var(--vi) !important}
.vi-switch-link{display:none !important;text-align:center !important;font-size:.83rem !important;color:var(--vi-txt2) !important;margin-top:16px !important}
.vi-switch-link a{color:var(--vi-acc) !important;text-decoration:none !important;font-weight:600 !important;outline:none !important}

/* CHECKBOX */
.vi-check{font-size:.82rem !important;color:var(--vi-txt2) !important;display:flex !important;align-items:center !important;gap:6px !important;cursor:pointer !important}
.vi-check input[type="checkbox"]{width:auto !important;height:auto !important;margin:0 !important;flex-shrink:0 !important}
/* Privacy checkbox - single flowing sentence */
.vi-check--privacy{align-items:flex-start !important;font-size:.8rem !important;line-height:1.45 !important;gap:8px !important}
.vi-check--privacy input{margin-top:3px !important}
.vi-check--privacy span{display:inline !important}
.vi-check--privacy span a{color:var(--vi-acc) !important;text-decoration:none !important}
.vi-link-sm{font-size:.82rem !important;color:var(--vi-acc) !important;text-decoration:none !important;outline:none !important}
.vi-link-sm:hover{text-decoration:underline !important}

/* MESSAGES */
.vi-message{padding:11px 15px !important;border-radius:7px !important;font-size:.87rem !important;line-height:1.5 !important;margin-bottom:6px !important}
.vi-message--success{background:#e8f5e9 !important;color:#2e7d32 !important;border:1px solid #a5d6a7 !important}
.vi-message--error{background:#ffebee !important;color:#c62828 !important;border:1px solid #ef9a9a !important}
.vi-notice{max-width:960px !important;margin:20px auto !important;padding:16px 24px !important;border-radius:var(--vi-r) !important;font-size:.9rem !important;line-height:1.5 !important}
.vi-notice a{font-weight:600 !important}
.vi-notice--info{background:#e3f2fd !important;color:#1565c0 !important;border:1px solid #90caf9 !important}
.vi-notice--warning{background:#fff3e0 !important;color:#e65100 !important;border:1px solid #ffcc80 !important}
.vi-notice--compact{margin-bottom:24px !important}

/* HEADER BUTTONS */
.vi-auth-buttons{display:inline-flex !important;align-items:center !important;gap:8px !important}
.vi-header-btn{display:inline-flex !important;align-items:center !important;justify-content:center !important;padding:10px 22px !important;font-size:.87rem !important;font-weight:600 !important;border-radius:6px !important;text-decoration:none !important;transition:all .2s !important;line-height:1.4 !important;white-space:nowrap !important;outline:none !important}
.vi-header-btn--login{background:var(--vi) !important;color:#fff !important;border:2px solid var(--vi) !important}
.vi-header-btn--login:hover{background:var(--vi-lt) !important;border-color:var(--vi-lt) !important;color:#fff !important}
.vi-header-btn--dash{background:var(--vi) !important;color:#fff !important;border:2px solid var(--vi) !important}
.vi-header-btn--dash:hover{background:var(--vi-lt) !important;border-color:var(--vi-lt) !important;color:#fff !important}
.vi-header-btn--logout{background:transparent !important;color:var(--vi) !important;border:2px solid var(--vi) !important;padding:10px 14px !important;font-size:.82rem !important}
.vi-header-btn--logout:hover{background:var(--vi) !important;color:#fff !important}

/* GENERAL BUTTONS */
.vi-btn{display:inline-flex !important;align-items:center !important;justify-content:center !important;padding:11px 26px !important;font-size:.93rem !important;font-weight:600 !important;border-radius:7px !important;border:2px solid transparent !important;cursor:pointer !important;text-decoration:none !important;transition:all .2s !important;line-height:1.4 !important;outline:none !important}
.vi-btn--primary{background:var(--vi) !important;color:var(--vi-w) !important;border-color:var(--vi) !important}
.vi-btn--primary:hover{background:var(--vi-lt) !important;border-color:var(--vi-lt) !important;color:var(--vi-w) !important}
.vi-btn--outline{background:transparent !important;color:var(--vi) !important;border-color:var(--vi) !important}
.vi-btn--outline:hover{background:var(--vi) !important;color:var(--vi-w) !important}
.vi-btn--ghost{background:transparent !important;color:var(--vi-txt2) !important;border-color:transparent !important;padding:8px 14px !important}
.vi-btn--ghost:hover{color:var(--vi) !important;background:var(--vi-bg) !important}
.vi-btn--sm{padding:8px 18px !important;font-size:.84rem !important}
.vi-btn--full{width:100% !important}
.vi-btn:disabled,.vi-btn--loading{opacity:.65 !important;cursor:not-allowed !important}
.vi-mt-24{margin-top:24px !important}

/* FORMS (profile) */
.vi-form-wrap{max-width:640px !important;margin:60px auto !important;padding:48px 44px !important;background:var(--vi-w) !important;border-radius:var(--vi-r) !important;box-shadow:var(--vi-sh) !important}
.vi-form-title{font-size:1.45rem !important;font-weight:700 !important;color:var(--vi) !important;margin:0 0 8px !important}
.vi-form-topbar{display:flex !important;justify-content:space-between !important;align-items:center !important;margin-bottom:24px !important;flex-wrap:wrap !important;gap:12px !important}
.vi-section-label{font-size:.95rem !important;font-weight:700 !important;color:var(--vi) !important;margin:0 0 2px !important}
.vi-form{display:flex !important;flex-direction:column !important;gap:18px !important}
.vi-field{display:flex !important;flex-direction:column !important;gap:5px !important}
.vi-field label{font-size:.85rem !important;font-weight:600 !important;color:var(--vi-txt) !important}
.vi-field input[type="text"],.vi-field input[type="email"],.vi-field input[type="password"],.vi-field select{width:100% !important;padding:10px 13px !important;font-size:.93rem !important;border:1.5px solid var(--vi-bdr) !important;border-radius:7px !important;background:var(--vi-w) !important;color:var(--vi-txt) !important;box-sizing:border-box !important}
.vi-form-row--half{display:grid !important;grid-template-columns:1fr 1fr !important;gap:14px !important}
.vi-divider{border:none !important;border-top:1px solid var(--vi-bdr) !important;margin:8px 0 !important}

/* DASHBOARD - break out of theme container */
.vi-dashboard{width:100vw !important;max-width:100vw !important;margin-left:calc(-50vw + 50%) !important;padding:48px 24px !important;box-sizing:border-box !important;display:flex !important;flex-direction:column !important;align-items:center !important}
.vi-dashboard>.vi-notice{width:100% !important;max-width:960px !important}
.vi-dash-header{width:100% !important;max-width:960px !important;display:flex !important;justify-content:space-between !important;align-items:flex-start !important;flex-wrap:wrap !important;gap:16px !important;margin-bottom:36px !important;padding-bottom:28px !important;border-bottom:1px solid var(--vi-bdr) !important}
.vi-dash-welcome h2{font-size:1.5rem !important;color:var(--vi) !important;margin:0 0 6px !important}
.vi-dash-meta{font-size:.9rem !important;color:var(--vi-txt2) !important;margin:0 !important}
.vi-dash-actions{display:flex !important;gap:8px !important;flex-wrap:wrap !important}
.vi-dash-grid{width:100% !important;max-width:960px !important;display:grid !important;grid-template-columns:repeat(3,1fr) !important;gap:24px !important}
.vi-dash-card{background:var(--vi-w) !important;border-radius:var(--vi-r) !important;box-shadow:var(--vi-sh) !important;padding:32px 28px !important;display:flex !important;flex-direction:column !important;gap:12px !important;transition:box-shadow .2s,transform .2s !important}
.vi-dash-card:hover{box-shadow:var(--vi-sh2) !important;transform:translateY(-2px) !important}
.vi-dash-card__header{display:flex !important;align-items:center !important;gap:12px !important}
.vi-dash-card__icon{font-size:1.8rem !important;line-height:1 !important}
.vi-dash-card__header h3{font-size:1.05rem !important;color:var(--vi) !important;margin:0 !important}
.vi-dash-card p{font-size:.88rem !important;color:var(--vi-txt2) !important;line-height:1.55 !important;margin:0 !important;flex-grow:1 !important}
.vi-dash-card__actions{display:flex !important;gap:8px !important;flex-wrap:wrap !important;margin-top:4px !important}

/* PLACEHOLDER */
.vi-placeholder-page{max-width:640px !important;margin:60px auto !important;padding:48px 44px !important;background:var(--vi-w) !important;border-radius:var(--vi-r) !important;box-shadow:var(--vi-sh) !important;text-align:center !important}
.vi-placeholder-icon{font-size:3rem !important;margin-bottom:16px !important}
.vi-placeholder-page h2{font-size:1.5rem !important;color:var(--vi) !important;margin:0 0 12px !important}
.vi-placeholder-page>p{color:var(--vi-txt2) !important;line-height:1.6 !important;margin:0 0 24px !important}
.vi-placeholder-actions{display:flex !important;gap:12px !important;justify-content:center !important;margin-bottom:8px !important}

/* ASSESSMENT */
.vi-assess-form-wrap{max-width:760px !important;margin:48px auto !important;padding:0 24px !important}
.vi-assess-header{text-align:center !important;margin-bottom:32px !important}
.vi-assess-header h2{font-size:1.6rem !important;color:var(--vi) !important;margin:0 0 8px !important}
.vi-assess-header p{color:var(--vi-txt2) !important;font-size:.92rem !important;line-height:1.5 !important;margin:0 !important}
.vi-assess-progress{height:6px !important;background:#e8e8e8 !important;border-radius:3px !important;overflow:hidden !important;margin-bottom:8px !important}
.vi-assess-progress__bar{height:100% !important;background:var(--vi-acc) !important;border-radius:3px !important;transition:width .4s ease !important}
.vi-assess-progress__label{text-align:center !important;font-size:.82rem !important;color:var(--vi-txt2) !important;margin-bottom:28px !important}
.vi-assess-pillar{background:var(--vi-w) !important;border-radius:var(--vi-r) !important;box-shadow:var(--vi-sh) !important;padding:36px 32px !important;margin-bottom:20px !important}
.vi-assess-pillar__header{display:flex !important;gap:16px !important;align-items:flex-start !important;margin-bottom:28px !important;padding-bottom:20px !important;border-bottom:1px solid var(--vi-bdr) !important}
.vi-assess-pillar__num{background:var(--vi) !important;color:#fff !important;font-size:.85rem !important;font-weight:700 !important;width:36px !important;height:36px !important;border-radius:50% !important;display:flex !important;align-items:center !important;justify-content:center !important;flex-shrink:0 !important}
.vi-assess-pillar__header h3{font-size:1.15rem !important;color:var(--vi) !important;margin:0 0 4px !important}
.vi-assess-pillar__header p{font-size:.88rem !important;color:var(--vi-txt2) !important;margin:0 !important;line-height:1.5 !important}
.vi-assess-stmt{margin-bottom:24px !important;padding-bottom:24px !important;border-bottom:1px solid #f0f0f0 !important}
.vi-assess-stmt:last-child{border-bottom:none !important;margin-bottom:0 !important;padding-bottom:0 !important}
.vi-assess-stmt__text{font-size:.93rem !important;color:var(--vi-txt) !important;line-height:1.55 !important;margin:0 0 14px !important}
.vi-assess-rating{display:flex !important;flex-wrap:wrap !important;gap:10px !important;align-items:center !important}
.vi-assess-rating__option{cursor:pointer !important;display:flex !important;align-items:center !important}
.vi-assess-rating__option input{position:absolute !important;opacity:0 !important;pointer-events:none !important}
.vi-assess-rating__circle{width:44px !important;height:44px !important;border-radius:50% !important;border:2px solid var(--vi-bdr) !important;display:flex !important;align-items:center !important;justify-content:center !important;font-size:.9rem !important;font-weight:600 !important;color:var(--vi-txt2) !important;transition:all .15s !important;background:var(--vi-w) !important}
.vi-assess-rating__option input:checked+.vi-assess-rating__circle{background:var(--vi) !important;color:#fff !important;border-color:var(--vi) !important}
.vi-assess-rating__option:hover .vi-assess-rating__circle{border-color:var(--vi) !important;color:var(--vi) !important}
.vi-assess-rating__labels{display:flex !important;justify-content:space-between !important;width:100% !important;font-size:.75rem !important;color:var(--vi-txt2) !important;margin-top:4px !important;padding:0 4px !important}
.vi-assess-nav{display:flex !important;justify-content:space-between !important;align-items:center !important;gap:12px !important;margin-top:8px !important}
.vi-assess-nav__spacer{flex-grow:1 !important}
.vi-assess-results{max-width:800px !important;margin:48px auto !important;padding:0 24px !important}
.vi-assess-chart-wrap{max-width:480px !important;margin:0 auto 40px !important;padding:20px !important;background:var(--vi-w) !important;border-radius:var(--vi-r) !important;box-shadow:var(--vi-sh) !important}
.vi-assess-scores{display:flex !important;flex-direction:column !important;gap:16px !important;margin-bottom:24px !important}
.vi-assess-score-row{display:grid !important;grid-template-columns:240px 1fr 60px !important;gap:12px !important;align-items:center !important}
.vi-assess-score-row__label{font-size:.88rem !important;color:var(--vi-txt) !important;display:flex !important;align-items:center !important;gap:8px !important}
.vi-assess-score-row__num{background:var(--vi-bg) !important;color:var(--vi) !important;font-size:.75rem !important;font-weight:700 !important;width:28px !important;height:28px !important;border-radius:50% !important;display:flex !important;align-items:center !important;justify-content:center !important;flex-shrink:0 !important}
.vi-assess-score-row__bar{height:12px !important;background:#e8e8e8 !important;border-radius:6px !important;overflow:hidden !important}
.vi-assess-score-row__fill{height:100% !important;border-radius:6px !important;transition:width .6s !important}
.vi-assess-score-row__fill--low{background:#ef5350 !important}
.vi-assess-score-row__fill--mid{background:#ffa726 !important}
.vi-assess-score-row__fill--high{background:#66bb6a !important}
.vi-assess-score-row__value{font-size:.88rem !important;font-weight:600 !important;color:var(--vi-txt) !important;text-align:right !important}
.vi-assess-date{text-align:center !important;font-size:.85rem !important;color:var(--vi-txt2) !important;margin-bottom:24px !important}
.vi-assess-result-actions{display:flex !important;gap:12px !important;justify-content:center !important}

/* FORGOT / RESET PASSWORD (uses vi-form-wrap base styles) */
.vi-forgot-wrap{max-width:480px !important}
.vi-form-back{text-align:center !important;margin-top:20px !important;font-size:.85rem !important}

/* LANGUAGE SWITCHER - minimal text style, not a button */
.vi-lang-dd{position:relative !important;display:inline-flex !important;align-items:center !important}
.vi-lang-dd__toggle{display:inline-flex !important;align-items:center !important;gap:6px !important;padding:0 !important;background:none !important;border:none !important;cursor:pointer !important;font-size:.85rem !important;font-weight:600 !important;color:var(--vi-txt) !important;line-height:1 !important;white-space:nowrap !important;transition:color .2s !important;font-family:inherit !important}
.vi-lang-dd__toggle:hover{color:var(--vi) !important}
.vi-lang-dd--open .vi-lang-dd__toggle{color:var(--vi) !important}
.vi-lang-dd__code{letter-spacing:.03em !important}
.vi-lang-dd__arrow{transition:transform .2s !important;color:var(--vi-txt2) !important;flex-shrink:0 !important;opacity:.6 !important}
.vi-lang-dd__toggle:hover .vi-lang-dd__arrow{opacity:1 !important;color:var(--vi) !important}
.vi-lang-dd--open .vi-lang-dd__arrow{transform:rotate(180deg) !important;opacity:1 !important;color:var(--vi) !important}
.vi-lang-dd__menu{display:none !important;position:absolute !important;top:calc(100% + 10px) !important;right:0 !important;min-width:170px !important;background:var(--vi-w) !important;border:1px solid rgba(0,0,0,.08) !important;border-radius:8px !important;box-shadow:0 4px 16px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.04) !important;z-index:9999 !important;overflow:hidden !important;padding:4px 0 !important}
.vi-lang-dd--open .vi-lang-dd__menu{display:block !important}
.vi-lang-dd__item{display:flex !important;align-items:center !important;gap:10px !important;padding:8px 14px !important;text-decoration:none !important;color:var(--vi-txt) !important;font-size:.83rem !important;font-weight:500 !important;transition:background .12s !important;cursor:pointer !important;outline:none !important}
.vi-lang-dd__item:hover,.vi-lang-dd__item:focus-visible{background:var(--vi-bg) !important}
.vi-lang-dd__item--active{color:var(--vi) !important;font-weight:600 !important}
.vi-lang-dd__item--active .vi-lang-dd__label::after{content:'' !important;display:inline-block !important;width:5px !important;height:5px !important;border-radius:50% !important;background:var(--vi-acc) !important;margin-left:6px !important;vertical-align:middle !important}
.vi-lang-dd__label{flex:1 !important;white-space:nowrap !important}
.vi-lang-dd__item .vi-lang-dd__code{font-size:.7rem !important;color:var(--vi-txt2) !important;font-weight:600 !important;letter-spacing:.05em !important;margin-left:auto !important}

/* RESPONSIVE */
@media(max-width:860px){
    .vi-auth-card{grid-template-columns:1fr !important}
    .vi-auth-divider{display:none !important}
    .vi-auth-tabs{display:flex !important}
    .vi-auth-col--register{display:none !important}
    .vi-auth-col{padding:28px 24px !important}
    .vi-switch-link{display:block !important}
}
@media(max-width:768px){
    .vi-dash-grid{grid-template-columns:1fr !important}
    .vi-assess-score-row{grid-template-columns:1fr !important;gap:4px !important}
    .vi-assess-score-row__bar{margin-left:36px !important}
    .vi-assess-score-row__value{margin-left:36px !important;text-align:left !important}
}
@media(max-width:560px){
    .vi-form-wrap{margin:20px 16px !important;padding:28px 22px !important}
    .vi-form-row--half{grid-template-columns:1fr !important}
    .vi-auth-form .vi-f-half{grid-template-columns:1fr !important}
    .vi-auth-col{padding:22px 18px !important}
    .vi-assess-form-wrap,.vi-assess-results{padding:0 16px !important}
    .vi-assess-pillar{padding:24px 20px !important}
    .vi-assess-rating__circle{width:38px !important;height:38px !important;font-size:.82rem !important}
    .vi-header-btn{padding:8px 16px !important;font-size:.82rem !important}
    .vi-lang-dd__toggle{font-size:.8rem !important}
}

/* DISABLED BUTTON STATE */
.vi-btn--disabled{opacity:.5 !important;cursor:default !important;pointer-events:none !important}

/* SELF-ASSESSMENT LOGIN GATE */
.vi-assess-login{max-width:800px !important;margin:48px auto !important;padding:0 24px !important}
.vi-assess-login-card{background:var(--vi-w) !important;border-radius:var(--vi-r) !important;box-shadow:var(--vi-sh) !important;padding:48px 40px !important;text-align:center !important;margin-bottom:32px !important}
.vi-assess-lock-icon{color:var(--vi) !important;margin-bottom:16px !important}
.vi-assess-login-card h2{font-size:1.35rem !important;color:var(--vi) !important;margin:0 0 10px !important}
.vi-assess-login-card p{font-size:.9rem !important;color:var(--vi-txt2) !important;line-height:1.55 !important;margin:0 0 24px !important;max-width:480px !important;margin-left:auto !important;margin-right:auto !important}
.vi-assess-gate-pillars{background:var(--vi-w) !important;border-radius:var(--vi-r) !important;box-shadow:var(--vi-sh) !important;padding:36px 32px !important}
.vi-assess-gate-pillars h3{font-size:1.05rem !important;color:var(--vi) !important;margin:0 0 20px !important;text-align:center !important}
.vi-assess-gate-grid{display:grid !important;grid-template-columns:1fr 1fr !important;gap:12px !important;margin-bottom:20px !important}
.vi-assess-gate-pillar{display:flex !important;align-items:flex-start !important;gap:12px !important;padding:14px 16px !important;border-radius:8px !important;background:var(--vi-bg) !important;transition:background .15s !important}
.vi-assess-gate-pillar:hover{background:#eaf0f7 !important}
.vi-assess-gate-num{background:var(--vi) !important;color:#fff !important;font-size:.75rem !important;font-weight:700 !important;width:28px !important;height:28px !important;border-radius:50% !important;display:flex !important;align-items:center !important;justify-content:center !important;flex-shrink:0 !important}
.vi-assess-gate-info{display:flex !important;flex-direction:column !important;gap:2px !important}
.vi-assess-gate-info strong{font-size:.88rem !important;color:var(--vi) !important}
.vi-assess-gate-info span{font-size:.78rem !important;color:var(--vi-txt2) !important;line-height:1.4 !important}
.vi-assess-gate-meta{text-align:center !important;font-size:.82rem !important;color:var(--vi-txt2) !important;margin:0 !important}
@media(max-width:560px){
    .vi-assess-gate-grid{grid-template-columns:1fr !important}
    .vi-assess-login-card{padding:32px 22px !important}
    .vi-assess-gate-pillars{padding:24px 18px !important}
}

/* NAV - shrink menu font + gap so all 6 items fit single line */
nav.elementor-nav-menu__container .elementor-nav-menu .elementor-item{font-size:13px !important;padding-left:10px !important;padding-right:10px !important}

/* ASSESSMENT PILLAR ICONS in score breakdown */
.vi-assess-pillar-icon{display:inline-flex !important;align-items:center !important;justify-content:center !important;width:28px !important;height:28px !important;flex-shrink:0 !important;color:var(--vi) !important}
.vi-assess-pillar-icon .material-symbols-outlined{text-shadow:none !important;box-shadow:none !important}
.vi-assess-pillar-row{display:flex !important;align-items:center !important;gap:10px !important;padding:10px 0 !important;border-bottom:1px solid #f0f0f0 !important}
.vi-assess-pillar-row:last-child{border-bottom:none !important}
.vi-assess-pillar-label{flex:0 0 180px !important;font-size:.88rem !important;color:var(--vi-txt) !important}
.vi-assess-bar-track{flex:1 !important;height:12px !important;background:#e8e8e8 !important;border-radius:6px !important;overflow:hidden !important}
.vi-assess-bar-fill{height:100% !important;border-radius:6px !important;background:var(--vi) !important}
.vi-assess-pillar-score{flex:0 0 40px !important;text-align:right !important;font-weight:600 !important;font-size:.88rem !important}

/* CONSORTIUM LOGO GRID LINKS */
a.ha-logo-grid-link{text-decoration:none !important;transition:opacity .15s !important}
a.ha-logo-grid-link:hover{opacity:.75 !important}

/* ============================================
   SITE-WIDE QA FIXES (2026-04-03)
   ============================================ */

/* --- Horizontal overflow fix (logo marquee) --- */
html,body{overflow-x:hidden !important}
.elementor-widget-ha-logo-grid,.ha-logo-grid-wrapper{overflow:hidden !important}

/* --- Global focus-visible for Elementor elements --- */
a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
[tabindex]:focus-visible,
.elementor-item:focus-visible,
.elementor-button:focus-visible{
    outline:2px solid #005F83 !important;
    outline-offset:2px !important
}

/* --- Skip link visible on focus --- */
a[href="#content"]:focus{
    position:fixed !important;top:8px !important;left:8px !important;z-index:100000 !important;
    background:#013A4F !important;color:#fff !important;padding:12px 24px !important;
    border-radius:8px !important;font-size:14px !important;font-weight:600 !important;
    width:auto !important;height:auto !important;clip:auto !important
}

/* --- News card headings — force brand color (was #005F83 on homepage, magenta on /news/) --- */
.elementor-posts .elementor-post__title,
.elementor-posts .elementor-post__title a,
.elementor-widget-posts .elementor-post__title a,
article .entry-title a,
.hentry .entry-title a{
    color:#2A2A2A !important
}
.elementor-posts .elementor-post__title a:hover,
article .entry-title a:hover{
    color:#013A4F !important
}

/* --- News "Read More" links — brand primary --- */
.elementor-post__read-more{
    color:#013A4F !important;
    font-weight:600 !important
}
.elementor-post__read-more:hover{
    color:#005F83 !important
}

/* --- Touch targets: language button + login --- */
.trp-language-switcher button,
.vi-lang-btn,
button[class*="trp"]{
    min-width:44px !important;
    min-height:44px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important
}

/* --- Page transition: reduce from 1500ms to 300ms, brand color --- */
.elementor-kit-2763{
    --e-page-transition-animation-duration:300ms !important
}
.elementor-kit-2763 e-page-transition{
    background-color:#013A4F !important
}

/* ============================================
   FOOTER (template: elementor-2836)
   ============================================ */

/* Force ALL footer text to white */
.elementor-2836,
.elementor-2836 *{
    color:#fff !important;
    fill:#fff !important
}

/* Footer outer container — padding, border-top */
.elementor-2836 .elementor-element.elementor-element-c309e30{
    padding:48px 24px 32px !important
}

/* Remove 120px top margin on EU-flag row */
.elementor-2836 .elementor-element.elementor-element-b1aa702{
    --margin-top:0px !important;
    margin-top:0 !important
}

/* EU flag image — invert to white version for dark background */
.elementor-2836 .elementor-element.elementor-element-90ad823 img{
    filter:brightness(0) invert(1) !important;
    opacity:.9 !important;
    max-height:56px !important;
    width:auto !important
}

/* EU disclaimer text — 13px readable */
.elementor-2836 .elementor-element.elementor-element-2397825,
.elementor-2836 .elementor-element.elementor-element-2397825 p{
    font-size:13px !important;
    line-height:1.55 !important;
    color:rgba(255,255,255,.85) !important
}
.elementor-2836 .elementor-element.elementor-element-2397825 strong{
    color:#fff !important
}

/* Footer nav — remove 120px bottom margin, add separator */
.elementor-2836 .elementor-element.elementor-element-eee3994 > .elementor-widget-container{
    margin:32px 0 0 !important;
    padding:24px 0 0 !important;
    border-top:1px solid rgba(255,255,255,.15) !important
}

/* Footer nav links — white at 0.9 */
.elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-nav-menu--main .elementor-item{
    color:rgba(255,255,255,.9) !important;
    fill:rgba(255,255,255,.9) !important;
    font-size:13px !important;
    transition:color .2s ease !important
}
.elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-nav-menu--main .elementor-item:hover,
.elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-nav-menu--main .elementor-item.elementor-item-active,
.elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-nav-menu--main .elementor-item:focus{
    color:#fff !important;
    fill:#fff !important
}

/* Underline pointer — white */
.elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-nav-menu--main:not(.e--pointer-framed) .elementor-item:before,
.elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-nav-menu--main:not(.e--pointer-framed) .elementor-item:after{
    background-color:rgba(255,255,255,.6) !important
}

/* Footer nav dividers */
.elementor-2836 .elementor-element.elementor-element-eee3994{
    --e-nav-menu-divider-color:rgba(255,255,255,.3) !important
}

/* Always show inline nav, hide hamburger */
.elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-nav-menu--main{display:flex !important}
.elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-menu-toggle{display:none !important}
.elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-nav-menu--dropdown{display:none !important}

/* Mobile footer */
@media(max-width:768px){
    .elementor-2836 .elementor-element.elementor-element-c309e30{
        padding:32px 16px 24px !important
    }
    .elementor-2836 .elementor-element.elementor-element-b1aa702{
        flex-direction:column !important
    }
    .elementor-2836 .elementor-element.elementor-element-23fec9b{
        width:100% !important;--width:100% !important;margin-bottom:16px !important
    }
    .elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-nav-menu{
        flex-wrap:wrap !important;justify-content:center !important;gap:4px 0 !important
    }
    .elementor-2836 .elementor-element.elementor-element-eee3994 .elementor-item{
        font-size:12px !important;padding:8px !important
    }
    .elementor-2836 .elementor-element.elementor-element-eee3994 > .elementor-widget-container{
        padding:16px 0 0 !important;margin-top:20px !important
    }
}

/* REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
    .vi-dash-card{transition:none !important}
    .vi-dash-card:hover{transform:none !important}
    .vi-assess-progress__bar,.vi-assess-score-row__fill{transition:none !important}
    .vi-lang-dd__arrow,.vi-lang-dd__toggle{transition:none !important}
    .vi-assess-gate-pillar{transition:none !important}
}
