/* transfert.darkvalley.fr — branding Darkvalley
   Palette + logo de darkvalley.fr ; fond « modèle Chromatik » (blobs + frost +
   vignette + grain) recoloré vert ; disposition centrée façon page d'auth. */
:root {
  --dv-bg:        #0a1810;
  --dv-bg-2:      #0f1a14;
  --dv-surface:   #11201a;
  --dv-surface-2: #16271f;
  --dv-border:    #243a30;
  --dv-text:      #eef3ee;
  --dv-muted:     #8fbeb3;
  --dv-accent:    #a0e060;   /* vert des boutons Darkvalley */
  --dv-accent-2:  #6fcfb0;
  --dv-teal:      #668C82;
  --dv-ink:       #08160e;
  --dv-danger:    #ff6b6b;
  --dv-ok:        #a0e060;
  --dv-warn:      #e8cd6a;
  --radius: 14px;
  --radius-sm: 9px;
  --font: 'DM Sans', -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, Menlo, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font);
  color: var(--dv-text);
  background: var(--dv-bg);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

/* ── Fond aurora — modèle Chromatik, palette verte, intensité calmée ──── */
.aurora { position: fixed; inset: 0; z-index: 0; overflow: hidden; background: var(--dv-bg); pointer-events: none; }
.aurora .blob { position: absolute; border-radius: 50%; will-change: transform; mix-blend-mode: screen; }
.aurora .b1 { width:70vw; height:70vw; top:-20%; right:-10%; filter:blur(70px); background:radial-gradient(circle at 50% 50%,rgba(160,224,96,.55) 0%,rgba(90,150,60,.32) 38%,transparent 64%); animation:b1 16s ease-in-out infinite alternate; }
.aurora .b2 { width:55vw; height:55vw; top:8%; left:24%; filter:blur(64px); background:radial-gradient(circle at 50% 50%,rgba(111,207,176,.5) 0%,rgba(60,150,120,.26) 42%,transparent 66%); animation:b2 20s ease-in-out infinite alternate; }
.aurora .b3 { width:62vw; height:62vw; top:-12%; left:-12%; filter:blur(88px); background:radial-gradient(circle at 50% 50%,rgba(42,140,122,.48) 0%,rgba(20,70,55,.26) 46%,transparent 68%); animation:b3 14s ease-in-out infinite alternate; }
.aurora .b4 { width:48vw; height:48vw; bottom:2%; right:4%; filter:blur(72px); background:radial-gradient(circle at 50% 50%,rgba(102,140,130,.5) 0%,rgba(40,100,80,.24) 45%,transparent 66%); animation:b4 18s ease-in-out infinite alternate; }
.aurora .b5 { width:40vw; height:40vw; top:30%; left:0; filter:blur(56px); background:radial-gradient(circle at 50% 50%,rgba(181,212,200,.36) 0%,rgba(120,170,150,.13) 45%,transparent 58%); animation:b5 22s ease-in-out infinite alternate; }
.aurora .frost { position:absolute; inset:0; -webkit-backdrop-filter:blur(50px) saturate(1.12); backdrop-filter:blur(50px) saturate(1.12); }
.aurora .vignette { position:absolute; inset:0; background:radial-gradient(ellipse at 50% 36%, transparent 30%, rgba(7,18,12,.58) 72%, rgba(7,18,12,.97) 100%); }
.aurora .grain { position:absolute; inset:0; opacity:.045; mix-blend-mode:overlay; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); background-size:190px; }
@keyframes b1 { from{transform:translate(0,0) scale(1);} to{transform:translate(-12%,14%) scale(1.18);} }
@keyframes b2 { from{transform:translate(0,0) scale(1);} to{transform:translate(14%,-12%) scale(.85);} }
@keyframes b3 { from{transform:translate(0,0) scale(1);} to{transform:translate(16%,10%) scale(1.16);} }
@keyframes b4 { from{transform:translate(0,0) scale(1);} to{transform:translate(-12%,-16%) scale(1.22);} }
@keyframes b5 { from{transform:translate(0,0) scale(1);} to{transform:translate(11%,14%) scale(.86);} }
@media (max-width:768px){ .aurora .blob{animation:none;} }
@media (prefers-reduced-motion:reduce){ .aurora .blob{animation:none;} }

/* ── Colonne centrée ─────────────────────────────────────────────────── */
.wrap { max-width: 560px; margin: 0 auto; padding: 48px 20px; position: relative; z-index: 1; }
.wrap--wide { max-width: 1080px; }

