/* =====================================================================
   AZIS 6.0 · lockscreen-6.0.css
   Cipher-Vault-Lockscreen — NACH styles.css einbinden:
     <link rel="stylesheet" href="./lockscreen-6.0.css">
   ---------------------------------------------------------------------
   Ersetzt die alten .binary-lock/.body-Regeln (altes Markup .body/.keyhole
   existiert nach Snippet-Einbau nicht mehr; alte Regeln laufen ins Leere).
   Farben über Theme-Variablen (--accent/--accent-glow/--danger), damit
   Light/Camo/Terminal/Classic automatisch mitspielen.
   Zustaende (Klassen auf .crypto-card, setzt lockscreen-6.0.js):
     .busy .deny .locked .tamper .fatal .unlocking .sealing
   ===================================================================== */

:root {
  --lk-warn: #fbbf24;
  --lk-warn-glow: rgba(251, 191, 36, 0.45);
}

/* ---- Hintergrund-Punktraster im Gate -------------------------------- */
#cryptoGate { overflow-y: auto; }
#cryptoGate .lk-dots {
  position: absolute; inset: 0; pointer-events: none;
  background-image: radial-gradient(color-mix(in srgb, var(--accent) 11%, transparent) 1px, transparent 1.6px);
  background-size: 26px 26px;
  mask-image: radial-gradient(ellipse 75% 65% at 50% 42%, rgba(0, 0, 0, 0.8) 0%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 75% 65% at 50% 42%, rgba(0, 0, 0, 0.8) 0%, transparent 75%);
  animation: lk-dots-drift 26s linear infinite alternate;
}
@keyframes lk-dots-drift { from { background-position: 0 0; } to { background-position: 26px 13px; } }

/* ---- Karte: HUD-Eckwinkel ------------------------------------------- */
.crypto-card { overflow: hidden; }
.crypto-card .hud-corner {
  position: absolute; width: 16px; height: 16px; pointer-events: none;
  border: 1.5px solid color-mix(in srgb, var(--accent) 55%, transparent);
  opacity: 0; animation: lk-corner-in 400ms ease-out both;
  transition: border-color 300ms ease;
}
.crypto-card .hud-corner.tl { top: 7px; left: 7px;  border-right: none; border-bottom: none; border-top-left-radius: 6px; animation-delay: 500ms; }
.crypto-card .hud-corner.tr { top: 7px; right: 7px; border-left: none;  border-bottom: none; border-top-right-radius: 6px; animation-delay: 580ms; }
.crypto-card .hud-corner.bl { bottom: 7px; left: 7px;  border-right: none; border-top: none; border-bottom-left-radius: 6px; animation-delay: 660ms; }
.crypto-card .hud-corner.br { bottom: 7px; right: 7px; border-left: none;  border-top: none; border-bottom-right-radius: 6px; animation-delay: 740ms; }
@keyframes lk-corner-in { from { opacity: 0; transform: scale(0.4); } to { opacity: 1; transform: scale(1); } }

/* =====================================================================
   Cipher-Vault
   ===================================================================== */
.lock-stage { position: relative; width: 100%; display: grid; justify-items: center; margin: 2px 0 12px; }

.binary-lock {
  position: relative;
  width: 170px;
  margin: 0;
  display: grid; justify-items: center;
  filter: drop-shadow(0 8px 14px rgba(7, 23, 20, 0.22));
  animation: lk-breathe 4.5s ease-in-out 1.4s infinite;
}
@keyframes lk-breathe {
  0%, 100% { filter: drop-shadow(0 8px 14px rgba(7, 23, 20, 0.22)) drop-shadow(0 0 14px color-mix(in srgb, var(--accent) 18%, transparent)); }
  50%      { filter: drop-shadow(0 8px 14px rgba(7, 23, 20, 0.22)) drop-shadow(0 0 26px color-mix(in srgb, var(--accent) 38%, transparent)); }
}

