/* ============================================================================
 * ux-tool.css — styles partagés des petits outils interactifs 5M Innov
 * (jwt-decoder, regex-tester, cron-builder). Thème-aware, look « glass ».
 * ========================================================================== */
.ux-wrap { max-width: 1100px; margin: 0 auto; padding: 6.5rem 1.2rem 5rem; text-align: left; }

.ux-hero {
  text-align: center; padding: 2.8rem 1.5rem;
  border-radius: var(--radius-glass, 22px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    radial-gradient(ellipse 75% 120% at 50% -10%, rgba(55, 239, 186, 0.18), transparent 60%),
    linear-gradient(160deg, rgba(24, 29, 40, 0.94), rgba(11, 14, 20, 0.97));
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.35), 0 0 60px rgba(55, 239, 186, 0.10);
  margin-bottom: 2rem; color: #f4fbff;
}
.ux-hero-icon {
  width: 64px; height: 64px; margin: 0 auto 1.1rem;
  display: flex; align-items: center; justify-content: center;
  border-radius: 16px; font-size: 1.8rem; color: #37EFBA;
  background: linear-gradient(140deg, rgba(55, 239, 186, 0.2), rgba(0, 212, 255, 0.12));
  border: 1px solid rgba(255, 255, 255, 0.18);
}
.ux-hero h1 { font-size: 2.2rem; margin-bottom: 0.6rem; }
.ux-hero p { opacity: 0.92; max-width: 640px; margin: 0 auto; line-height: 1.6; }

