/* Virii8 OS Login v1.9.7 - login screens only; no OS desktop shell elements. */
html, body.login {
  min-height: 100%;
  overflow-x: hidden;
}
body.login.virii8-os-login-enabled {
  margin: 0;
  min-height: 100vh;
  background: #10141f;
  color: #fff;
  font-family: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, Roboto, Arial, sans-serif;
}
#virii8-login-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(circle at 25% 20%, rgba(80, 140, 255, .42), transparent 38%),
    radial-gradient(circle at 80% 75%, rgba(0, 95, 160, .48), transparent 44%),
    linear-gradient(135deg, #0b1222, #18294a 52%, #0a0e18);
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
  transition: background-image .35s ease, filter .35s ease;
}
#virii8-login-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.23);
}
#virii8-login-shell {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}
body.login #login {
  position: relative;
  z-index: 5;
  width: min(390px, calc(100vw - 36px));
  padding: 0;
  margin: 0 auto;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  pointer-events: auto;
}
body.login #login h1,
body.login #login h1 a {
  width: 108px;
  height: 108px;
  margin: 0 auto 18px;
  background-size: cover !important;
  background-position: center !important;
  border-radius: 999px;
  box-shadow: 0 14px 44px rgba(0,0,0,.42);
  overflow: hidden;
}
body.login #login h1 a { display: block; text-indent: -9999px; }
body.login #loginform,
body.login #lostpasswordform,
body.login #registerform {
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  color: #fff;
}
body.login label {
  color: rgba(255,255,255,.93);
  font-size: 13px;
  letter-spacing: .01em;
}
body.login .input,
body.login input[type="text"],
body.login input[type="password"],
body.login input[type="email"] {
  min-height: 42px;
  border: 1px solid rgba(255,255,255,.35);
  border-radius: 4px;
  background: rgba(255,255,255,.84);
  color: #161616;
  box-shadow: none;
  outline: none;
  font-size: 16px;
  padding: 9px 12px;
}
body.login .input:focus { border-color: rgba(255,255,255,.82); box-shadow: 0 0 0 2px rgba(255,255,255,.22); }
body.login .button.wp-hide-pw { color: #111; }
body.login .forgetmenot label { color: rgba(255,255,255,.9); }
body.login .submit .button-primary {
  min-height: 40px;
  padding: 0 18px;
  border: 0;
  border-radius: 4px;
  background: var(--v8-win-accent);
  color: #fff;
  text-shadow: none;
  box-shadow: none;
  transition: transform .12s ease, filter .12s ease;
}
body.login .submit .button-primary:hover { filter: brightness(1.08); transform: translateY(-1px); }
body.login #nav,
body.login #backtoblog,
body.login .privacy-policy-page-link {
  position: relative;
  z-index: 6;
  text-align: center;
  color: rgba(255,255,255,.82);
  text-shadow: 0 1px 2px rgba(0,0,0,.5);
}
body.login #nav a,
body.login #backtoblog a,
body.login .privacy-policy-page-link a { color: rgba(255,255,255,.92) !important; text-decoration: none; }
.login .message,
.login .notice,
.login #login_error {
  background: rgba(18,18,18,.62);
  backdrop-filter: blur(var(--v8-blur));
  color: #fff;
  border-left-color: var(--v8-win-accent);
  box-shadow: 0 10px 34px rgba(0,0,0,.28);
}
.v8-lock-date {
  position: absolute;
  left: 32px;
  bottom: 42px;
  display: flex;
  flex-direction: column;
  text-shadow: 0 2px 10px rgba(0,0,0,.45);
}
#v8-time { font-size: clamp(42px, 6vw, 76px); line-height: .95; font-weight: 300; letter-spacing: -.04em; }
#v8-date { font-size: 18px; opacity: .9; margin-top: 8px; }
.v8-login-avatar,.v8-login-title,.v8-login-subtitle { display: none; }
.v8-theme-switch,
.v8-customize-open {
  pointer-events: auto;
  position: fixed;
  z-index: 20;
}
.v8-theme-switch {
  right: 18px;
  bottom: 18px;
  display: flex;
  gap: 6px;
  padding: 6px;
  background: rgba(0,0,0,.25);
  backdrop-filter: blur(var(--v8-blur));
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
}
.v8-theme-switch button,
.v8-customize-open {
  cursor: pointer;
  border: 1px solid rgba(255,255,255,.24);
  color: #fff;
  background: rgba(255,255,255,.13);
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
}
.v8-theme-switch button.is-active { background: rgba(255,255,255,.34); }
.v8-theme-switch button,
.v8-customize-open,
.v8-customizer-panel button {
  touch-action: manipulation;
  -webkit-tap-highlight-color: rgba(255,255,255,.18);
  -webkit-user-select: none;
  user-select: none;
}
.v8-customize-open { right: 18px; top: 18px; }
.v8-bottom-actions { display: none; }
.v8-customizer {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(12px);
}
.v8-customizer-panel {
  position: absolute;
  right: 18px;
  top: 62px;
  width: min(360px, calc(100vw - 36px));
  box-sizing: border-box;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 18px;
  background: rgba(20,20,24,.86);
  color: #fff;
  box-shadow: 0 24px 70px rgba(0,0,0,.45);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}