/* Buegel: Proportion wie 5.0 (Buegel ≈ 0.79 × Body-Breite) */
.binary-lock .shackle {
  width: 134px; height: 105px; display: block;
  transform-origin: 67px 105px;
  background: transparent; overflow: visible;
  -webkit-backface-visibility: hidden; backface-visibility: hidden;
}
.binary-lock .shackle path { fill: none; stroke-linecap: round; stroke-linejoin: round; }
.binary-lock .shackle .sh-core {
  stroke: var(--accent); stroke-width: 14;
  filter: drop-shadow(0 0 8px var(--accent-glow));
  stroke-dasharray: 270; stroke-dashoffset: 270;
  animation: lk-shackle-draw 650ms cubic-bezier(0.5, 0.05, 0.3, 1) 200ms forwards;
  transition: stroke 250ms ease;
}
.binary-lock .shackle .sh-hilite {
  stroke: color-mix(in srgb, var(--accent) 35%, #ffffff); stroke-width: 4; opacity: 0;
  animation: lk-hilite-on 350ms ease-out 760ms forwards;
}
@keyframes lk-shackle-draw { to { stroke-dashoffset: 0; } }
@keyframes lk-hilite-on { to { opacity: 0.55; } }

/* Body */
.vault {
  position: relative;
  width: 170px; height: 128px;
  border: 2px solid var(--accent);
  border-radius: 16px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), transparent 35%),
    linear-gradient(180deg, color-mix(in srgb, var(--accent) 9%, #0a0f16) 0%, #0a1018 100%);
  box-sizing: border-box;
  padding: 9px 0;
  display: grid; grid-template-rows: auto 1fr auto; align-items: center;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.04),
    inset 0 -18px 30px color-mix(in srgb, var(--accent) 16%, transparent),
    0 0 26px var(--accent-glow);
  animation: lk-body-pop 420ms cubic-bezier(0.34, 1.56, 0.64, 1) 420ms both;
  transition: border-color 250ms ease, box-shadow 250ms ease, opacity 250ms ease;
}
.vault .vault-notch {
  position: absolute; width: 7px; height: 7px; pointer-events: none;
  border: 1.5px solid color-mix(in srgb, var(--accent) 60%, transparent);
  transition: border-color 250ms ease;
}
.vault .vault-notch.tl { top: 5px; left: 5px;   border-right: none; border-bottom: none; }
.vault .vault-notch.tr { top: 5px; right: 5px;  border-left: none;  border-bottom: none; }
.vault .vault-notch.bl { bottom: 5px; left: 5px;  border-right: none; border-top: none; }
.vault .vault-notch.br { bottom: 5px; right: 5px; border-left: none;  border-top: none; }
@keyframes lk-body-pop { from { opacity: 0; transform: scale(0.82); } to { opacity: 1; transform: scale(1); } }

