@import url('https://fonts.googleapis.com/css2?family=UnifrakturCook:wght@700&family=Inter:wght@400;500;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --bg-1: #0a0612;
  --bg-2: #1a0a2e;
  --bg-3: #2a1640;
  --surface: rgba(42, 22, 64, 0.6);
  --surface-strong: rgba(58, 30, 84, 0.85);
  --border: #3d1f5c;
  --border-glow: rgba(255, 119, 168, 0.4);
  --text: #f5f0ff;
  --dim: #b8a8d8;
  --pink: #ff77a8;
  --pink-soft: #ffb3d9;
  --lavender: #c084fc;
  --err: #ff5577;
  --warn: #ffb84d;
  --ok: #a8ffb3;
  --pink-glow: 0 0 18px rgba(255, 119, 168, 0.45);
  --lav-glow: 0 0 18px rgba(192, 132, 252, 0.45);
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0; height: 100%;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  color: var(--text);
  overflow: hidden;
}

body {
  background:
    radial-gradient(ellipse at top, rgba(192, 132, 252, 0.12), transparent 60%),
    radial-gradient(ellipse at bottom, rgba(255, 119, 168, 0.10), transparent 60%),
    linear-gradient(135deg, var(--bg-1), var(--bg-2), var(--bg-3));
  background-attachment: fixed;
}

.sparkles {
  position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden;
}

.sparkle {
  position: absolute;
  width: 4px; height: 4px;
  background: var(--pink-soft);
  border-radius: 50%;
  box-shadow: 0 0 6px var(--pink-soft), 0 0 12px var(--pink);
  animation: twinkle 4s infinite ease-in-out;
}

@keyframes twinkle {
  0%, 100% { transform: scale(0.5); opacity: 0.2; }
  50%      { transform: scale(1.2); opacity: 0.9; }
}

.logo {
  font-family: 'UnifrakturCook', serif;
  font-weight: 700;
  font-size: 2.6rem;
  text-align: center;
  margin: 0 0 0.4rem;
  color: var(--pink);
  text-shadow: 0 0 12px var(--pink), 0 0 28px rgba(192, 132, 252, 0.6);
  letter-spacing: 0.02em;
}

.logo-sm {
  font-size: 1.5rem;
  margin: 0;
  text-align: left;
}

.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.tagline {
  text-align: center;
  color: var(--dim);
  font-style: italic;
  margin: 0 0 1.5rem;
}

.err-banner {
  color: var(--err);
  text-align: center;
  margin: 0 0 0.75rem;
  padding: 0.5rem;
  border: 1px solid rgba(255, 85, 119, 0.4);
  border-radius: 8px;
  background: rgba(255, 85, 119, 0.08);
}

.login-bg {
  display: flex; align-items: center; justify-content: center;
  min-height: 100vh;
  padding: 1rem;
}

.login-card {
  position: relative; z-index: 1;
  width: min(380px, 100%);
  background: var(--surface-strong);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6), var(--pink-glow);
  padding: 2.2rem 1.8rem;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.login-card form {
  display: flex; flex-direction: column; gap: 1rem;
}

input[type="password"], select {
  background: var(--bg-2);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  font-family: inherit;
  outline: none;
  transition: border 0.15s, box-shadow 0.15s;
}

input[type="password"]:focus, select:focus {
  border-color: var(--pink);
  box-shadow: var(--pink-glow);
}

button {
  cursor: pointer;
  background: linear-gradient(135deg, var(--pink), var(--lavender));
  color: var(--bg-1);
  border: none;
  border-radius: 10px;
  padding: 0.7rem 1.2rem;
  font-size: 0.95rem;
  font-weight: 600;
  font-family: inherit;
  transition: transform 0.1s, box-shadow 0.15s;
}

button:hover {
  box-shadow: var(--pink-glow);
  transform: translateY(-1px);
}

button:active { transform: translateY(0); }