.v8-customizer-panel h2 { margin: 0 36px 16px 0; font-size: 20px; color: #fff; }
.v8-customizer-panel label { display: block; margin: 10px 0; color: #fff; }
.v8-customizer-panel input,.v8-customizer-panel select { width: 100%; box-sizing: border-box; min-height: 38px; border-radius: 10px; border: 1px solid rgba(255,255,255,.24); background: rgba(255,255,255,.1); color: #fff; padding: 7px 10px; }
.v8-customizer-panel select option { color: #111; }
.v8-close { position: absolute; right: 14px; top: 12px; border: 0; background: transparent; color: #fff; font-size: 28px; cursor: pointer; }
.v8-customizer-actions { display: flex; gap: 8px; margin-top: 14px; }
.v8-note { font-size: 12px; opacity: .75; margin-bottom: 0; }
/* Windows login: blurred wallpaper + centered user/password, no desktop shell. */
body.v8-effective-windows #virii8-login-bg { filter: blur(2px) saturate(1.05); }
body.v8-effective-windows #login { transform: translateY(-18px); }
body.v8-effective-windows #loginform,
body.v8-effective-windows #lostpasswordform,
body.v8-effective-windows #registerform {
  text-align: left;
}
body.v8-effective-windows.login #login h1 + form::before {
  content: attr(data-v8-title);
  display: block;
  text-align: center;
  color: #fff;
  font-size: 28px;
  font-weight: 400;
  margin: 0 0 16px;
  text-shadow: 0 2px 12px rgba(0,0,0,.45);
}
body.v8-effective-windows.login #loginform p:not(.forgetmenot),
body.v8-effective-windows.login #lostpasswordform p,
body.v8-effective-windows.login #registerform p {
  margin-bottom: 10px;
}
body.v8-effective-windows.login .submit { text-align: right; }
body.v8-effective-windows .v8-bottom-actions {
  display: flex;
  pointer-events: none;
  position: fixed;
  right: 28px;
  bottom: 28px;
  gap: 18px;
  color: rgba(255,255,255,.78);
  font-size: 13px;
  text-shadow: 0 1px 4px rgba(0,0,0,.5);
}
/* macOS login: central avatar, password pill, bottom power actions. */
body.v8-effective-macos { font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Helvetica Neue", Arial, sans-serif; }
body.v8-effective-macos #virii8-login-bg {
  background:
    radial-gradient(circle at 15% 18%, rgba(255, 174, 80, .48), transparent 30%),
    radial-gradient(circle at 84% 35%, rgba(120, 100, 255, .45), transparent 38%),
    linear-gradient(135deg, #231532, #442d62 48%, #101727);
  filter: blur(10px) saturate(1.18);
}
body.v8-effective-macos #login { width: min(330px, calc(100vw - 36px)); transform: translateY(-12px); }
body.v8-effective-macos.login #login h1,
body.v8-effective-macos.login #login h1 a {
  width: 132px;
  height: 132px;
  margin-bottom: 16px;
  border-radius: 999px;
  box-shadow: 0 16px 50px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.2);
}
body.v8-effective-macos.login #login h1 + form::before {
  content: attr(data-v8-title);
  display: block;
  text-align: center;
  color: #fff;
  font-size: 22px;
  font-weight: 600;
  margin: 0 0 18px;
  text-shadow: 0 2px 12px rgba(0,0,0,.38);
}
body.v8-effective-macos.login label[for="user_login"],
body.v8-effective-macos.login label[for="user_pass"] { font-size: 0; }
body.v8-effective-macos.login input.input {
  border-radius: 999px;
  height: 44px;
  background: rgba(255,255,255,.22);
  border-color: rgba(255,255,255,.35);
  color: #fff;
  text-align: center;
  backdrop-filter: blur(var(--v8-blur));
}
body.v8-effective-macos.login input.input::placeholder { color: rgba(255,255,255,.68); }
body.v8-effective-macos.login .submit { text-align: center; }
body.v8-effective-macos.login .submit .button-primary {
  border-radius: 999px;
  background: rgba(255,255,255,.22);
  border: 1px solid rgba(255,255,255,.35);
  color: #fff;
  padding: 0 24px;
}
body.v8-effective-macos .v8-lock-date { display: none; }
body.v8-effective-macos .v8-bottom-actions {
  display: flex;
  pointer-events: none;
  position: fixed;
  bottom: 34px;
  left: 50%;
  transform: translateX(-50%);
  gap: 28px;
  color: rgba(255,255,255,.72);
  font-size: 13px;
}
body.v8-effective-macos .v8-theme-switch,
body.v8-effective-macos .v8-customize-open { background: rgba(255,255,255,.13); }
/* Android mobile mapping for selected Windows theme. */
@media (max-width: 700px) {
  body.v8-effective-android {
    font-family: Roboto, system-ui, Arial, sans-serif;
    background: #111;
  }
  body.v8-effective-android #virii8-login-bg {
    background:
      radial-gradient(circle at 50% 15%, rgba(138,180,248,.42), transparent 34%),
      linear-gradient(180deg, #182032, #0b0f16 70%);
    filter: none;
  }
  body.v8-effective-android #virii8-login-bg::after { background: rgba(0,0,0,.18); }
  body.v8-effective-android #login {
    justify-content: flex-end;
    padding-bottom: 80px;
    width: min(380px, calc(100vw - 34px));
  }
  body.v8-effective-android.login #login h1,
  body.v8-effective-android.login #login h1 a {
    width: 84px;
    height: 84px;
    margin-bottom: 12px;
  }
  body.v8-effective-android.login #login h1 + form::before {
    content: attr(data-v8-title);
    display: block;
    text-align: center;
    font-size: 20px;
    margin: 0 0 18px;
  }
  body.v8-effective-android.login #loginform,
  body.v8-effective-android.login #lostpasswordform,
  body.v8-effective-android.login #registerform {
    padding: 20px;
    border-radius: 28px 28px 0 0;
    background: rgba(18,22,30,.78);
    backdrop-filter: blur(18px);
  }
  body.v8-effective-android.login .input { border-radius: 14px; background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.18); }
  body.v8-effective-android.login .submit .button-primary { border-radius: 999px; background: var(--v8-android-accent); color: #07111f; font-weight: 700; }
  body.v8-effective-android .v8-lock-date { top: 58px; bottom: auto; left: 24px; }
  body.v8-effective-android #v8-time { font-size: 54px; }
  body.v8-effective-android #v8-date { font-size: 15px; }
  body.v8-effective-android .v8-bottom-actions { display: none; }
  body.v8-effective-android .v8-theme-switch { left: 50%; right: auto; transform: translateX(-50%); bottom: 14px; }
  body.v8-effective-android .v8-customize-open { top: 14px; right: 14px; }
}
/* iOS mobile mapping for selected macOS theme. */
@media (max-width: 700px) {
  body.v8-effective-ios {
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", Arial, sans-serif;
  }
  body.v8-effective-ios #virii8-login-bg {
    background:
      radial-gradient(circle at 30% 20%, rgba(255,255,255,.25), transparent 16%),
      radial-gradient(circle at 70% 28%, rgba(120,180,255,.35), transparent 30%),
      linear-gradient(180deg, #233351, #08111e 75%);
    filter: none;
  }
  body.v8-effective-ios #login {
    justify-content: flex-end;
    padding-bottom: 86px;
    width: min(350px, calc(100vw - 36px));
  }
  body.v8-effective-ios.login #login h1,
  body.v8-effective-ios.login #login h1 a {
    width: 74px;
    height: 74px;
    margin-bottom: 12px;
    box-shadow: 0 12px 34px rgba(0,0,0,.34);
  }
  body.v8-effective-ios.login #login h1 + form::before {
    content: attr(data-v8-title);
    display: block;
    text-align: center;
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 18px;
  }
  body.v8-effective-ios.login #loginform,
  body.v8-effective-ios.login #lostpasswordform,
  body.v8-effective-ios.login #registerform {
    padding: 18px;
    border-radius: 26px;
    background: rgba(255,255,255,.13);
    backdrop-filter: blur(22px);
  }
  body.v8-effective-ios.login .input {
    border-radius: 999px;
    background: rgba(255,255,255,.18);
    border-color: rgba(255,255,255,.24);
    color: #fff;
    text-align: center;
  }
  body.v8-effective-ios.login .submit { text-align: center; }
  body.v8-effective-ios.login .submit .button-primary { background: var(--v8-ios-accent); border-radius: 999px; font-weight: 700; }
  body.v8-effective-ios .v8-lock-date {
    top: 46px;
    bottom: auto;
    left: 0;
    right: 0;
    align-items: center;
  }
  body.v8-effective-ios #v8-time { font-size: 72px; font-weight: 600; letter-spacing: -.06em; }
  body.v8-effective-ios #v8-date { font-size: 17px; order: -1; margin: 0 0 2px; }
  body.v8-effective-ios .v8-bottom-actions { display: none; }
  body.v8-effective-ios .v8-theme-switch { left: 50%; right: auto; transform: translateX(-50%); bottom: 14px; }
  body.v8-effective-ios .v8-customize-open { top: 14px; right: 14px; }
}
body.v8-logo-rounded.login #login h1, body.v8-logo-rounded.login #login h1 a { border-radius: 24px; }
body.v8-logo-square.login #login h1, body.v8-logo-square.login #login h1 a { border-radius: 4px; }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}
@media (max-width: 480px) {
  .v8-customizer-panel { left: 12px; right: 12px; top: 54px; width: auto; }
  body.login #nav, body.login #backtoblog { font-size: 12px; }
}