.ux-note {
  background: var(--glass-bg, rgba(20, 24, 33, 0.62));
  border: 1px solid var(--glass-border, rgba(255, 255, 255, 0.14));
  -webkit-backdrop-filter: blur(var(--glass-blur, 18px)); backdrop-filter: blur(var(--glass-blur, 18px));
  border-radius: var(--radius-glass, 18px);
  padding: 1.1rem 1.4rem; margin-bottom: 2rem; line-height: 1.65; font-size: 0.95rem;
}
.ux-note strong { color: var(--accent-text, #37EFBA); }
.ux-note--warn { border-color: rgba(55, 239, 186, 0.4); }

.ux-card {
  background: var(--glass-bg, rgba(20, 24, 33, 0.62));
  border: 1px solid var(--glass-border, rgba(255, 255, 255, 0.14));
  -webkit-backdrop-filter: blur(var(--glass-blur, 18px)); backdrop-filter: blur(var(--glass-blur, 18px));
  border-radius: var(--radius-glass, 22px); padding: 1.6rem 1.7rem;
}

.ux-field { display: flex; flex-direction: column; margin-bottom: 1rem; }
.ux-field label { font-weight: 600; font-size: 0.92rem; margin-bottom: 0.4rem; }
.ux-field textarea, .ux-field input[type="text"], .ux-field select {
  font-family: inherit; font-size: 0.95rem; color: inherit;
  background: var(--glass-bg, rgba(20, 24, 33, 0.55));
  border: 1px solid var(--glass-border, rgba(255, 255, 255, 0.16));
  border-radius: 12px; padding: 0.6rem 0.8rem; line-height: 1.5; width: 100%;
}
.ux-field textarea { resize: vertical; min-height: 3rem; }
.ux-field textarea:focus, .ux-field input:focus, .ux-field select:focus {
  outline: none; border-color: #37EFBA; box-shadow: 0 0 0 3px rgba(55, 239, 186, 0.18);
}
.ux-field input.mono, .ux-field textarea.mono { font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace; }

.ux-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; align-items: start; }
@media (max-width: 760px) { .ux-grid2 { grid-template-columns: 1fr; } }

.ux-out-label { font-weight: 600; font-size: 0.85rem; opacity: 0.78; margin-bottom: 0.4rem; text-transform: uppercase; letter-spacing: 0.03em; }
.ux-out {
  background: var(--glass-bg, rgba(14, 18, 26, 0.7));
  border: 1px solid var(--glass-border, rgba(255, 255, 255, 0.14));
  border-radius: 12px; padding: 0.9rem 1rem; margin: 0;
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
  font-size: 0.85rem; line-height: 1.55; white-space: pre-wrap; word-break: break-word;
  min-height: 2.6rem; max-height: 50vh; overflow: auto;
}
.ux-out--sm { font-size: 0.78rem; min-height: auto; }
.ux-out:focus-visible { outline: 2px solid #37EFBA; outline-offset: 2px; }

.ux-error { color: var(--bad-text, #ff7a7a); font-weight: 600; min-height: 1.2rem; margin: 0.2rem 0 0.6rem; }

.ux-claims { list-style: none; padding: 0; margin: 0; }
.ux-claims li {
  padding: 0.45rem 0.7rem; border-radius: 10px; margin-bottom: 0.4rem;
  background: rgba(55, 239, 186, 0.08); border: 1px solid rgba(55, 239, 186, 0.18);
  font-size: 0.9rem; word-break: break-word;
}
.ux-claims strong { color: var(--accent-text, #37EFBA); }
.ux-groups { font-size: 0.82rem; opacity: 0.85; margin-top: 0.25rem; font-family: "SFMono-Regular", Consolas, monospace; }

/* ---- boutons (réutilisés) ---- */
.btn-primary, .btn-ghost {
  font-family: inherit; font-weight: 600; font-size: 0.85rem; cursor: pointer;
  display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.5rem 1rem; border-radius: 999px;
  transition: filter 0.2s ease, border-color 0.2s ease; appearance: none;
}
.btn-primary { color: #25282f; border: 1px solid transparent; background: linear-gradient(135deg, #37EFBA, #00d4aa); }
.btn-primary:hover:not(:disabled) { filter: brightness(1.06); transform: none; box-shadow: none; }
.btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-ghost { background: transparent; color: inherit; border: 1px solid var(--glass-border, rgba(255, 255, 255, 0.2)); }
.btn-ghost:hover { border-color: #37EFBA; }
.btn-primary:focus-visible, .btn-ghost:focus-visible { outline: 2px solid #37EFBA; outline-offset: 2px; }
.copy-status { display: inline-block; margin-left: 0.6rem; font-size: 0.85rem; color: var(--accent-text, #37EFBA); font-weight: 600; }

/* ---- regex ---- */
.ux-flags { display: flex; flex-wrap: wrap; gap: 0.8rem; margin: 0.2rem 0 1rem; }
.ux-flags label { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.9rem; font-weight: 600; }
.ux-highlight {
  background: var(--glass-bg, rgba(14, 18, 26, 0.7));
  border: 1px solid var(--glass-border, rgba(255, 255, 255, 0.14));
  border-radius: 12px; padding: 0.9rem 1rem; line-height: 1.6; white-space: pre-wrap;
  word-break: break-word; min-height: 3rem; max-height: 40vh; overflow: auto; font-size: 0.92rem;
}
.ux-highlight mark { background: rgba(55, 239, 186, 0.35); color: inherit; border-radius: 3px; padding: 0 1px; }
.ux-count { font-size: 0.9rem; opacity: 0.85; margin: 0.6rem 0; }
.ux-count strong { color: var(--accent-text, #37EFBA); }

/* ---- cron ---- */
.ux-cron-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0.7rem; margin-bottom: 1rem; }
@media (max-width: 620px) { .ux-cron-grid { grid-template-columns: repeat(2, 1fr); } }
.ux-cron-grid .ux-field { margin-bottom: 0; }
.ux-cron-grid label { font-size: 0.82rem; }
.ux-presets { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1.3rem; }
.ux-preset {
  font-family: inherit; font-size: 0.82rem; font-weight: 600; cursor: pointer;
  padding: 0.35rem 0.85rem; border-radius: 999px; appearance: none;
  background: transparent; color: inherit; border: 1px solid var(--glass-border, rgba(255, 255, 255, 0.22));
}
.ux-preset:hover { border-color: #37EFBA; }
.ux-cron-expr {
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
  font-size: 1.4rem; font-weight: 700; color: var(--accent-text, #37EFBA);
  background: var(--glass-bg, rgba(14, 18, 26, 0.7));
  border: 1px solid rgba(55, 239, 186, 0.3); border-radius: 12px;
  padding: 0.9rem 1rem; text-align: center; letter-spacing: 0.04em; word-break: break-all;
}
.ux-desc { margin: 0.9rem 0 0; line-height: 1.6; font-size: 1.02rem; }
.ux-desc strong { color: var(--accent-text, #37EFBA); }

.ux-back { margin-top: 2.2rem; }
.ux-back a { color: var(--accent-text, #37EFBA); font-weight: 600; text-decoration: none; display: inline-flex; align-items: center; gap: 0.4rem; }
.ux-back a:hover { text-decoration: underline; }