/* Cipher-Tracks */
@keyframes lk-track-scroll     { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes lk-track-scroll-rev { from { transform: translateX(-50%); } to { transform: translateX(0); } }
.vault .track {
  overflow: hidden; white-space: nowrap; pointer-events: none;
  opacity: 0; animation: lk-track-on 600ms ease-out 640ms forwards;
  mask-image: linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
}
@keyframes lk-track-on { to { opacity: 1; } }
.vault .track .track-inner {
  display: inline-block;
  font-family: var(--font-num, ui-monospace, monospace); font-weight: 700;
  font-size: 9px; letter-spacing: 0.32em; line-height: 1.6;
  color: color-mix(in srgb, var(--accent) 40%, transparent);
  animation: lk-track-scroll 26s linear infinite;
  transition: color 250ms ease;
}
.vault .track--rev .track-inner {
  animation-name: lk-track-scroll-rev; animation-duration: 34s;
  color: color-mix(in srgb, var(--accent) 26%, transparent); font-size: 8.5px;
}

/* Kern-Zeilen */
.vault-rows { position: relative; z-index: 2; display: grid; gap: 2px; padding: 2px 0; }
.vault-rows span {
  font-family: var(--font-num, ui-monospace, monospace);
  font-size: 13.5px; font-weight: 700; line-height: 1.25;
  color: var(--accent); letter-spacing: 0.14em; text-align: center;
  user-select: none;
  text-shadow: 0 0 6px var(--accent-glow), 0 0 1px rgba(0, 0, 0, 0.6);
  opacity: 0;
  transition: opacity 300ms ease, color 300ms ease;
}
.vault-rows span:nth-child(1) { animation: lk-row-in 300ms ease-out 700ms forwards; }
.vault-rows span:nth-child(2) { animation: lk-row-in 300ms ease-out 810ms forwards; }
.vault-rows span:nth-child(3) { animation: lk-row-in 300ms ease-out 920ms forwards; }
.vault-rows span.dim { opacity: 0.22 !important; }
.vault-rows span.lit {
  color: color-mix(in srgb, var(--accent) 18%, #ffffff);
  text-shadow: 0 0 10px color-mix(in srgb, var(--accent) 60%, #ffffff), 0 0 22px var(--accent-glow);
}
.vault-rows span.err {
  color: var(--danger);
  text-shadow: 0 0 10px color-mix(in srgb, var(--danger) 45%, transparent);
}
.vault-rows span.warnrow {
  color: var(--lk-warn);
  text-shadow: 0 0 10px var(--lk-warn-glow);
}
@keyframes lk-row-in { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: translateY(0); } }

/* Badge unterm Schloss */
.lock-meta {
  margin: 10px 0 0; font-family: var(--font-num, ui-monospace, monospace);
  font-size: 9.5px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--muted);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  opacity: 0; animation: lk-row-in 400ms ease-out 950ms forwards;
}
.lock-meta::before {
  content: ""; width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 7px var(--accent-glow);
  animation: lk-meta-blink 2.4s ease-in-out 1.4s infinite;
}
@keyframes lk-meta-blink { 0%, 100% { opacity: 1; } 50% { opacity: 0.25; } }

/* gestaffelte Text/Form-Entrance im Gate */
.crypto-card h2 { opacity: 0; animation: lk-row-in 400ms ease-out 700ms forwards; transition: color 250ms ease; }
.crypto-card #cryptoSubtitle { opacity: 0; animation: lk-row-in 400ms ease-out 780ms forwards; }
.crypto-card .field { opacity: 0; animation: lk-row-in 400ms ease-out 860ms forwards; }
.crypto-card #cryptoHint { opacity: 0; animation: lk-row-in 400ms ease-out 920ms forwards; }
.crypto-card .dialog-actions { opacity: 0; animation: lk-row-in 400ms ease-out 980ms forwards; }
.btn.soft.danger { color: var(--danger); border-color: color-mix(in srgb, var(--danger) 35%, transparent); }
.btn.soft.danger:hover { border-color: color-mix(in srgb, var(--danger) 70%, transparent); }

/* =====================================================================
   Zustaende
   ===================================================================== */
/* Busy: Tracks beschleunigen waehrend KDF/Entschluesselung */
.crypto-card.busy .track .track-inner { animation-duration: 4s; color: color-mix(in srgb, var(--accent) 55%, transparent); }
.crypto-card.busy .track--rev .track-inner { animation-duration: 3s; }

/* Unlock (playUnlockAnimation) */
.crypto-card.unlocking .binary-lock .shackle {
  animation: shackle-open 1050ms cubic-bezier(0.2, 0.72, 0.2, 1) 700ms forwards;
}
/* Original-Keyframes aus styles.css gelten weiter:
   0% → 36% anheben → 100% translate(22px,-12px) rotate(33deg) */
.crypto-card.unlocking .vault {
  animation: lk-body-pop 420ms cubic-bezier(0.34, 1.56, 0.64, 1) 420ms both, lk-unlock-flicker 1050ms ease;
}
@keyframes lk-unlock-flicker {
  0% { filter: brightness(1); } 20% { filter: brightness(1.35); }
  32% { filter: brightness(0.92); } 45% { filter: brightness(1.5); }
  60% { filter: brightness(1.05); } 100% { filter: brightness(1); }
}
.crypto-card.unlocking .track .track-inner { animation-duration: 1.6s; color: color-mix(in srgb, var(--accent) 75%, transparent); }
.crypto-card.unlocking .track--rev .track-inner { animation-duration: 1.1s; }

.unlock-burst {
  position: absolute; top: 50%; left: 50%;
  width: 150px; height: 150px; margin: -75px 0 0 -75px;
  border: 1.5px solid color-mix(in srgb, var(--accent) 85%, #ffffff); border-radius: 50%;
  opacity: 0; pointer-events: none;
}
.crypto-card.unlocking .unlock-burst { animation: lk-burst 800ms cubic-bezier(0.23, 1, 0.32, 1) 720ms both; }
.crypto-card.sealing .unlock-burst { animation: lk-burst 700ms cubic-bezier(0.23, 1, 0.32, 1) 350ms both; }
@keyframes lk-burst {
  0%   { opacity: 0.9; transform: scale(0.55); }
  100% { opacity: 0; transform: scale(2.1); }
}

/* Versiegeln (PIN-Setup-Erfolg): offener Buegel schnappt zu */
.binary-lock.open .shackle { transform: translate(22px, -12px) rotate(33deg); }
.binary-lock.open.closing .shackle { animation: lk-shackle-close 700ms cubic-bezier(0.4, 0, 0.2, 1.25) forwards; }
@keyframes lk-shackle-close {
  0%   { transform: translate(22px, -12px) rotate(33deg); }
  55%  { transform: translate(0, -12px) rotate(0deg); }
  82%  { transform: translateY(1.5px) rotate(0deg); }
  100% { transform: translateY(0) rotate(0deg); }
}

/* Deny (PIN falsch / Device-Bind): kurz rot */
.crypto-card.deny .vault {
  border-color: color-mix(in srgb, var(--danger) 85%, transparent);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.04),
    inset 0 -18px 30px color-mix(in srgb, var(--danger) 14%, transparent),
    0 0 26px color-mix(in srgb, var(--danger) 45%, transparent);
  animation: lk-body-pop 420ms cubic-bezier(0.34, 1.56, 0.64, 1) 420ms both, lk-deny-flicker 500ms ease;
}
@keyframes lk-deny-flicker {
  0% { filter: brightness(1); } 18% { filter: brightness(1.45); }
  32% { filter: brightness(0.85); } 50% { filter: brightness(1.3); }
  100% { filter: brightness(1); }
}
.crypto-card.deny .vault .vault-notch { border-color: color-mix(in srgb, var(--danger) 70%, transparent); }
.crypto-card.deny .binary-lock .shackle .sh-core { stroke: var(--danger); filter: drop-shadow(0 0 8px color-mix(in srgb, var(--danger) 45%, transparent)); }
.crypto-card.deny .track .track-inner { color: color-mix(in srgb, var(--danger) 40%, transparent); }
.crypto-card.deny .hud-corner { border-color: color-mix(in srgb, var(--danger) 55%, transparent); }

/* Lockout: dimmen, Countdown lebt im Hint */
.crypto-card.locked .vault { opacity: 0.55; }
.crypto-card.locked .binary-lock { animation: none; }

/* Tamper (Container beschaedigt): amber, Buegel haengt halb offen */
.crypto-card.tamper .vault {
  border-color: color-mix(in srgb, var(--lk-warn) 85%, transparent);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.04),
    inset 0 -18px 30px color-mix(in srgb, var(--lk-warn) 13%, transparent),
    0 0 26px var(--lk-warn-glow);
}
.crypto-card.tamper .vault .vault-notch { border-color: color-mix(in srgb, var(--lk-warn) 70%, transparent); }
.crypto-card.tamper .binary-lock {
  animation: none;
  filter: drop-shadow(0 8px 14px rgba(23, 18, 7, 0.3)) drop-shadow(0 0 16px color-mix(in srgb, var(--lk-warn) 25%, transparent));
}
.crypto-card.tamper .binary-lock .shackle { transform: translate(9px, -7px) rotate(14deg); }
.crypto-card.tamper .binary-lock .shackle .sh-core { stroke: var(--lk-warn); filter: drop-shadow(0 0 8px var(--lk-warn-glow)); }
.crypto-card.tamper .binary-lock .shackle .sh-hilite { opacity: 0.3; }
.crypto-card.tamper .track .track-inner { color: color-mix(in srgb, var(--lk-warn) 35%, transparent); animation-duration: 60s; }
.crypto-card.tamper .lock-meta::before { background: var(--lk-warn); box-shadow: 0 0 7px var(--lk-warn-glow); animation-duration: 1.2s; }
.crypto-card.tamper .hud-corner { border-color: color-mix(in srgb, var(--lk-warn) 55%, transparent); }