/* v1.8.0 controls: clock/provider permissions and Openverse/Picsum credits */
.v8-bg-credit {
  position: fixed;
  right: 18px;
  bottom: 16px;
  z-index: 3;
  max-width: min(420px, calc(100vw - 36px));
  color: rgba(255,255,255,.72);
  font-size: 11px;
  line-height: 1.3;
  text-align: right;
  text-shadow: 0 1px 8px rgba(0,0,0,.6);
  pointer-events: none;
}
@media (max-width: 700px) {
  .v8-bg-credit { left: 14px; right: 14px; bottom: 8px; text-align: center; font-size: 10px; }
}


/* v1.8.0 hardening/refinement overrides */
body.login.virii8-os-login-enabled { overflow: hidden; }
#virii8-login-shell { pointer-events: none; }
#virii8-login-shell .v8-customize-open,
#virii8-login-shell .v8-theme-switch,
#v8-customizer,
#v8-customizer * { pointer-events: auto; }
body.login #login form p { position: relative; }
body.login #login_error, .login .message, .login .notice { border-radius: 10px; }
body.v8-effective-windows #virii8-login-bg::after { background: rgba(0,0,0,.32); }
body.v8-effective-windows.login #login h1,
body.v8-effective-windows.login #login h1 a { width: 96px; height: 96px; }
body.v8-effective-windows.login #loginform,
body.v8-effective-windows.login #lostpasswordform,
body.v8-effective-windows.login #registerform { max-width: 360px; margin-inline: auto; }
body.v8-effective-windows.login .input { border-radius: 2px; background: rgba(255,255,255,.9); }
body.v8-effective-windows .v8-bottom-actions span { opacity: .82; }
body.v8-effective-macos #virii8-login-bg::after { background: rgba(0,0,0,.2); }
body.v8-effective-macos.login #loginform,
body.v8-effective-macos.login #lostpasswordform,
body.v8-effective-macos.login #registerform { max-width: 330px; margin-inline: auto; }
body.v8-effective-macos.login .forgetmenot { text-align: center; }
body.v8-effective-macos.login #nav,
body.v8-effective-macos.login #backtoblog { opacity: .9; }
.v8-customizer[hidden] { display: none !important; }
.v8-customizer-panel { max-height: calc(100vh - 84px); overflow: auto; }
.v8-customizer-panel input:focus,
.v8-customizer-panel select:focus,
.v8-customizer-panel button:focus,
.v8-theme-switch button:focus,
.v8-customize-open:focus { outline: 2px solid rgba(255,255,255,.78); outline-offset: 2px; }
body.v8-no-front-customization .v8-customize-open,
body.v8-no-theme-switch .v8-theme-switch,
body.v8-no-front-background .v8-bg-row,
body.v8-no-front-logo .v8-logo-row,
body.v8-no-front-clock .v8-clock-row,
body.v8-no-provider .v8-provider-row,
body.v8-no-provider .v8-openverse-row,
body.v8-no-provider #v8-random-bg,
body.v8-no-front-background #v8-random-bg { display: none !important; }
@media (max-height: 620px) {
  body.login #login { justify-content: flex-start; padding-top: 36px; }
  .v8-lock-date { display: none; }
  .v8-bottom-actions { display: none !important; }
}
@media (max-width: 700px) {
  body.login.virii8-os-login-enabled { overflow-y: auto; }
  body.v8-effective-android #login,
  body.v8-effective-ios #login { min-height: 100svh; }
  body.v8-effective-android .v8-theme-switch,
  body.v8-effective-ios .v8-theme-switch { max-width: calc(100vw - 28px); overflow: hidden; }
  body.v8-effective-android .v8-customize-open,
  body.v8-effective-ios .v8-customize-open { padding: 7px 10px; }
}


/* v1.8.9 mobile activation hardening: explicit modal state, high stacking context, and touch-safe controls. */
#v8-customizer { display: none; }
#v8-customizer.is-open { display: block; }
#v8-customizer[hidden] { display: none !important; }
#virii8-login-shell .v8-customize-open,
#virii8-login-shell .v8-theme-switch,
#virii8-login-shell .v8-theme-switch button {
  z-index: 100001;
  pointer-events: auto;
}
#v8-customizer { z-index: 100000; pointer-events: auto; }
#v8-customizer .v8-customizer-panel { pointer-events: auto; }