/* ── Organisation façon page d'auth chromatik.darkvalley.fr (page de dépôt) */
.auth-stack { position: relative; z-index: 1; min-height: 100vh; box-sizing: border-box;
  display: flex; flex-direction: column; align-items: center; padding: 16px 20px; }
.auth-top { flex: 1 1 auto; display: flex; align-items: center; justify-content: center; width: 100%; min-height: 84px; }
.brand-hero-logo { width: 100%; max-width: 396px; height: auto; opacity: .98; filter: drop-shadow(0 4px 24px rgba(0,0,0,.45)); }
.auth-mid { flex: 0 0 auto; width: 100%; display: flex; flex-direction: column; align-items: center; }
.auth-foot { flex: 1 1 auto; display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 9.5px; letter-spacing: .24em; text-transform: uppercase; color: rgba(255,255,255,.38); }

h1 { font-size: 22px; line-height: 1.15; margin: 0 0 7px; letter-spacing: -.01em; font-weight: 500; }
.lead { color: var(--dv-muted); font-size: 13.5px; line-height: 1.5; margin: 0 auto; max-width: 42ch; }
.card-h1 { font-size: 17px; text-align: center; margin: 0 0 4px; font-weight: 600; line-height: 1.2; }
.card-hint { color: var(--dv-muted); font-size: 13px; text-align: center; margin: 0 0 16px; line-height: 1.5; }

/* brand line interne (login / topbar dashboard) */
.brand { margin-bottom: 26px; display: flex; align-items: center; gap: 12px; }
.brand .logo { height: 30px; width: auto; display: block; }
.brand .suffix { font-size: 12px; letter-spacing: .26em; text-transform: uppercase; color: var(--dv-muted); }

.card {
  background: rgba(255,255,255,.058);
  -webkit-backdrop-filter: blur(22px) saturate(1.15); backdrop-filter: blur(22px) saturate(1.15);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 20px;
  padding: 22px;
  box-shadow: 0 28px 60px -30px rgba(0,0,0,.6);
}
.auth-mid .card { width: 100%; max-width: 396px; box-sizing: border-box; }

.field { margin-bottom: 14px; }
.field label { display: block; font-size: 12.5px; font-weight: 500; margin-bottom: 6px; color: var(--dv-text); }
.field .hint { color: var(--dv-muted); font-weight: 400; }
input[type=email], input[type=text], textarea {
  width: 100%; padding: 10px 13px; font-size: 14px; font-family: var(--font);
  color: var(--dv-text); background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-sm);
  transition: border-color .15s, box-shadow .15s;
}
input:focus, textarea:focus {
  outline: none; border-color: var(--dv-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--dv-accent) 22%, transparent);
}
textarea { resize: vertical; min-height: 54px; }

/* Turnstile en pleine largeur (size:flexible) — aligné sur les champs */
.turnstile-row { margin: 14px 0; min-height: 66px; }

.note { font-size: 11.5px; color: var(--dv-muted); margin-top: 13px; line-height: 1.45; }
.note code { font-family: var(--mono); color: var(--dv-text); }