/* Fatal (CRYPT ERROR): permanent rot + Jitter */
.crypto-card.fatal h2 { color: var(--danger); font-family: var(--font-num, ui-monospace, monospace); letter-spacing: 0.08em; }
.crypto-card.fatal .vault {
  border-color: var(--danger);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.04),
    inset 0 -18px 30px color-mix(in srgb, var(--danger) 16%, transparent),
    0 0 26px color-mix(in srgb, var(--danger) 45%, transparent);
  animation: lk-body-pop 420ms cubic-bezier(0.34, 1.56, 0.64, 1) 420ms both, lk-fatal-jitter 3.2s steps(1, end) 600ms infinite;
}
@keyframes lk-fatal-jitter {
  0%, 100% { transform: translateX(0); filter: brightness(1); }
  4%  { transform: translateX(-1.5px); filter: brightness(1.25); }
  6%  { transform: translateX(1px); filter: brightness(0.9); }
  8%  { transform: translateX(0); filter: brightness(1); }
  54% { transform: translateX(1.5px); filter: brightness(1.2); }
  57% { transform: translateX(0); filter: brightness(1); }
}
.crypto-card.fatal .vault .vault-notch { border-color: color-mix(in srgb, var(--danger) 70%, transparent); }
.crypto-card.fatal .binary-lock {
  animation: none;
  filter: drop-shadow(0 8px 14px rgba(23, 7, 7, 0.3)) drop-shadow(0 0 18px color-mix(in srgb, var(--danger) 30%, transparent));
}
.crypto-card.fatal .binary-lock .shackle .sh-core { stroke: var(--danger); filter: drop-shadow(0 0 8px color-mix(in srgb, var(--danger) 45%, transparent)); }
.crypto-card.fatal .binary-lock .shackle .sh-hilite { opacity: 0.25; }
.crypto-card.fatal .track .track-inner { color: color-mix(in srgb, var(--danger) 35%, transparent); animation-duration: 80s; }
.crypto-card.fatal .track--rev .track-inner { animation-duration: 110s; }
.crypto-card.fatal .lock-meta::before { background: var(--danger); box-shadow: 0 0 7px color-mix(in srgb, var(--danger) 45%, transparent); animation-duration: 0.8s; }
.crypto-card.fatal .hud-corner { border-color: color-mix(in srgb, var(--danger) 60%, transparent); }