/* v1.8.0 typography scaling + NeoMatrix live-ready appearance mode */
body.login.virii8-os-login-enabled {
  font-size: calc(16px * var(--v8-font-scale, 1));
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body.login.virii8-os-login-enabled label,
body.login.virii8-os-login-enabled #nav,
body.login.virii8-os-login-enabled #backtoblog,
body.login.virii8-os-login-enabled .privacy-policy-page-link,
.v8-theme-switch button,
.v8-customize-open,
.v8-customizer-panel { font-size: calc(1em * var(--v8-font-scale, 1)); }
body.login.virii8-os-login-enabled .input,
body.login.virii8-os-login-enabled input[type="text"],
body.login.virii8-os-login-enabled input[type="password"],
body.login.virii8-os-login-enabled input[type="email"] {
  font-size: calc(16px * var(--v8-font-scale, 1));
}
.v8-text-row output {
  display: inline-block;
  min-width: 52px;
  margin-top: 6px;
  color: rgba(255,255,255,.82);
  font-variant-numeric: tabular-nums;
}
.v8-matrix-row {
  display: flex !important;
  align-items: center;
  gap: 8px;
}
.v8-matrix-row input[type="checkbox"] { width: auto; min-height: auto; }
.v8-matrix-rain {
  position: fixed;
  inset: 0;
  z-index: 1;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  opacity: 0;
  transition: opacity .25s ease;
}
body.v8-mode-neomatrix.v8-matrix-on .v8-matrix-rain { opacity: .6; }
body.v8-mode-neomatrix #virii8-login-bg {
  background:
    radial-gradient(circle at 50% 28%, rgba(0,255,102,.10), transparent 30%),
    linear-gradient(180deg, #020704, #000 74%, #031007);
  filter: none !important;
}
body.v8-mode-neomatrix #virii8-login-bg::after {
  background:
    linear-gradient(rgba(0,255,105,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,255,105,.028) 1px, transparent 1px),
    rgba(0,0,0,.52);
  background-size: 100% 4px, 4px 100%, auto;
}
body.v8-mode-neomatrix #virii8-login-shell,
body.v8-mode-neomatrix #login,
body.v8-mode-neomatrix #nav,
body.v8-mode-neomatrix #backtoblog,
body.v8-mode-neomatrix .privacy-policy-page-link { z-index: 6; }
body.v8-mode-neomatrix.login #login h1,
body.v8-mode-neomatrix.login #login h1 a {
  border-radius: 14px;
  background-color: rgba(0, 20, 8, .74) !important;
  box-shadow: 0 0 0 1px rgba(0,255,105,.48), 0 0 34px rgba(0,255,105,.22), inset 0 0 28px rgba(0,255,105,.08);
}
body.v8-mode-neomatrix.login #login h1 a:not([style*="url"]) {
  background-image: linear-gradient(135deg, rgba(0,255,105,.7), rgba(255,255,255,.9), rgba(0,120,55,.75)) !important;
}
body.v8-mode-neomatrix.login #login h1 + form::before,
body.v8-mode-neomatrix #v8-time {
  color: #00ff69 !important;
  text-shadow: 0 0 10px rgba(0,255,105,.55), 0 0 28px rgba(0,255,105,.22);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
}
body.v8-mode-neomatrix #v8-date,
body.v8-mode-neomatrix.login label,
body.v8-mode-neomatrix.login .forgetmenot label,
body.v8-mode-neomatrix.login #nav,
body.v8-mode-neomatrix.login #backtoblog,
body.v8-mode-neomatrix.login .privacy-policy-page-link,
body.v8-mode-neomatrix.login #nav a,
body.v8-mode-neomatrix.login #backtoblog a,
body.v8-mode-neomatrix.login .privacy-policy-page-link a {
  color: rgba(234,255,242,.94) !important;
  text-shadow: 0 0 10px rgba(0,255,105,.25);
}
body.v8-mode-neomatrix.login #loginform,
body.v8-mode-neomatrix.login #lostpasswordform,
body.v8-mode-neomatrix.login #registerform,
body.v8-mode-neomatrix .login .message,
body.v8-mode-neomatrix.login .notice,
body.v8-mode-neomatrix.login #login_error {
  background: rgba(0, 12, 5, .76) !important;
  border: 1px solid rgba(0,255,105,.34) !important;
  border-radius: 16px !important;
  box-shadow: 0 0 0 1px rgba(0,255,105,.09), 0 22px 70px rgba(0,0,0,.72), inset 0 0 28px rgba(0,255,105,.05) !important;
  backdrop-filter: blur(12px);
}
body.v8-mode-neomatrix.login .input,
body.v8-mode-neomatrix.login input[type="text"],
body.v8-mode-neomatrix.login input[type="password"],
body.v8-mode-neomatrix.login input[type="email"] {
  background: rgba(0,0,0,.82) !important;
  color: #f4fff7 !important;
  border: 1px solid rgba(0,255,105,.52) !important;
  border-radius: 10px !important;
  box-shadow: inset 0 0 18px rgba(0,255,105,.08), 0 0 16px rgba(0,255,105,.08) !important;
  caret-color: #00ff69;
}
body.v8-mode-neomatrix.login .input:focus {
  border-color: #b9ffd0 !important;
  box-shadow: inset 0 0 18px rgba(0,255,105,.12), 0 0 0 2px rgba(0,255,105,.22), 0 0 24px rgba(0,255,105,.18) !important;
}
body.v8-mode-neomatrix.login .submit .button-primary,
body.v8-mode-neomatrix .v8-customize-open,
body.v8-mode-neomatrix .v8-theme-switch button,
body.v8-mode-neomatrix .v8-customizer-actions .button-primary,
body.v8-mode-neomatrix #v8-random-bg {
  background: rgba(0,255,105,.14) !important;
  color: #eafff2 !important;
  border: 1px solid rgba(0,255,105,.58) !important;
  box-shadow: 0 0 18px rgba(0,255,105,.18) !important;
  text-shadow: 0 0 8px rgba(0,255,105,.42) !important;
}
body.v8-mode-neomatrix.login .submit .button-primary:hover,
body.v8-mode-neomatrix .v8-customize-open:hover,
body.v8-mode-neomatrix .v8-theme-switch button:hover,
body.v8-mode-neomatrix .v8-theme-switch button.is-active {
  background: rgba(0,255,105,.28) !important;
  color: #fff !important;
}
body.v8-mode-neomatrix .v8-theme-switch,
body.v8-mode-neomatrix .v8-customizer-panel {
  background: rgba(0, 10, 4, .88) !important;
  border-color: rgba(0,255,105,.36) !important;
  color: #eafff2 !important;
  box-shadow: 0 22px 70px rgba(0,0,0,.75), 0 0 32px rgba(0,255,105,.13) !important;
}
body.v8-mode-neomatrix .v8-customizer-panel h2,
body.v8-mode-neomatrix .v8-customizer-panel label { color: #eafff2 !important; }
body.v8-mode-neomatrix .v8-customizer-panel input,
body.v8-mode-neomatrix .v8-customizer-panel select {
  background: rgba(0,0,0,.72) !important;
  border-color: rgba(0,255,105,.38) !important;
  color: #eafff2 !important;
}
body.v8-mode-neomatrix .v8-customizer-panel select option { color: #111; }
body.v8-mode-neomatrix .v8-bg-credit { color: rgba(183,255,205,.76); }
body.v8-no-front-text .v8-text-row,
body.v8-no-front-visual .v8-visual-row,
body.v8-no-front-visual .v8-matrix-row { display: none !important; }
@media (max-width: 700px) {
  body.v8-mode-neomatrix.v8-matrix-on .v8-matrix-rain { opacity: .42; }
  body.v8-mode-neomatrix.login #loginform,
  body.v8-mode-neomatrix.login #lostpasswordform,
  body.v8-mode-neomatrix.login #registerform { border-radius: 22px !important; }
  .v8-text-row output { display: block; }
}
@media (max-width: 380px) {
  .v8-theme-switch button,
  .v8-customize-open { font-size: 12px; padding: 7px 9px; }
  body.login #login { width: min(360px, calc(100vw - 24px)); }
}


/* v1.8.2 mobile viewport containment and overlap prevention
   Goal: keep the login form, clock, Customize button, theme switcher, credits, and safe-area insets from competing for the same pixels on phones. */
:root {
  --v8-safe-top: env(safe-area-inset-top, 0px);
  --v8-safe-right: env(safe-area-inset-right, 0px);
  --v8-safe-bottom: env(safe-area-inset-bottom, 0px);
  --v8-safe-left: env(safe-area-inset-left, 0px);
}

body.login.virii8-os-login-enabled {
  min-height: 100svh;
  min-height: 100dvh;
}
#virii8-login-bg,
.v8-matrix-rain {
  min-height: 100svh;
  min-height: 100dvh;
}

@media (max-width: 700px), (max-height: 560px) and (pointer: coarse) {
  html {
    min-height: 100%;
    overflow-x: hidden;
  }

  body.login.virii8-os-login-enabled {
    width: 100%;
    min-width: 0;
    min-height: 100svh;
    min-height: 100dvh;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: contain;
  }

  #virii8-login-bg {
    transform: none !important;
    min-height: 100svh;
    min-height: 100dvh;
  }

  .v8-matrix-rain {
    width: 100vw !important;
    height: 100svh !important;
    height: 100dvh !important;
  }

  #virii8-login-shell {
    position: fixed;
    inset: 0;
    z-index: 7;
    pointer-events: none;
  }

  body.login #login,
  body.v8-effective-android #login,
  body.v8-effective-ios #login,
  body.v8-effective-windows #login,
  body.v8-effective-macos #login {
    width: min(390px, calc(100vw - 28px)) !important;
    min-width: 0;
    max-width: calc(100vw - 28px) !important;
    min-height: 100svh !important;
    min-height: 100dvh !important;
    height: auto !important;
    box-sizing: border-box;
    margin: 0 auto !important;
    padding: calc(var(--v8-safe-top) + clamp(92px, 16dvh, 138px)) 0 calc(var(--v8-safe-bottom) + 98px) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    transform: none !important;
    overflow: visible;
  }

  body.login #login h1,
  body.login #login h1 a,
  body.v8-effective-android.login #login h1,
  body.v8-effective-android.login #login h1 a,
  body.v8-effective-ios.login #login h1,
  body.v8-effective-ios.login #login h1 a {
    width: clamp(64px, 18vw, 82px) !important;
    height: clamp(64px, 18vw, 82px) !important;
    margin-bottom: clamp(8px, 2dvh, 14px) !important;
    flex: 0 0 auto;
  }

  body.login #loginform,
  body.login #lostpasswordform,
  body.login #registerform,
  body.v8-effective-android.login #loginform,
  body.v8-effective-android.login #lostpasswordform,
  body.v8-effective-android.login #registerform,
  body.v8-effective-ios.login #loginform,
  body.v8-effective-ios.login #lostpasswordform,
  body.v8-effective-ios.login #registerform {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    margin-inline: auto !important;
    padding: clamp(14px, 4vw, 20px) !important;
    border-radius: 22px !important;
    overflow: visible;
  }

  body.login #login h1 + form::before,
  body.v8-effective-android.login #login h1 + form::before,
  body.v8-effective-ios.login #login h1 + form::before {
    font-size: clamp(16px, 5vw, 20px) !important;
    line-height: 1.15;
    margin-bottom: clamp(8px, 2.6vw, 14px) !important;
    overflow-wrap: anywhere;
  }

  body.login #login form p,
  body.login #login form .user-pass-wrap {
    max-width: 100%;
    box-sizing: border-box;
  }

  body.login label {
    max-width: 100%;
    line-height: 1.25;
    overflow-wrap: anywhere;
  }

  body.login .input,
  body.login input[type="text"],
  body.login input[type="password"],
  body.login input[type="email"] {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 42px;
    box-sizing: border-box;
  }

  body.login .wp-pwd {
    position: relative;
    display: block;
    width: 100%;
  }

  body.login .wp-pwd .input,
  body.login .wp-pwd input[type="password"],
  body.login .wp-pwd input[type="text"] {
    padding-right: 48px !important;
  }

  body.login .button.wp-hide-pw {
    position: absolute !important;
    right: 5px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 40px !important;
    min-width: 40px !important;
    height: 34px !important;
    min-height: 34px !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    line-height: 1;
  }

  body.login .forgetmenot {
    float: none !important;
    margin: 2px 0 10px !important;
  }

  body.login .submit {
    float: none !important;
    clear: both;
    margin: 0 !important;
    text-align: center !important;
  }

  body.login .submit .button-primary {
    width: 100%;
    min-height: 42px;
    margin-top: 2px;
  }

  body.login #nav,
  body.login #backtoblog,
  body.login .privacy-policy-page-link {
    margin: 8px 0 0 !important;
    padding: 0 !important;
    font-size: clamp(11px, 3.4vw, 13px) !important;
    line-height: 1.35;
    overflow-wrap: anywhere;
  }

  .login .message,
  .login .notice,
  .login #login_error {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    margin: 0 0 10px !important;
    padding: 10px 12px !important;
  }

  .v8-lock-date,
  body.v8-effective-android .v8-lock-date,
  body.v8-effective-ios .v8-lock-date {
    top: calc(var(--v8-safe-top) + 12px) !important;
    bottom: auto !important;
    left: calc(var(--v8-safe-left) + 12px) !important;
    right: calc(var(--v8-safe-right) + 12px) !important;
    align-items: center !important;
    text-align: center;
    pointer-events: none;
  }

  #v8-time,
  body.v8-effective-android #v8-time,
  body.v8-effective-ios #v8-time {
    font-size: clamp(34px, 11.5vw, 52px) !important;
    line-height: 1 !important;
    letter-spacing: -.045em;
  }

  #v8-date,
  body.v8-effective-android #v8-date,
  body.v8-effective-ios #v8-date {
    font-size: clamp(12px, 3.5vw, 15px) !important;
    line-height: 1.2 !important;
    margin-top: 3px !important;
  }

  .v8-customize-open,
  body.v8-effective-android .v8-customize-open,
  body.v8-effective-ios .v8-customize-open {
    top: calc(var(--v8-safe-top) + 10px) !important;
    right: calc(var(--v8-safe-right) + 10px) !important;
    left: auto !important;
    max-width: calc(100vw - var(--v8-safe-left) - var(--v8-safe-right) - 20px);
    min-height: 36px;
    padding: 7px 10px !important;
    white-space: nowrap;
  }

  .v8-theme-switch,
  body.v8-effective-android .v8-theme-switch,
  body.v8-effective-ios .v8-theme-switch,
  body.v8-effective-macos .v8-theme-switch {
    left: 50% !important;
    right: auto !important;
    bottom: calc(var(--v8-safe-bottom) + 10px) !important;
    transform: translateX(-50%) !important;
    max-width: calc(100vw - var(--v8-safe-left) - var(--v8-safe-right) - 20px) !important;
    box-sizing: border-box;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .v8-theme-switch::-webkit-scrollbar { display: none; }

  .v8-theme-switch button {
    flex: 0 0 auto;
    min-height: 34px;
    white-space: nowrap;
    touch-action: manipulation;
  }

  #virii8-login-shell .v8-customize-open,
  #virii8-login-shell .v8-theme-switch {
    z-index: 100002 !important;
  }

  .v8-bg-credit {
    left: calc(var(--v8-safe-left) + 14px) !important;
    right: calc(var(--v8-safe-right) + 14px) !important;
    bottom: calc(var(--v8-safe-bottom) + 54px) !important;
    max-width: none !important;
    text-align: center !important;
    font-size: 10px !important;
    line-height: 1.25;
  }

  .v8-bottom-actions { display: none !important; }

  .v8-customizer {
    min-height: 100svh;
    min-height: 100dvh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .v8-customizer-panel,
  #v8-customizer .v8-customizer-panel {
    position: fixed !important;
    left: calc(var(--v8-safe-left) + 12px) !important;
    right: calc(var(--v8-safe-right) + 12px) !important;
    top: calc(var(--v8-safe-top) + 56px) !important;
    bottom: calc(var(--v8-safe-bottom) + 12px) !important;
    width: auto !important;
    max-width: none !important;
    max-height: none !important;
    box-sizing: border-box;
    overflow: auto;
    overscroll-behavior: contain;
    padding: 16px !important;
  }

  .v8-customizer-panel h2 {
    font-size: 18px;
    line-height: 1.2;
    margin-bottom: 12px;
  }

  .v8-customizer-panel label {
    margin: 8px 0;
  }

  .v8-customizer-panel input,
  .v8-customizer-panel select {
    min-height: 40px;
    font-size: 16px;
  }

  .v8-customizer-actions {
    position: sticky;
    bottom: -16px;
    padding: 10px 0 0;
    background: inherit;
    flex-wrap: wrap;
  }

  .v8-customizer-actions .button {
    flex: 1 1 120px;
    min-height: 40px;
  }
}