/* Bouton d'envoi — modèle chromatik.darkvalley.fr (gradient + glow), en vert */
.btn.btn-send {
  display: block; width: 100%; margin-top: 16px;
  padding: 13px; border: 0; border-radius: 10px; cursor: pointer;
  font-weight: 600; font-size: 14px; color: var(--dv-ink); text-align: center;
  background: linear-gradient(120deg, #7cc23d, var(--dv-accent) 55%, #bdee84);
  box-shadow: 0 6px 20px rgba(160,224,96,.3);
  transition: filter .2s, transform .05s;
}
.btn.btn-send:hover { filter: brightness(1.06); }
.btn.btn-send:active { transform: translateY(1px); }

.done { text-align: center; padding: 14px 8px; }
.done .check {
  width: 56px; height: 56px; border-radius: 50%; margin: 0 auto 16px;
  display: grid; place-items: center; position: relative;
  background: color-mix(in srgb, var(--dv-ok) 16%, transparent);
  color: var(--dv-ok); font-size: 28px;
  animation: pop .5s cubic-bezier(.2,.8,.2,1) both;
}
.done .check::before {
  content: ""; position: absolute; inset: -2px; border-radius: 50%;
  border: 2px solid var(--dv-ok); animation: ring 1s ease-out .15s both;
}
@keyframes pop { 0% { transform: scale(0); opacity: 0; } 60% { transform: scale(1.12); } 100% { transform: scale(1); opacity: 1; } }
@keyframes ring { 0% { transform: scale(1); opacity: .7; } 100% { transform: scale(1.7); opacity: 0; } }
.hidden { display: none !important; }

.uppy-Dashboard-inner { background: rgba(0,0,0,.22) !important; border-color: rgba(255,255,255,.12) !important; }
.uppy-StatusBar-progress, .uppy-StatusBar.is-complete .uppy-StatusBar-progress { background-color: var(--dv-accent) !important; }
.uppy-StatusBar-actionBtn--upload, .uppy-c-btn-primary { background-color: var(--dv-accent) !important; color: var(--dv-ink) !important; }
.uppy-Dashboard-Item-progressIndicator { color: var(--dv-accent) !important; }
.uppy-Dashboard-browse { color: #fff !important; }
.uppy-Dashboard-browse:hover { border-bottom-color: #fff !important; }
/* supprimer tout le bleu d'Uppy (liens / actions) */
.uppy-c-btn-link, .uppy-DashboardContent-back, .uppy-DashboardContent-addMore,
.uppy-DashboardContent-addMoreCaption, .uppy-Dashboard-Item-action,
.uppy-StatusBar-actionBtn, .uppy-Dashboard-AddFiles-info button { color: var(--dv-accent) !important; }
.uppy-Dashboard-Item-action--remove { color: var(--dv-muted) !important; }

/* État + animation d'upload (barre brandée) */
.up-status { margin-top: 14px; }
.up-bar { height: 6px; border-radius: 999px; background: rgba(255,255,255,.08); overflow: hidden; }
.up-bar-fill { height: 100%; width: 0; border-radius: 999px; background: var(--dv-accent); transition: width .25s ease; position: relative; overflow: hidden; }
.up-bar-fill::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent); transform: translateX(-100%); animation: shimmer 1.1s linear infinite; }
.up-meta { display: flex; justify-content: space-between; margin-top: 8px; font-size: 12.5px; color: var(--dv-muted); }
.up-meta #up-pct { color: var(--dv-text); font-family: var(--mono); }
.up-status.is-error .up-bar-fill { background: var(--dv-danger); }
.up-status.is-error .up-bar-fill::after, .up-status.is-done .up-bar-fill::after { display: none; }
.up-status.is-error #up-label { color: var(--dv-danger); }
@keyframes shimmer { to { transform: translateX(100%); } }
@media (prefers-reduced-motion: reduce) { .up-bar-fill::after { animation: none; } }

/* ── dashboard ── */
.topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 26px; }
.topbar a { color: var(--dv-muted); text-decoration: none; font-size: 13px; }
.topbar a:hover { color: var(--dv-text); }

table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
th, td { text-align: left; padding: 11px 12px; border-bottom: 1px solid var(--dv-border); }
th { color: var(--dv-muted); font-weight: 500; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
td .sub { color: var(--dv-muted); font-size: 12px; }
tr:hover td { background: rgba(255,255,255,.025); }

.pill { display: inline-block; padding: 2px 9px; border-radius: 999px; font-size: 11.5px; font-weight: 500; border: 1px solid transparent; }
.pill.clean   { color: var(--dv-ok);     background: color-mix(in srgb, var(--dv-ok) 16%, transparent); }
.pill.infected{ color: var(--dv-danger); background: color-mix(in srgb, var(--dv-danger) 14%, transparent); }
.pill.pending,.pill.error,.pill.skipped { color: var(--dv-warn); background: color-mix(in srgb, var(--dv-warn) 14%, transparent); }
.loc { font-family: var(--mono); font-size: 11.5px; color: var(--dv-muted); }

.btn {
  display: inline-block; padding: 7px 14px; border-radius: var(--radius-sm);
  background: var(--dv-accent); color: var(--dv-ink); font-weight: 500;
  font-size: 13px; text-decoration: none; border: 0; cursor: pointer;
}
.btn:hover { filter: brightness(1.06); }
.btn[disabled], .btn.muted { background: var(--dv-surface-2); color: var(--dv-muted); pointer-events: none; }

.empty { text-align: center; color: var(--dv-muted); padding: 60px 0; }

.login-card { max-width: 360px; margin: 0 auto; }
