textarea{width:100%;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:12px;font-family:'Courier New',monospace;font-size:0.9rem;resize:vertical;box-sizing:border-box}textarea:focus{outline:none;border-color:var(--accent)}input[type="text"],input[type="number"],input[type="password"],input[type="time"],input[type="date"],input[type="color"],select{width:100%;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;font-size:0.9rem;box-sizing:border-box}input:focus,select:focus{outline:none;border-color:var(--accent)}.result-box{padding:16px;background:var(--surface);border:2px solid var(--accent);border-radius:var(--radius);font-size:1.2rem;font-weight:700;text-align:center;color:var(--accent);margin-top:16px;word-break:break-all}.file-list{padding:8px 0;font-size:0.85rem;color:var(--text-secondary)}.file-list li{padding:4px 0}.output-area{padding:12px;margin-top:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:0.85rem;color:var(--text-secondary);text-align:center}

/* ─── Modern SaaS Upload Card ─── */
.modern-upload {
  min-height: 220px !important;
  padding: 36px 28px !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,0.03) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border: 2px dashed rgba(255,255,255,0.08) !important;
  box-shadow:
    0 8px 32px rgba(0,0,0,0.3),
    0 0 0 1px rgba(255,255,255,0.02) inset !important;
  transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1) !important;
}

.modern-upload:hover {
  border-color: transparent !important;
  background: rgba(255,255,255,0.06) !important;
  transform: translateY(-4px) !important;
  box-shadow:
    0 16px 48px rgba(0,0,0,0.35),
    0 0 40px rgba(124,111,255,0.12),
    0 0 0 1px rgba(124,111,255,0.08) inset !important;
}

.modern-upload .file-upload-icon {
  width: 64px !important;
  height: 64px !important;
  border-radius: 20px !important;
  background: linear-gradient(135deg, rgba(124,111,255,0.15), rgba(0,212,255,0.1)) !important;
  border: 1px solid rgba(124,111,255,0.2) !important;
  margin-bottom: 8px !important;
}

.modern-upload .file-upload-icon svg {
  width: 30px !important;
  height: 30px !important;
  color: #8b7cff !important;
  filter: drop-shadow(0 0 8px rgba(124,111,255,0.3)) !important;
}

.modern-upload:hover .file-upload-icon {
  transform: scale(1.12) rotate(-4deg) !important;
  background: linear-gradient(135deg, rgba(124,111,255,0.25), rgba(0,212,255,0.18)) !important;
  border-color: rgba(124,111,255,0.4) !important;
  box-shadow: 0 0 30px rgba(124,111,255,0.2) !important;
}

.modern-upload .file-upload-title {
  font-size: 1.15rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  background: linear-gradient(135deg, #f0f0ff 0%, #c8c0ff 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

.modern-upload .file-upload-hint {
  font-size: 0.85rem !important;
  color: rgba(255,255,255,0.4) !important;
}

.modern-upload .file-upload-hint strong {
  color: #8b7cff !important;
  text-decoration: none !important;
  font-weight: 700 !important;
}

/* Floating plus button effect */
.modern-upload::after {
  content: '+' !important;
  position: absolute !important;
  top: 16px !important;
  right: 20px !important;
  width: 36px !important;
  height: 36px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #7c6fff, #5a4fff) !important;
  color: #fff !important;
  font-size: 22px !important;
  font-weight: 300 !important;
  line-height: 1 !important;
  box-shadow: 0 4px 16px rgba(124,111,255,0.35) !important;
  opacity: 0 !important;
  transform: scale(0.6) !important;
  transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1) !important;
  pointer-events: none !important;
  z-index: 2 !important;
}

.modern-upload:hover::after {
  opacity: 1 !important;
  transform: scale(1) !important;
}

/* Glow effect on hover */
.modern-upload::before {
  content: '' !important;
  position: absolute !important;
  inset: -2px !important;
  border-radius: 26px !important;
  background: linear-gradient(135deg, rgba(124,111,255,0.15), rgba(0,212,255,0.08), transparent) !important;
  opacity: 0 !important;
  transition: opacity 0.5s ease !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

.modern-upload:hover::before {
  opacity: 1 !important;
}

/* Drag over state */
.modern-upload.drag-over {
  border-color: #7c6fff !important;
  background: rgba(124,111,255,0.08) !important;
  transform: translateY(-4px) scale(1.01) !important;
  box-shadow:
    0 0 60px rgba(124,111,255,0.15),
    0 16px 48px rgba(0,0,0,0.35) !important;
}

/* Has file state */
.modern-upload.has-file {
  border-style: solid !important;
  border-color: rgba(34,197,94,0.3) !important;
  background: rgba(34,197,94,0.04) !important;
}

.modern-upload.has-file:hover {
  border-color: rgba(34,197,94,0.5) !important;
}

/* Responsive */
@media (max-width: 768px) {
  .modern-upload {
    min-height: 180px !important;
    padding: 28px 20px !important;
    border-radius: 20px !important;
  }
  .modern-upload .file-upload-icon {
    width: 54px !important;
    height: 54px !important;
    border-radius: 16px !important;
  }
  .modern-upload .file-upload-icon svg {
    width: 26px !important;
    height: 26px !important;
  }
  .modern-upload .file-upload-title {
    font-size: 1rem !important;
  }
  .modern-upload .file-upload-hint {
    font-size: 0.78rem !important;
  }
}

@media (max-width: 540px) {
  .modern-upload {
    min-height: 160px !important;
    padding: 24px 16px !important;
    border-radius: 18px !important;
  }
  .modern-upload .file-upload-icon {
    width: 48px !important;
    height: 48px !important;
    border-radius: 14px !important;
  }
  .modern-upload .file-upload-icon svg {
    width: 22px !important;
    height: 22px !important;
  }
  .modern-upload .file-upload-title {
    font-size: 0.92rem !important;
  }
  .modern-upload .file-upload-hint {
    font-size: 0.74rem !important;
  }
}
