/*
 * Tema login Figaro Secure Gateway — sovrascrive keycloak.v2 (PatternFly v5).
 * Palette e raggi allineati a public/admin.css (tema scuro navy + accento indigo).
 * Caricato dopo css/styles.css: vince sulla cascata per ordine + selettori mirati.
 *
 * Estetica "console firewall": sfondo a griglia di rete + glow indigo, fascia
 * accento animata, watermark a scudo, tagline e chip di sicurezza, micro-
 * interazioni su input/bottoni. Solo CSS — nessun override dei template
 * FreeMarker, così resta compatibile con gli upgrade di Keycloak.
 */

:root {
  /* Token Figaro (da public/admin.css) */
  --fg-bg:          #0d1426;
  --fg-bg-grad:     #0b1020;
  --fg-panel:       #161c2d;
  --fg-panel-inner: #1a2236;
  --fg-ink:         #aab5cf;
  --fg-ink-strong:  #dde3f0;
  --fg-muted:       #7c8ab3;
  --fg-line:        rgba(140, 160, 200, 0.10);
  --fg-line-bright: rgba(140, 160, 200, 0.18);
  --fg-indigo:      #818cf8;
  --fg-indigo-hi:   #99a2fb;
  --fg-indigo-soft: rgba(129, 140, 248, 0.10);
  --fg-indigo-glow: rgba(129, 140, 248, 0.35);
  --fg-good:        #3dd68c;
  --fg-good-glow:   rgba(61, 214, 140, 0.30);
  --fg-crit:        #ef4444;
  --fg-warn:        #f59e0b;
  --fg-radius:      4px;
  --fg-font:        system-ui, -apple-system, BlinkMacSystemFont,
                    'Segoe UI', Helvetica, Arial, sans-serif;
  --fg-mono:        ui-monospace, SFMono-Regular, 'SF Mono', Menlo,
                    Consolas, 'Liberation Mono', monospace;

  /* Override dei token globali PatternFly v5 usati dai componenti del login */
  --pf-v5-global--BackgroundColor--100: var(--fg-panel);
  --pf-v5-global--BackgroundColor--200: var(--fg-panel-inner);
  --pf-v5-global--Color--100: var(--fg-ink-strong);
  --pf-v5-global--Color--200: var(--fg-muted);
  --pf-v5-global--BorderColor--100: var(--fg-line-bright);
  --pf-v5-global--BorderColor--200: var(--fg-line);
  --pf-v5-global--primary-color--100: var(--fg-indigo);
  --pf-v5-global--primary-color--200: var(--fg-indigo-hi);
  --pf-v5-global--link--Color: var(--fg-indigo);
  --pf-v5-global--link--Color--hover: var(--fg-indigo-hi);
  --pf-v5-global--danger-color--100: var(--fg-crit);
  --pf-v5-global--success-color--100: var(--fg-good);
  --pf-v5-global--warning-color--100: var(--fg-warn);
  --pf-v5-global--FontFamily--text: var(--fg-font);
  --pf-v5-global--FontFamily--heading: var(--fg-font);

  /* Banda accento in cima alla card (keycloak.v2 la disegna su .__main-header):
     resa trasparente perché la ridisegniamo noi animata su .__main::before */
  --keycloak-card-top-color: transparent;
}

/* ── Sfondo pagina ─────────────────────────────────────────────────────────── */
html,
body#keycloak-bg {
  background:
    radial-gradient(1200px 600px at 50% -10%, #14203a 0%, var(--fg-bg) 55%, var(--fg-bg-grad) 100%) fixed;
  color: var(--fg-ink);
  font-family: var(--fg-font);
}

/* Overlay decorativo a tutto schermo: griglia di rete (firewall) + due glow
   indigo/verde sfumati ai bordi. Pseudo-elemento fisso, non intercetta i click. */
body#keycloak-bg::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    /* glow accento in alto e in basso */
    radial-gradient(620px 320px at 18% 8%,  var(--fg-indigo-soft) 0%, transparent 70%),
    radial-gradient(560px 300px at 86% 96%, rgba(61, 214, 140, 0.07) 0%, transparent 70%),
    /* griglia di rete */
    linear-gradient(to right,  var(--fg-line) 1px, transparent 1px),
    linear-gradient(to bottom, var(--fg-line) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 46px 46px, 46px 46px;
  /* la griglia sfuma verso i bordi, resta densa al centro */
  -webkit-mask-image: radial-gradient(1000px 700px at 50% 42%, #000 0%, transparent 88%);
          mask-image: radial-gradient(1000px 700px at 50% 42%, #000 0%, transparent 88%);
}

/* Fascio di scansione: linea indigo che attraversa lentamente la pagina,
   come uno scanner di sicurezza. Disattivata con prefers-reduced-motion. */
body#keycloak-bg::after {
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  height: 2px;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, var(--fg-indigo-glow), transparent);
  opacity: 0.55;
  animation: fg-scan 7s linear infinite;
}