.btn-danger {
  background: linear-gradient(135deg, var(--err), #b03060);
  color: white;
}

.btn-ghost {
  background: transparent;
  color: var(--dim);
  border: 1px solid var(--border);
}

.btn-ghost:hover {
  box-shadow: none;
  color: var(--pink);
  border-color: var(--pink);
  transform: none;
}

.inline-form { display: inline; }

.footer {
  text-align: center;
  margin-top: 1.5rem;
  color: var(--dim);
  font-size: 0.85rem;
}

.editor-bg {
  display: flex; flex-direction: column; height: 100vh;
}

.editor-header {
  position: relative; z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.7rem 1.25rem;
  background: var(--surface-strong);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  flex-wrap: wrap;
}

.controls {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.status {
  font-size: 0.8rem;
  color: var(--dim);
  padding: 0.3rem 0.85rem;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--border);
  transition: color 0.15s, border-color 0.15s;
}

.status.ok   { color: var(--ok);   border-color: rgba(168, 255, 179, 0.4); }
.status.warn { color: var(--warn); border-color: rgba(255, 184, 77, 0.4); }
.status.err  { color: var(--err);  border-color: rgba(255, 85, 119, 0.4); }
.status.pending {
  color: var(--pink-soft);
  border-color: var(--border-glow);
  box-shadow: var(--pink-glow);
}

.mode-select {
  padding: 0.35rem 0.6rem;
  font-size: 0.85rem;
}

.editor-main {
  flex: 1;
  position: relative;
  z-index: 1;
  overflow: hidden;
}

.editor-main .CodeMirror {
  height: 100%;
  background: transparent;
  color: var(--text);
  font-family: 'JetBrains Mono', 'SF Mono', Consolas, monospace;
  font-size: 14px;
  line-height: 1.65;
  padding: 0.5rem 0;
}

.CodeMirror-gutters {
  background: rgba(10, 6, 18, 0.4);
  border-right: 1px solid var(--border);
}

.CodeMirror-linenumber {
  color: var(--dim);
  opacity: 0.55;
  padding-right: 0.6rem;
}

.CodeMirror-cursor {
  border-left: 2px solid var(--pink);
  box-shadow: 0 0 8px var(--pink);
}

.CodeMirror-selected {
  background: rgba(255, 119, 168, 0.22) !important;
}

.CodeMirror-line::selection,
.CodeMirror-line ::selection {
  background: rgba(255, 119, 168, 0.3);
}

.CodeMirror-activeline-background {
  background: rgba(192, 132, 252, 0.08);
}

.cm-keyword   { color: var(--pink); }
.cm-string    { color: var(--pink-soft); }
.cm-string-2  { color: var(--pink-soft); }
.cm-number    { color: var(--lavender); }
.cm-comment   { color: var(--dim); font-style: italic; opacity: 0.85; }
.cm-variable  { color: var(--text); }
.cm-variable-2{ color: var(--text); }
.cm-variable-3{ color: var(--lavender); }
.cm-property  { color: var(--lavender); }
.cm-def       { color: var(--pink); font-weight: 500; }
.cm-atom      { color: var(--lavender); }
.cm-meta      { color: var(--dim); }
.cm-tag       { color: var(--pink); }
.cm-attribute { color: var(--pink-soft); }
.cm-bracket   { color: var(--dim); }
.cm-operator  { color: var(--pink-soft); }
.cm-header    { color: var(--pink); font-weight: 700; }
.cm-link      { color: var(--lavender); text-decoration: underline; }
.cm-builtin   { color: var(--lavender); }

.editor-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem 1.25rem;
  background: var(--surface-strong);
  border-top: 1px solid var(--border);
  font-size: 0.78rem;
  color: var(--dim);
  z-index: 2;
}

.editor-footer .warn { color: var(--warn); }
.editor-footer .err  { color: var(--err);  }
.editor-footer .footer-tag { font-style: italic; }

.modal {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex; align-items: center; justify-content: center;
  z-index: 100;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.modal.hidden { display: none; }

.modal-card {
  background: var(--surface-strong);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 2rem;
  width: min(460px, calc(100% - 2rem));
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.7),
              0 0 32px rgba(255, 85, 119, 0.3);
}

.modal-card h2 {
  font-family: 'UnifrakturCook', serif;
  color: var(--err);
  margin: 0 0 1rem;
  text-shadow: 0 0 12px rgba(255, 85, 119, 0.5);
  font-size: 1.8rem;
}

.modal-card p { color: var(--dim); margin: 0 0 1.5rem; line-height: 1.5; }

.modal-card code {
  background: var(--bg-1);
  padding: 0.1rem 0.4rem;
  border-radius: 4px;
  color: var(--pink-soft);
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.85em;
}

.modal-actions {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
}

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: rgba(10, 6, 18, 0.3); }
::-webkit-scrollbar-thumb {
  background: linear-gradient(135deg, var(--pink), var(--lavender));
  border-radius: 5px;
}
::-webkit-scrollbar-thumb:hover {
  box-shadow: var(--pink-glow);
}

@media (max-width: 640px) {
  .editor-header { padding: 0.5rem 0.75rem; }
  .logo-sm { font-size: 1.15rem; }
  .controls { gap: 0.4rem; }
  button, .status { font-size: 0.72rem; padding: 0.3rem 0.55rem; }
  .modal-card { padding: 1.4rem; }
  .modal-card h2 { font-size: 1.4rem; }
}