/* Warn-Hint (Tamper) — ergaenzt .hint.az-error aus styles.css */
.hint.az-warn { color: var(--lk-warn); font-weight: 600; }

/* =====================================================================
   PUK-Reveal-Panel (pukRevealDialog)
   ===================================================================== */
.puk-panel {
  position: relative; overflow: hidden;
  margin: 4px 0 0;
  border: 1px dashed color-mix(in srgb, var(--accent) 45%, transparent);
  border-radius: 14px;
  background: rgba(10, 14, 20, 0.85);
  padding: 16px 12px;
}
.puk-code {
  font-family: var(--font-num, ui-monospace, monospace); font-weight: 700;
  font-size: clamp(16px, 4.6vw, 21px); letter-spacing: 0.14em;
  display: flex; justify-content: center; flex-wrap: wrap; gap: 2px 0;
  user-select: text; margin: 0; white-space: normal;
}
.puk-code span { color: color-mix(in srgb, var(--accent) 45%, transparent); transition: color 150ms ease; }
.puk-code span.lockd {
  color: color-mix(in srgb, var(--accent) 18%, #ffffff);
  text-shadow: 0 0 9px color-mix(in srgb, var(--accent) 55%, #ffffff), 0 0 20px var(--accent-glow);
}
.puk-code span.sep { color: var(--muted); text-shadow: none; }

/* Light-Theme: hellerer Vault-Body (analog zu den alten Overrides) */
:root[data-theme="light"] .vault {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.6), transparent 30%),
    linear-gradient(180deg, color-mix(in srgb, var(--accent) 8%, #f4f7fa) 0%, #e8eef4 100%);
}
:root[data-theme="light"] .vault-rows span { text-shadow: none; color: var(--accent-strong); }
:root[data-theme="light"] .puk-panel { background: rgba(244, 247, 250, 0.9); }

@media (prefers-reduced-motion: reduce) {
  #cryptoGate *, #cryptoGate { animation: none !important; }
  .crypto-card .hud-corner, .vault, .vault-rows span, .lock-meta, .vault .track,
  .crypto-card h2, .crypto-card #cryptoSubtitle, .crypto-card .field,
  .crypto-card #cryptoHint, .crypto-card .dialog-actions { opacity: 1; transform: none; }
  .binary-lock .shackle .sh-core { stroke-dashoffset: 0; }
  .binary-lock .shackle .sh-hilite { opacity: 0.55; }
  .unlock-burst { display: none; }
}