@keyframes fg-scan {
  0%   { transform: translateY(0); opacity: 0; }
  10%  { opacity: 0.55; }
  90%  { opacity: 0.55; }
  100% { transform: translateY(100vh); opacity: 0; }
}

/* Tiene la card sopra gli overlay */
.pf-v5-c-login {
  min-height: 100vh;
  position: relative;
  z-index: 1;
}

/* ── Header / logo ─────────────────────────────────────────────────────────── */
#kc-header {
  margin-bottom: 1.25rem;
}

/* Sostituisce il displayName testuale con il logo wordmark Figaro */
#kc-header-wrapper {
  display: block;
  height: 56px;
  font-size: 0;            /* nasconde il testo del realm */
  color: transparent;
  background-image: url('../img/figaro-logo.png');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  padding: 0;
  text-indent: -9999px;
  overflow: hidden;
  filter: drop-shadow(0 6px 20px rgba(129, 140, 248, 0.22));
}

/* Tagline brand sotto il logo: payoff "secure gateway" in maiuscoletto spaziato */
#kc-header::after {
  content: "Secure Gateway · Zero-Trust LLM Access";
  display: block;
  margin-top: 0.85rem;
  text-align: center;
  font-family: var(--fg-mono);
  font-size: 0.66rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fg-muted);
  text-indent: 0;
}

/* ── Card login ────────────────────────────────────────────────────────────── */
.pf-v5-c-login__main {
  position: relative;
  background:
    linear-gradient(180deg, rgba(26, 34, 54, 0.55) 0%, rgba(22, 28, 45, 0.85) 100%),
    var(--fg-panel);
  border: 1px solid var(--fg-line-bright);
  border-radius: 10px;
  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(129, 140, 248, 0.06),
    0 0 60px -20px var(--fg-indigo-glow);
  color: var(--fg-ink);
  overflow: hidden;
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
}

/* Fascia accento animata in cima alla card (sostituisce il top-color statico) */
.pf-v5-c-login__main::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(
    90deg,
    var(--fg-indigo) 0%,
    var(--fg-good) 35%,
    var(--fg-indigo-hi) 70%,
    var(--fg-indigo) 100%);
  background-size: 250% 100%;
  animation: fg-shimmer 6s linear infinite;
}

@keyframes fg-shimmer {
  0%   { background-position: 0% 0; }
  100% { background-position: 250% 0; }
}

/* Watermark a scudo con serratura, dietro al form (decorativo, non clicabile) */
.pf-v5-c-login__main::after {
  content: "";
  position: absolute;
  right: -28px;
  bottom: -28px;
  width: 220px;
  height: 220px;
  z-index: 0;
  pointer-events: none;
  opacity: 0.06;
  background: no-repeat center / contain
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23818cf8' stroke-width='1' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2 4 5v6c0 5 3.4 8.6 8 11 4.6-2.4 8-6 8-11V5l-8-3z'/%3E%3Ccircle cx='12' cy='10.5' r='2'/%3E%3Cpath d='M12 12.5v3.5'/%3E%3C/svg%3E");
}

/* il contenuto reale sta sopra il watermark */
.pf-v5-c-login__main-header,
.pf-v5-c-login__main-body,
.pf-v5-c-login__main-footer {
  position: relative;
  z-index: 1;
  background: transparent;
}

#kc-page-title,
.pf-v5-c-login__main-header .pf-v5-c-title {
  color: var(--fg-ink-strong);
  font-family: var(--fg-font);
  font-weight: 600;
}

/* Riga di "chip" di sicurezza sotto il titolo della pagina di login */
.pf-v5-c-login__main-header::after {
  content: "🔒 TLS 1.3      🛡 WAF      🔥 Firewall LLM";
  display: block;
  margin-top: 0.6rem;
  text-align: center;
  font-family: var(--fg-mono);
  font-size: 0.64rem;
  letter-spacing: 0.04em;
  color: var(--fg-muted);
  white-space: pre;
}

.pf-v5-c-login__main-footer-band,
.pf-v5-c-login__main-footer-band-item {
  color: var(--fg-muted);
}

/* ── Etichette e testo form ────────────────────────────────────────────────── */
.pf-v5-c-form__label,
.pf-v5-c-form__label-text,
.pf-v5-c-form__group-label,
.pf-v5-c-check__label {
  color: var(--fg-ink-strong);
}

.pf-v5-c-form__label-required,
.pf-v5-c-check__label-required {
  color: var(--fg-indigo);
}

/* ── Input ─────────────────────────────────────────────────────────────────── */
.pf-v5-c-form-control,
.pf-v5-c-form-control input,
input.pf-v5-c-form-control {
  background: var(--fg-panel-inner);
  color: var(--fg-ink-strong);
  border-radius: var(--fg-radius);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  --pf-v5-c-form-control--BorderColor: var(--fg-line-bright);
  --pf-v5-c-form-control--BackgroundColor: var(--fg-panel-inner);
  --pf-v5-c-form-control--Color: var(--fg-ink-strong);
  --pf-v5-c-form-control--m-readonly--BackgroundColor: var(--fg-panel-inner);
}

