/* ═══════════════════════════════════════════════════════
   animations.css — Tevos
   All @keyframes and shared animation/transition styles.
   Must be loaded after base.css on every page.
═══════════════════════════════════════════════════════ */

@keyframes screenIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes ringShimmer {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

@keyframes ringGlow {
  0%, 100% { opacity: 0.5; transform: scale(1); }
  50%       { opacity: 1;   transform: scale(1.05); }
}

@keyframes hapticReveal {
  0%   { opacity: 0; }
  100% { opacity: 1; }
}

@keyframes hapticKey {
  0%   { opacity: 0; transform: scale(0.7); }
  100% { opacity: 1; transform: scale(1); }
}

@keyframes wv {
  0%, 100% { transform: scaleY(1); }
  50%       { transform: scaleY(0.3); }
}

@keyframes pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(16,185,129,0.4); }
  50%       { opacity: 0.8; box-shadow: 0 0 0 4px rgba(16,185,129,0); }
}

/* ── Toast & Modal Animations ── */

#toast-container {
  position: fixed;
  top: 64px;
  right: 16px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
  /* never wider than viewport on mobile */
  max-width: calc(100vw - 32px);
}
@keyframes toastIn  { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }
@keyframes toastOut { from { opacity:1; } to { opacity:0; transform:translateX(20px); } }

/* Modal overlay — shared by all modals */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.modal-box {
  background: var(--bg-raised);
  border: 1px solid var(--line-mid);
  border-radius: var(--r-xl);
  padding: 28px;
  width: 100%;
  max-width: min(460px, 94vw);
  box-shadow: 0 24px 64px rgba(0,0,0,0.5);
  animation: modalIn 0.22s cubic-bezier(0.4,0,0.2,1);
}
@media (max-width: 480px) {
  .modal-overlay { padding: 12px; align-items: flex-end; }
  /* [FIXED P1] safe-area-inset-bottom for iPhone home bar */
  .modal-box {
    padding: 20px 20px max(20px, env(safe-area-inset-bottom)) 20px;
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    max-width: 100%;
  }
}
@keyframes modalIn { from { opacity:0; transform:scale(0.95) translateY(10px); } to { opacity:1; transform:scale(1) translateY(0); } }
.modal-title {
  font-family: var(--ff-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--t-primary);
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.modal-sub { font-size: 12px; color: var(--t-muted); margin-bottom: 20px; line-height: 1.5; }
.modal-field { margin-bottom: 14px; }
.modal-label {
  display: block;
  font-family: var(--ff-data);
  font-size: 9.5px;
  color: var(--t-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 5px;
}
.modal-input, .modal-select, .modal-textarea {
  width: 100%;
  background: var(--bg-surface);
  border: 1px solid var(--line-mid);
  border-radius: var(--r-sm);
  padding: 10px 13px;
  font-size: 16px; /* [FIXED P0] iOS Safari auto-zooms on focus when < 16px */
  color: var(--t-primary);
  font-family: var(--ff-body);
  outline: none;
  box-sizing: border-box;
  min-height: 44px; /* [FIXED P0] touch target */
}
@media (min-width: 1024px) {
  .modal-input, .modal-select, .modal-textarea {
    font-size: 13px;
    min-height: 36px;
  }
}
.modal-input:focus, .modal-select:focus, .modal-textarea:focus {
  border-color: var(--brand-border);
  box-shadow: 0 0 0 3px var(--brand-glass);
}
.modal-select option { background: var(--bg-raised); }
.modal-textarea { resize: vertical; min-height: 80px; line-height: 1.55; }
.modal-actions { display: flex; gap: 8px; margin-top: 20px; }

/* Editable code textarea in audit screen */
.audit-answer-area {
  width: 100%;
  background: var(--code-bg);
  border: 1px solid var(--brand-border);
  border-radius: var(--r-sm);
  padding: 13px;
  font-family: var(--ff-data);
  font-size: 11.5px;
  color: var(--code-text);
  line-height: 1.7;
  resize: vertical;
  min-height: 80px;
  outline: none;
  margin-top: 8px;
  box-sizing: border-box;
}
.audit-answer-area:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px var(--brand-glass);
}
.audit-answer-area::placeholder { color: var(--code-placeholder); }