@media (max-width: 700px) and (max-height: 740px), (max-height: 560px) and (pointer: coarse) {
  body.login #login,
  body.v8-effective-android #login,
  body.v8-effective-ios #login,
  body.v8-effective-windows #login,
  body.v8-effective-macos #login {
    padding-top: calc(var(--v8-safe-top) + 58px) !important;
    padding-bottom: calc(var(--v8-safe-bottom) + 76px) !important;
  }

  .v8-lock-date { display: none !important; }
  .v8-bg-credit { display: none !important; }

  body.login #login h1,
  body.login #login h1 a,
  body.v8-effective-android.login #login h1,
  body.v8-effective-android.login #login h1 a,
  body.v8-effective-ios.login #login h1,
  body.v8-effective-ios.login #login h1 a {
    width: 58px !important;
    height: 58px !important;
    margin-bottom: 8px !important;
  }

  body.login #login h1 + form::before,
  body.v8-effective-android.login #login h1 + form::before,
  body.v8-effective-ios.login #login h1 + form::before {
    font-size: 16px !important;
    margin-bottom: 8px !important;
  }

  body.login #loginform,
  body.login #lostpasswordform,
  body.login #registerform {
    padding: 12px !important;
  }
}

@media (max-height: 520px) and (orientation: landscape) and (pointer: coarse) {
  body.login #login,
  body.v8-effective-android #login,
  body.v8-effective-ios #login,
  body.v8-effective-windows #login,
  body.v8-effective-macos #login {
    width: min(420px, calc(100vw - 112px)) !important;
    max-width: calc(100vw - 112px) !important;
    padding-top: calc(var(--v8-safe-top) + 46px) !important;
    padding-bottom: calc(var(--v8-safe-bottom) + 48px) !important;
  }

  body.login #login h1,
  body.login #login h1 a {
    width: 46px !important;
    height: 46px !important;
    margin-bottom: 5px !important;
  }

  body.login #login h1 + form::before { display: none !important; }

  body.login .input,
  body.login input[type="text"],
  body.login input[type="password"],
  body.login input[type="email"] {
    min-height: 38px !important;
    padding-top: 7px !important;
    padding-bottom: 7px !important;
  }

  body.login #login form p { margin-bottom: 7px !important; }

  .v8-customize-open,
  body.v8-effective-android .v8-customize-open,
  body.v8-effective-ios .v8-customize-open {
    left: calc(var(--v8-safe-left) + 8px) !important;
    right: auto !important;
    top: calc(var(--v8-safe-top) + 8px) !important;
  }

  .v8-theme-switch,
  body.v8-effective-android .v8-theme-switch,
  body.v8-effective-ios .v8-theme-switch,
  body.v8-effective-macos .v8-theme-switch {
    left: auto !important;
    right: calc(var(--v8-safe-right) + 8px) !important;
    bottom: calc(var(--v8-safe-bottom) + 8px) !important;
    transform: none !important;
  }

  .v8-customizer-panel,
  #v8-customizer .v8-customizer-panel {
    top: calc(var(--v8-safe-top) + 8px) !important;
    bottom: calc(var(--v8-safe-bottom) + 8px) !important;
  }
}