.pf-v5-c-form-control:hover {
  --pf-v5-c-form-control--BorderColor: var(--fg-indigo);
}

.pf-v5-c-form-control:focus-within,
.pf-v5-c-form-control input:focus,
input.pf-v5-c-form-control:focus {
  --pf-v5-c-form-control--BorderColor: var(--fg-indigo);
  outline: none;
  box-shadow: 0 0 0 3px var(--fg-indigo-soft), 0 0 18px -6px var(--fg-indigo-glow);
}

.pf-v5-c-form-control::placeholder,
.pf-v5-c-form-control input::placeholder {
  color: var(--fg-muted);
  opacity: 1;
}

/* Selettore lingua nell'header */
#login-select-toggle {
  background: var(--fg-panel-inner);
  color: var(--fg-ink-strong);
  border: 1px solid var(--fg-line-bright);
  border-radius: var(--fg-radius);
}

/* ── Pulsanti ──────────────────────────────────────────────────────────────── */
.pf-v5-c-button.pf-m-primary {
  background: linear-gradient(180deg, var(--fg-indigo-hi) 0%, var(--fg-indigo) 100%);
  color: #0d1426;
  border-radius: var(--fg-radius);
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: transform 0.12s ease, box-shadow 0.15s ease, filter 0.15s ease;
  box-shadow: 0 6px 18px -8px var(--fg-indigo-glow);
  --pf-v5-c-button--m-primary--BackgroundColor: var(--fg-indigo);
  --pf-v5-c-button--m-primary--Color: #0d1426;
  --pf-v5-c-button--m-primary--hover--BackgroundColor: var(--fg-indigo-hi);
  --pf-v5-c-button--m-primary--active--BackgroundColor: var(--fg-indigo-hi);
}

.pf-v5-c-button.pf-m-primary:hover {
  filter: brightness(1.05);
  box-shadow: 0 10px 26px -8px var(--fg-indigo-glow);
  transform: translateY(-1px);
}

.pf-v5-c-button.pf-m-primary:active {
  transform: translateY(0);
}

.pf-v5-c-button.pf-m-secondary,
.pf-v5-c-button.pf-m-control {
  background: transparent;
  color: var(--fg-ink-strong);
  border: 1px solid var(--fg-line-bright);
  border-radius: var(--fg-radius);
  transition: border-color 0.15s ease, color 0.15s ease;
  --pf-v5-c-button--m-secondary--Color: var(--fg-ink-strong);
  --pf-v5-c-button--m-secondary--BorderColor: var(--fg-line-bright);
}

.pf-v5-c-button.pf-m-secondary:hover {
  border-color: var(--fg-indigo);
  color: var(--fg-ink-strong);
}

/* ── Link ──────────────────────────────────────────────────────────────────── */
a,
.pf-v5-c-button.pf-m-link,
.pf-v5-c-login__main-footer-links-item a {
  color: var(--fg-indigo);
}

a:hover,
.pf-v5-c-button.pf-m-link:hover {
  color: var(--fg-indigo-hi);
}

/* ── Checkbox (Ricordami) ──────────────────────────────────────────────────── */
.pf-v5-c-check__input {
  accent-color: var(--fg-indigo);
}

/* ── Alert / messaggi ──────────────────────────────────────────────────────── */
.pf-v5-c-alert {
  background: var(--fg-panel-inner);
  border: 1px solid var(--fg-line-bright);
  border-radius: var(--fg-radius);
  color: var(--fg-ink-strong);
}

.pf-v5-c-alert.pf-m-danger { border-left: 3px solid var(--fg-crit); }
.pf-v5-c-alert.pf-m-success { border-left: 3px solid var(--fg-good); }
.pf-v5-c-alert.pf-m-warning { border-left: 3px solid var(--fg-warn); }
.pf-v5-c-alert.pf-m-info { border-left: 3px solid var(--fg-indigo); }

.kc-feedback-text,
.pf-v5-c-alert__title {
  color: var(--fg-ink-strong);
}

/* ── Helper / errori di campo ──────────────────────────────────────────────── */
.kc-feedback-text.pf-m-error,
.pf-v5-c-helper-text__item.pf-m-error .pf-v5-c-helper-text__item-text {
  color: var(--fg-crit);
}

/* ── Accessibilità: niente animazioni se l'utente le ha disattivate ─────────── */
@media (prefers-reduced-motion: reduce) {
  body#keycloak-bg::after,
  .pf-v5-c-login__main::before {
    animation: none;
  }
  body#keycloak-bg::after { opacity: 0; }
  .pf-v5-c-button.pf-m-primary:hover { transform: none; }
}
