/* ============================================================
   upload.css — Foto-Upload · 99 < x < 100 · 90s Neon
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --pink:      #ff00cc;
  --pink-dim:  #cc0099;
  --cyan:      #00ffff;
  --green:     #00ff41;
  --orange:    #f97316;
  --yellow:    #e8ff00;
  --bg:        #070010;
  --bg2:       #0d001f;
  --card:      rgba(20,0,45,0.7);
  --border:    rgba(255,0,204,0.35);
  --text:      #c8b0e8;
  --text-dim:  #9070b0;
  --font:      -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  --mono:      'Courier New', Courier, monospace;
}

html { scroll-behavior: smooth; }
body {
  font-family: var(--font);
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(255,0,204,0.20) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 100% 100%, rgba(0,255,255,0.10) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 0% 80%, rgba(232,255,0,0.08) 0%, transparent 60%),
    linear-gradient(180deg, #14003a 0%, #070010 100%);
  background-attachment: fixed;
  color: var(--text);
  line-height: 1.6;
  min-height: 100vh;
  padding: 2.5rem 1rem 4rem;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--pink); text-decoration: none; }
a:hover { text-decoration: underline; }
strong { color: #fff; }

/* ── SCANLINES ── */
.scanlines {
  position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  background: repeating-linear-gradient(
    0deg, transparent, transparent 2px,
    rgba(0,0,0,0.15) 2px, rgba(0,0,0,0.15) 4px
  );
  mask-image: linear-gradient(to bottom, black 30%, transparent 55%);
  -webkit-mask-image: linear-gradient(to bottom, black 30%, transparent 55%);
}

/* ── RB'S BANNER ── */
.rbs-banner {
  position: fixed; top: 0; left: 0; right: 0; z-index: 3000;
  text-align: center; padding: 0.25rem 1rem;
  font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--pink);
  background: rgba(7,0,16,0.82); border-bottom: 1px solid rgba(255,0,204,0.2);
  backdrop-filter: blur(8px); user-select: none; pointer-events: none;
}

/* ── LAYOUT ── */
.upload-wrap {
  max-width: 560px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 1.5rem;
}

.upload-head {
  display: flex; flex-direction: column; align-items: center;
  padding-top: 0.5rem; gap: 0.6rem;
}
.upload-back {
  align-self: flex-start;
  font-family: var(--mono); font-size: 0.78rem; font-weight: 700;
  color: var(--cyan); padding: 0.45rem 1rem;
  border: 1.5px solid var(--cyan); border-radius: 50px;
  letter-spacing: 0.08em; text-decoration: none;
  margin-bottom: 1.4rem;
  transition: background 0.15s, color 0.15s;
}
.upload-back:hover { background: var(--cyan); color: #000; text-decoration: none; }

.upload-title {
  font-size: clamp(1.8rem, 7vw, 2.6rem); font-weight: 900;
  color: #fff; letter-spacing: 0.02em; margin-bottom: 0.6rem;
  text-shadow: 0 0 14px rgba(255,0,204,0.55), 0 0 30px rgba(255,0,204,0.25);
}
.upload-sub { color: var(--text); font-size: 0.95rem; max-width: 38ch; margin: 0 auto; }

/* ── GLITCH (subtle) ── */
.glitch { position: relative; display: inline-block; }
.glitch::before, .glitch::after {
  content: attr(data-text); position: absolute; left: 0; top: 0;
  width: 100%; pointer-events: none;
}
.glitch::before { color: var(--cyan); transform: translate(-1px, 0); mix-blend-mode: screen; opacity: 0.6; }
.glitch::after  { color: var(--yellow); transform: translate(1px, 0);  mix-blend-mode: screen; opacity: 0.4; }

/* ── CARD ── */
.upload-card, .success-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 1.4rem;
  backdrop-filter: blur(6px);
  box-shadow: 0 6px 30px rgba(255,0,204,0.12);
}

/* ── PICKERS ── */
.picker-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
@media (max-width: 380px) { .picker-row { grid-template-columns: 1fr; } }

.picker-btn {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; gap: 0.2rem;
  padding: 1.2rem 0.8rem; min-height: 130px;
  border-radius: 14px; cursor: pointer;
  border: 1.5px solid var(--border);
  background: rgba(7,0,16,0.5);
  transition: transform 0.15s, border-color 0.15s, background 0.15s, box-shadow 0.15s;
  user-select: none; -webkit-tap-highlight-color: transparent;
}
.picker-btn:active { transform: scale(0.97); }
.picker-btn--primary {
  border-color: var(--pink);
  background: linear-gradient(180deg, rgba(255,0,204,0.18), rgba(255,0,204,0.05));
  box-shadow: inset 0 0 24px rgba(255,0,204,0.15), 0 0 18px rgba(255,0,204,0.18);
}
.picker-btn--secondary {
  border-color: rgba(0,255,255,0.45);
  background: linear-gradient(180deg, rgba(0,255,255,0.10), rgba(0,255,255,0.02));
}
.picker-btn--primary:hover { box-shadow: inset 0 0 30px rgba(255,0,204,0.22), 0 0 26px rgba(255,0,204,0.30); }
.picker-btn--secondary:hover { border-color: var(--cyan); }

