:root {
  --bg: #f7fbff;
  --bg-grad-1: #f7fbff;
  --bg-grad-2: #eaf2ff;
  --text: #0f172a;
  --muted: #475569;
  --primary: #2563eb;
  --primary-press: #1d4ed8;
  --border: #e5e7eb;
  --surface: #ffffff;
  --surface-elev: #ffffff;
  --radius: 16px;
  --space-1: 8px;
  --space-2: 12px;
  --space-3: 16px;
  --space-4: 24px;
  --fs-1: 14px;
  --fs-2: 16px;
  --fs-3: 24px;
  --container: 760px;
  --shadow-1: 0 8px 28px rgba(27, 66, 142, .12);
  --shadow-2: 0 16px 34px rgba(27, 66, 142, .18);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body { font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; margin: 0; background: radial-gradient(1200px circle at 0% 0%, var(--bg-grad-2), var(--bg-grad-1)); color: var(--text); }
.container { max-width: var(--container); margin: 0 auto; padding: var(--space-4) var(--space-3); min-height: 100dvh; display: grid; align-content: center; gap: var(--space-4); }
.header { text-align: center; display: flex; align-items: center; justify-content: center; gap: 12px; position: relative; }
.brand-logo { width: 40px; height: 40px; filter: drop-shadow(0 6px 14px rgba(37,99,235,.25)); }
.title { font-size: calc(var(--fs-3) + 8px); margin: 0; letter-spacing: .4px; font-weight: 800; background: linear-gradient(90deg, #60a5fa, #2563eb, #1e3a8a); -webkit-background-clip: text; background-clip: text; color: transparent; animation: title-shift 6s ease-in-out infinite alternate; text-shadow: 0 2px 0 rgba(255,255,255,.4); }
@keyframes title-shift { 0% { background-position: 0% 50%; } 100% { background-position: 100% 50%; } }

/* Language switch in header */
.header .lang-switch {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}

.view { background: var(--surface); padding: var(--space-4); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-2); }
.field-row { display: grid; grid-template-columns: 1fr auto auto; gap: var(--space-2); align-items: center; }
.input { padding: var(--space-2); font-size: var(--fs-2); border: 1px solid var(--border); border-radius: var(--radius); width: 100%; color: var(--text); background: var(--surface-elev); }
.key-row { margin-bottom: var(--space-3); }
.key-badge { display: inline-block; padding: 6px 12px; border-radius: 999px; background: #e0ecff; color: #1e3a8a; font-size: var(--fs-1); border: 1px solid #cfe1ff; }
.actions { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2); margin-top: var(--space-2); }
.btn { appearance: none; border: 1px solid #cfe1ff; background: #ffffff; color: #0b1b2b; border-radius: var(--radius); padding: 14px var(--space-3); font-size: var(--fs-2); min-height: 48px; cursor: pointer; transition: transform .08s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease; box-shadow: var(--shadow-1); display: inline-flex; align-items: center; gap: 10px; justify-content: center; }
.btn:hover { background: #f0f6ff; box-shadow: var(--shadow-2); border-color: #bcd6ff; }
.btn:focus-visible { outline: 3px solid #93c5fd; outline-offset: 2px; }
.btn:active { transform: translateY(1px); }
.btn[disabled] { opacity: .6; cursor: not-allowed; }
.btn-primary { background: linear-gradient(135deg, #60a5fa, #2563eb); color: #fff; border-color: #2563eb; }
.btn-primary:hover { background: linear-gradient(135deg, #3b82f6, #1d4ed8); }
.msg { margin-top: var(--space-2); font-size: var(--fs-1); color: var(--muted); min-height: 1em; }
.icon { width: 20px; height: 20px; display: inline-block; }

.section-header {
  font-size: var(--fs-2);
  font-weight: 600;
  color: var(--text);
  margin-bottom: var(--space-2);
}

/* Password row */
.password-row {
  margin-top: var(--space-2);
}

/* Password prompt */
.password-prompt {
  text-align: center;
  padding: var(--space-4) 0;
}
.password-prompt p {
  color: var(--muted);
  margin: 0 0 var(--space-3) 0;
}
.password-prompt .field-row {
  max-width: 400px;
  margin: 0 auto;
}

/* Textarea */
.textarea {
  width: 100%;
  padding: var(--space-2);
  font-size: var(--fs-2);
  font-family: inherit;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  background: var(--surface-elev);
  resize: vertical;
  min-height: 120px;
}
.textarea:focus {
  outline: 2px solid var(--primary);
  outline-offset: -1px;
  border-color: var(--primary);
}

/* Content section */
.content-section {
  margin-bottom: var(--space-3);
}

/* Drop zone */
.drop-zone {
  border: 2px dashed var(--border);
  border-radius: var(--radius);
  padding: var(--space-4);
  text-align: center;
  color: var(--muted);
  cursor: pointer;
  transition: border-color .2s ease, background .2s ease;
  position: relative;
}
.drop-zone:hover {
  border-color: var(--primary);
  background: #f0f6ff;
}
.drop-zone.drag-over {
  border-color: var(--primary);
  background: #e0ecff;
}

.file-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

/* File list */
.file-list {
  display: grid;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.file-item {
  padding: var(--space-3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface-elev);
}
.file-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.file-info-text {
  font-size: var(--fs-1);
  color: var(--muted);
}
.file-info-name {
  font-weight: 600;
  color: var(--text);
}
.image-preview {
  max-width: 100%;
  max-height: 300px;
  border-radius: 8px;
  margin-bottom: var(--space-2);
  display: block;
}
.file-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.file-actions .btn {
  padding: 8px 16px;
  min-height: 36px;
  font-size: var(--fs-1);
}
.btn-danger {
  background: #fff;
  color: #dc2626;
  border-color: #fca5a5;
}
.btn-danger:hover {
  background: #fef2f2;
  border-color: #f87171;
}

/* History */
.history { margin-top: var(--space-3); display: grid; gap: var(--space-2); }
.history-header { font-size: var(--fs-2); color: var(--text); font-weight: 600; }
.history-list { display: grid; gap: var(--space-2); }
.history-item { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: var(--space-2); padding: var(--space-2); border: 1px solid var(--border); border-radius: var(--radius); background: var(--surface-elev); }
.history-text { font-size: var(--fs-1); color: var(--muted); overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.history-copy-btn { padding: 8px 12px; min-height: 36px; }

/* Notice */
.notice {
  background: linear-gradient(135deg, #f0f9ff, #e0f2fe);
  border: 1px solid #7dd3fc;
  border-radius: var(--radius);
  padding: var(--space-3);
}
.notice-title {
  font-size: var(--fs-2);
  font-weight: 600;
  color: #0369a1;
  margin-bottom: var(--space-1);
}
.notice-list {
  margin: 0;
  padding-left: 20px;
  font-size: var(--fs-1);
  color: #0c4a6e;
  line-height: 1.6;
}
.notice-list li {
  margin-bottom: 4px;
}

/* Language switch */
.lang-switch {
  display: flex;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.lang-btn {
  appearance: none;
  border: none;
  background: var(--surface);
  color: var(--muted);
  padding: 6px 12px;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.15s ease;
}
.lang-btn:hover {
  background: #f0f6ff;
}
.lang-btn.active {
  background: var(--primary);
  color: #fff;
}

/* Footer */
.footer {
  text-align: center;
  font-size: var(--fs-1);
  color: var(--muted);
  padding: var(--space-2) 0;
}
.footer a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
}
.footer a:hover {
  text-decoration: underline;
}