@supports not (height: 100dvh) {
  @media (max-width: 700px), (max-height: 560px) and (pointer: coarse) {
    body.login.virii8-os-login-enabled,
    body.login #login,
    body.v8-effective-android #login,
    body.v8-effective-ios #login,
    .v8-customizer,
    #virii8-login-bg,
    .v8-matrix-rain {
      min-height: 100vh !important;
    }
  }
}


/* v1.9.1 successful sign-in verification overlay
   Visual handoff only: WordPress and identity providers still own authentication. */
.v8-identity-verifier {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: calc(var(--v8-safe-top, 0px) + 24px) calc(var(--v8-safe-right, 0px) + 18px) calc(var(--v8-safe-bottom, 0px) + 24px) calc(var(--v8-safe-left, 0px) + 18px);
  background:
    radial-gradient(circle at 50% 38%, var(--v8-verify-primary-soft, rgba(79,140,255,.34)), transparent 34%),
    var(--v8-verify-backdrop, rgba(3,8,18,.78));
  background:
    radial-gradient(circle at 50% 38%, color-mix(in srgb, var(--v8-verify-primary, #4f8cff) 34%, transparent), transparent 34%),
    var(--v8-verify-backdrop, rgba(3,8,18,.78));
  backdrop-filter: blur(18px) saturate(140%);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
}
.v8-identity-verifier[hidden] { display: none !important; }
.v8-identity-verifier.is-active {
  opacity: 1;
  pointer-events: auto;
}
.v8-identity-verifier.is-active.is-provider-handoff {
  pointer-events: none;
}
body.v8-auth-provider-handoff #login {
  pointer-events: auto;
}
.v8-identity-card {
  position: relative;
  overflow: hidden;
  width: min(420px, calc(100vw - 36px));
  min-height: 260px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 34px 28px 30px;
  border: 1px solid rgba(255,255,255,.26);
  border-radius: 28px;
  color: #fff;
  text-align: center;
  background: linear-gradient(145deg, rgba(255,255,255,.22), rgba(255,255,255,.08));
  box-shadow: 0 28px 90px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.26);
  transform: translateY(10px) scale(.985);
  animation: v8-identity-card-in .34s ease forwards;
}
.v8-identity-orb {
  position: relative;
  width: 104px;
  height: 104px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: radial-gradient(circle, rgba(255,255,255,.3), rgba(255,255,255,.08) 48%, transparent 52%);
  box-shadow: 0 0 44px var(--v8-verify-primary-glow, rgba(79,140,255,.48));
  box-shadow: 0 0 44px color-mix(in srgb, var(--v8-verify-primary, #4f8cff) 48%, transparent);
}
.v8-identity-orb::before {
  content: "";
  width: 62px;
  height: 62px;
  border-radius: inherit;
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,.96), color-mix(in srgb, var(--v8-verify-secondary, #8ab4f8) 30%, rgba(255,255,255,.2)) 48%, color-mix(in srgb, var(--v8-verify-primary, #4f8cff) 62%, transparent));
  box-shadow: inset 0 0 18px rgba(255,255,255,.22), 0 0 26px rgba(255,255,255,.2);
}
.v8-identity-orb span {
  position: absolute;
  inset: 2px;
  border-radius: inherit;
  border: 2px solid transparent;
  border-top-color: rgba(255,255,255,.9);
  border-right-color: rgba(255,255,255,.28);
  animation: v8-identity-spin 1.16s linear infinite;
}
.v8-identity-orb span:nth-child(2) {
  inset: 12px;
  border-top-color: var(--v8-verify-secondary, #8ab4f8);
  border-right-color: var(--v8-verify-secondary-soft, rgba(138,180,248,.32));
  border-right-color: color-mix(in srgb, var(--v8-verify-secondary, #8ab4f8) 28%, transparent);
  animation-duration: 1.82s;
  animation-direction: reverse;
}
.v8-identity-orb span:nth-child(3) {
  inset: 24px;
  border-top-color: rgba(255,255,255,.68);
  animation-duration: 2.4s;
}
.v8-identity-title {
  font-size: clamp(22px, 4vw, 30px);
  font-weight: 650;
  letter-spacing: -.02em;
  text-shadow: 0 2px 14px rgba(0,0,0,.35);
}
.v8-identity-dots::after {
  content: "";
  display: inline-block;
  width: 1.25em;
  text-align: left;
  animation: v8-identity-dots 1.1s steps(4, end) infinite;
}
.v8-identity-step {
  min-height: 22px;
  font-size: 14px;
  color: rgba(255,255,255,.82);
}
.v8-identity-bar {
  width: min(270px, 76vw);
  height: 5px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
}
.v8-identity-bar span {
  display: block;
  width: 46%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, transparent, var(--v8-verify-secondary, #8ab4f8), transparent);
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--v8-verify-secondary, #8ab4f8) 72%, white), transparent);
  animation: v8-identity-scan 1.25s ease-in-out infinite;
}
body.v8-auth-verifying #login { filter: blur(1px); }
body.v8-effective-macos .v8-identity-card,
body.v8-effective-ios .v8-identity-card {
  border-radius: 32px;
  background: linear-gradient(145deg, rgba(255,255,255,.28), rgba(255,255,255,.1));
}
body.v8-mode-neomatrix .v8-identity-verifier {
  background: radial-gradient(circle at 50% 36%, rgba(0,255,105,.16), transparent 35%), rgba(0, 7, 3, .82);
}
body.v8-mode-neomatrix .v8-identity-card {
  border-color: rgba(0,255,105,.38);
  background: linear-gradient(145deg, rgba(0,255,105,.13), rgba(0, 12, 5, .82));
  box-shadow: 0 28px 90px rgba(0,0,0,.72), 0 0 38px rgba(0,255,105,.14), inset 0 0 30px rgba(0,255,105,.05);
}
body.v8-mode-neomatrix .v8-identity-orb { box-shadow: 0 0 44px rgba(0,255,105,.26); }
body.v8-mode-neomatrix .v8-identity-orb::before { background: radial-gradient(circle at 35% 30%, #eafff2, rgba(0,255,105,.36) 48%, rgba(0,0,0,.75)); }
body.v8-mode-neomatrix .v8-identity-orb span { border-top-color: rgba(0,255,105,.92); border-right-color: rgba(0,255,105,.22); }
body.v8-mode-neomatrix .v8-identity-bar span { background: linear-gradient(90deg, transparent, rgba(0,255,105,.92), transparent); }
.v8-identity-verifier[data-v8-theme=aurora] {
  background:
    radial-gradient(circle at 24% 24%, var(--v8-verify-primary-glow, rgba(79,140,255,.48)), transparent 30%),
    radial-gradient(circle at 78% 70%, var(--v8-verify-secondary-soft, rgba(138,180,248,.32)), transparent 32%),
    var(--v8-verify-backdrop, rgba(3,8,18,.78));
  background:
    radial-gradient(circle at 24% 24%, color-mix(in srgb, var(--v8-verify-primary, #4f8cff) 42%, transparent), transparent 30%),
    radial-gradient(circle at 78% 70%, color-mix(in srgb, var(--v8-verify-secondary, #8ab4f8) 36%, transparent), transparent 32%),
    var(--v8-verify-backdrop, rgba(3,8,18,.78));
}
.v8-identity-verifier[data-v8-theme=aurora] .v8-identity-card { border-color: color-mix(in srgb, var(--v8-verify-secondary, #8ab4f8) 42%, transparent); box-shadow: 0 30px 105px color-mix(in srgb, var(--v8-verify-primary, #4f8cff) 25%, rgba(0,0,0,.55)); }
.v8-identity-verifier[data-v8-theme=neomatrix] {
  background: radial-gradient(circle at 50% 36%, rgba(0,255,105,.16), transparent 35%), rgba(0, 7, 3, .86);
}
.v8-identity-verifier[data-v8-theme=neomatrix] .v8-identity-card { border-color: rgba(0,255,105,.38); background: linear-gradient(145deg, rgba(0,255,105,.13), rgba(0, 12, 5, .82)); box-shadow: 0 28px 90px rgba(0,0,0,.72), 0 0 38px rgba(0,255,105,.14), inset 0 0 30px rgba(0,255,105,.05); }
.v8-identity-verifier[data-v8-theme=neomatrix] .v8-identity-orb { box-shadow: 0 0 44px rgba(0,255,105,.26); }
.v8-identity-verifier[data-v8-theme=neomatrix] .v8-identity-orb::before { background: radial-gradient(circle at 35% 30%, #eafff2, rgba(0,255,105,.36) 48%, rgba(0,0,0,.75)); }
.v8-identity-verifier[data-v8-theme=neomatrix] .v8-identity-orb span { border-top-color: rgba(0,255,105,.92); border-right-color: rgba(0,255,105,.22); }
.v8-identity-verifier[data-v8-theme=neomatrix] .v8-identity-bar span { background: linear-gradient(90deg, transparent, rgba(0,255,105,.92), transparent); }
.v8-identity-verifier[data-v8-theme=blueprint] {
  background:
    linear-gradient(var(--v8-verify-primary-soft, rgba(79,140,255,.34)) 1px, transparent 1px),
    linear-gradient(90deg, var(--v8-verify-primary-soft, rgba(79,140,255,.34)) 1px, transparent 1px),
    var(--v8-verify-backdrop, rgba(3,8,18,.78));
  background:
    linear-gradient(color-mix(in srgb, var(--v8-verify-primary, #4f8cff) 13%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--v8-verify-primary, #4f8cff) 13%, transparent) 1px, transparent 1px),
    var(--v8-verify-backdrop, rgba(3,8,18,.78));
  background-size: 34px 34px, 34px 34px, auto;
}
.v8-identity-verifier[data-v8-theme=blueprint] .v8-identity-card { border-color: color-mix(in srgb, var(--v8-verify-primary, #4f8cff) 48%, transparent); background: linear-gradient(145deg, color-mix(in srgb, var(--v8-verify-primary, #4f8cff) 17%, rgba(255,255,255,.06)), rgba(0,0,0,.22)); }
.v8-identity-verifier[data-v8-theme=minimal] { background: var(--v8-verify-backdrop-soft, rgba(3,8,18,.52)); backdrop-filter: blur(10px); }
.v8-identity-verifier[data-v8-theme=minimal] .v8-identity-card { min-height: 210px; border-radius: 20px; background: rgba(15,18,28,.88); box-shadow: 0 18px 54px rgba(0,0,0,.42); }
.v8-identity-verifier[data-v8-animation=pulse] .v8-identity-orb::before { animation: v8-identity-pulse 1.25s ease-in-out infinite; }
.v8-identity-verifier[data-v8-animation=scanline] .v8-identity-card::after { content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none; background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--v8-verify-secondary, #8ab4f8) 20%, transparent), transparent); transform: translateY(-100%); animation: v8-identity-card-scan 1.55s linear infinite; }
.v8-identity-verifier[data-v8-animation=float] .v8-identity-card { animation: v8-identity-card-in .34s ease forwards, v8-identity-float 3.4s ease-in-out .35s infinite; }
.v8-identity-verifier[data-v8-animation=none] .v8-identity-card,
.v8-identity-verifier[data-v8-animation=none] .v8-identity-orb span,
.v8-identity-verifier[data-v8-animation=none] .v8-identity-orb::before,
.v8-identity-verifier[data-v8-animation=none] .v8-identity-bar span,
.v8-identity-verifier[data-v8-animation=none] .v8-identity-dots::after { animation: none !important; }
@keyframes v8-identity-spin { to { transform: rotate(360deg); } }
@keyframes v8-identity-scan { 0% { transform: translateX(-115%); } 100% { transform: translateX(235%); } }
@keyframes v8-identity-dots { 0% { content: ""; } 25% { content: "."; } 50% { content: ".."; } 75%, 100% { content: "..."; } }
@keyframes v8-identity-card-in { to { transform: translateY(0) scale(1); } }
@keyframes v8-identity-pulse { 0%,100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.08); opacity: .76; } }
@keyframes v8-identity-card-scan { to { transform: translateY(100%); } }
@keyframes v8-identity-float { 0%,100% { transform: translateY(0) scale(1); } 50% { transform: translateY(-7px) scale(1); } }
@media (prefers-reduced-motion: reduce) {
  .v8-identity-card,
  .v8-identity-orb span,
  .v8-identity-bar span,
  .v8-identity-dots::after { animation: none !important; }
  .v8-identity-verifier { transition: none !important; }
}
@media (max-width: 480px) {
  .v8-identity-card { min-height: 230px; padding: 28px 22px 26px; border-radius: 24px; }
  .v8-identity-orb { width: 88px; height: 88px; }
  .v8-identity-orb::before { width: 54px; height: 54px; }
}