.picker-emoji { font-size: 2.2rem; line-height: 1; }
.picker-label { font-size: 1.05rem; font-weight: 700; color: #fff; letter-spacing: 0.03em; }
.picker-hint  { font-size: 0.72rem; color: var(--text-dim); font-family: var(--mono); }

/* ── PREVIEW ── */
.preview-area { margin-top: 1.2rem; }
.preview-count {
  font-family: var(--mono); font-size: 0.78rem; color: var(--cyan);
  letter-spacing: 0.05em; margin-bottom: 0.6rem;
}
.preview-grid {
  display: grid; gap: 0.4rem;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  margin-bottom: 0.8rem;
}
.preview-thumb {
  position: relative; aspect-ratio: 1 / 1;
  border-radius: 10px; overflow: hidden;
  border: 1px solid var(--border);
  background: #000;
}
.preview-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.preview-thumb__rm {
  position: absolute; top: 4px; right: 4px;
  width: 24px; height: 24px; border-radius: 50%;
  background: rgba(0,0,0,0.75); color: #fff;
  border: 1px solid rgba(255,0,204,0.5);
  font-size: 14px; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
}
.preview-thumb__rm:hover { background: var(--pink); }
.preview-thumb__pending {
  position: absolute; inset: 0; background: rgba(0,0,0,0.55);
  display: flex; align-items: center; justify-content: center;
  color: var(--cyan); font-family: var(--mono); font-size: 0.7rem;
}
.preview-thumb--done .preview-thumb__pending { color: var(--green); background: rgba(0,40,10,0.55); }
.preview-thumb--err  .preview-thumb__pending { color: #ff3366; background: rgba(40,0,10,0.65); }

.btn-clear {
  background: transparent; color: var(--text-dim);
  border: 1px solid rgba(255,0,204,0.25); border-radius: 50px;
  padding: 0.4rem 1rem; font-family: var(--mono); font-size: 0.72rem;
  letter-spacing: 0.08em; cursor: pointer; text-transform: uppercase;
}
.btn-clear:hover { color: var(--pink); border-color: var(--pink); }

/* ── TURNSTILE ── */
.turnstile-area {
  margin-top: 1.2rem;
  display: flex; justify-content: center;
}
.turnstile-area .cf-turnstile { display: flex; justify-content: center; }

/* ── SUBMIT ── */
.submit-area { margin-top: 0.6rem; display: flex; flex-direction: column; gap: 0.8rem; align-items: stretch; }

.btn-upload {
  background: linear-gradient(135deg, var(--pink), #ff44dd);
  color: #fff; border: none; border-radius: 50px;
  padding: 1rem 1.6rem; font-size: 1.05rem; font-weight: 700;
  letter-spacing: 0.05em; cursor: pointer;
  box-shadow: 0 0 18px rgba(255,0,204,0.45), inset 0 0 22px rgba(255,255,255,0.12);
  transition: transform 0.1s, box-shadow 0.15s, opacity 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.btn-upload:hover:not(:disabled) { box-shadow: 0 0 28px rgba(255,0,204,0.65), inset 0 0 30px rgba(255,255,255,0.18); }
.btn-upload:active:not(:disabled) { transform: scale(0.98); }
.btn-upload:disabled { opacity: 0.55; cursor: not-allowed; }

.dots-anim::after {
  content: '...'; display: inline-block; width: 1.2em; text-align: left;
  animation: dots 1.2s steps(4, end) infinite;
}
@keyframes dots { 0% { content: ''; } 25% { content: '.'; } 50% { content: '..'; } 75%, 100% { content: '...'; } }

/* ── PROGRESS ── */
.upload-progress { display: flex; flex-direction: column; gap: 0.4rem; }
.upload-progress__bar {
  position: relative; height: 8px; border-radius: 8px;
  background: rgba(255,255,255,0.08); overflow: hidden;
  border: 1px solid var(--border);
}
.upload-progress__bar > span {
  position: absolute; left: 0; top: 0; bottom: 0; width: 0%;
  background: linear-gradient(90deg, var(--pink), var(--cyan));
  transition: width 0.3s ease;
}
.upload-progress__txt {
  font-family: var(--mono); font-size: 0.75rem; color: var(--text-dim);
  text-align: center; letter-spacing: 0.05em;
}

.upload-error {
  background: rgba(255,0,60,0.12); border: 1px solid rgba(255,0,60,0.5);
  color: #ff8aa8; padding: 0.7rem 0.9rem; border-radius: 10px;
  font-size: 0.85rem; text-align: center;
}

/* ── SUCCESS ── */
.success-card { text-align: center; }
.success-emoji { font-size: 3rem; margin-bottom: 0.4rem; }
.success-title {
  font-size: 1.8rem; color: var(--green); font-weight: 900;
  text-shadow: 0 0 14px rgba(0,255,65,0.55); margin-bottom: 0.4rem;
}
.success-msg { color: var(--text); margin-bottom: 1.2rem; }

.btn-again {
  background: transparent; color: var(--cyan);
  border: 1.5px solid var(--cyan); border-radius: 50px;
  padding: 0.7rem 1.4rem; font-weight: 700; letter-spacing: 0.04em;
  cursor: pointer; transition: background 0.15s, color 0.15s;
}
.btn-again:hover { background: var(--cyan); color: #000; }

/* ── FOOT ── */
.upload-foot {
  text-align: center; font-family: var(--mono);
  font-size: 0.7rem; color: var(--text-dim);
  letter-spacing: 0.08em; margin-top: 1rem;
}
