/* ─── Reset & Tokens ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Colours — dark theme base */
  --bg:           #1a1b26;
  --bg-surface:   #24283b;
  --bg-raised:    #2f3349;
  --bg-input:     #1e2030;
  --border:       #3d4166;
  --border-focus: #7aa2f7;

  --text:         #c0caf5;
  --text-muted:   #787c99;
  --text-strong:  #e0e4ff;

  --accent:       #7aa2f7;
  --accent-hover: #9ab5ff;
  --danger:       #f7768e;
  --danger-hover: #ff9eb0;
  --success:      #9ece6a;
  --warning:      #e0af68;

  --sidebar-w:    240px;
  --topbar-h:     52px;

  --font-sans:    -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  --font-mono:    'JetBrains Mono', 'Fira Code', 'SF Mono', Consolas, monospace;
  --radius:       6px;
  --radius-lg:    10px;
  --shadow:       0 2px 12px rgba(0,0,0,.4);
}

html, body {
  height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }

code, pre { font-family: var(--font-mono); }

/* ─── Layout ──────────────────────────────────────────────────────────────── */
.layout {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}

.layout--editor {
  display: flex;
  flex-direction: column;
}

/* ─── Topbar ──────────────────────────────────────────────────────────────── */
.topbar {
  display: flex;
  align-items: center;
  gap: 8px;
  height: var(--topbar-h);
  padding: 0 16px;
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  z-index: 10;
  overflow: hidden;
}

/* Logo */
.topbar__logo {
  display: flex; align-items: center; gap: 8px;
  font-weight: 700; font-size: 1rem; color: var(--text-strong);
  letter-spacing: -.5px; flex-shrink: 0; text-decoration: none;
}
.topbar__logo:hover { color: var(--accent); }
.topbar__logo-img { width: 22px; height: 22px; display: block; flex-shrink: 0; }

/* Breadcrumb */
.topbar__breadcrumb {
  display: flex; align-items: center; gap: 5px;
  min-width: 0; overflow: hidden; flex-shrink: 1;
}
.topbar__bc-sep    { color: var(--border); font-size: .8rem; flex-shrink: 0; user-select: none; }
.topbar__bc-link   { font-size: .875rem; color: var(--text-muted); flex-shrink: 0; white-space: nowrap; }
.topbar__bc-link:hover { color: var(--text); }
.topbar__bc-current {
  font-size: .875rem; font-weight: 500; color: var(--text-strong);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0;
}

/* Spacer pushes right-side items to the right */
.topbar__spacer { flex: 1; min-width: 8px; }

/* Editor-specific actions */
.topbar__editor-actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }

/* Pipe separator between editor actions and global nav */
.topbar__pipe {
  display: block; width: 1px; height: 20px;
  background: var(--border); flex-shrink: 0; margin: 0 4px;
}

/* Global nav (always shown) */
.topbar__global-nav { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.topbar__username { font-size: .8rem; color: var(--text); white-space: nowrap; }
.topbar__link { color: var(--text-muted); font-size: .875rem; white-space: nowrap; }
.topbar__link:hover { color: var(--text); }
.topbar__link--icon {
  display: flex; align-items: center; padding: 4px;
  border-radius: var(--radius); transition: color .15s, background .15s;
}
.topbar__link--icon:hover { color: var(--text); background: var(--bg-hover); }

/* Misc topbar helpers kept for any remaining uses */
.topbar__dirty-dot {
  font-size: .72rem; font-weight: 600;
  color: var(--warning);
  padding: 1px 6px;
  border-radius: 4px;
  background: rgba(224,175,104,.12);
  border: 1px solid rgba(224,175,104,.3);
  margin-left: 6px;
  vertical-align: middle;
}

.presence-indicator {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .8rem;
  color: var(--warning, #e0af68);
  white-space: nowrap;
  flex-shrink: 0;
  padding: 0 10px;
  height: 26px;
  box-sizing: border-box;
  background: rgba(224,175,104,.12);
  border: 1px solid rgba(224,175,104,.35);
  border-radius: var(--radius);
}
.presence-reload-btn {
  background: none; border: none; cursor: pointer;
  color: var(--warning, #e0af68);
  font-size: .95rem; line-height: 1; padding: 0 2px;
  flex-shrink: 0;
  transition: transform .2s;
}
.presence-reload-btn:hover { transform: rotate(180deg); color: var(--text); }

/* ─── Buttons ─────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  font-size: .875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  white-space: nowrap;
}
.btn--primary  { background: transparent; color: var(--accent); border-color: var(--accent); }
.btn--primary:hover  { background: var(--accent-hover); border-color: var(--accent-hover); color: #fff; }
.btn--danger   { background: transparent; color: var(--danger); border-color: var(--danger); }
.btn--danger:hover   { background: var(--danger); color: #fff; }
.btn--ghost    { background: transparent; color: var(--text); border-color: var(--text); }
.btn--ghost:hover    { background: var(--bg-raised); }
.btn--shared   { background: transparent; color: var(--success); border-color: var(--success); }
.btn--shared:hover   { background: var(--success); color: #fff; }
.btn--passkey  { background: var(--bg-raised); color: var(--text); border: 1px solid var(--border); }
.btn--passkey:hover  { border-color: var(--accent); color: var(--accent); }
.btn--full     { width: 100%; justify-content: center; }
.btn--sm       { padding: 3px 9px; font-size: .8rem; }
.btn--icon-circle {
  display: flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; padding: 0; flex-shrink: 0;
  background: none; border: none; border-radius: 50%;
  color: var(--accent); cursor: pointer;
  transition: color .15s, background .15s;
}
.btn--icon-circle:hover { color: var(--accent-hover); background: rgba(122,162,247,.12); }
.btn:disabled  { opacity: .5; cursor: not-allowed; }
.btn__icon     { width: 16px; height: 16px; }

/* ─── Inputs ──────────────────────────────────────────────────────────────── */
.input {
  display: block;
  width: 100%;
  padding: 8px 12px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font-size: .9rem;
  transition: border-color .15s;
}
.input:focus { outline: none; border-color: var(--border-focus); }
.input--code  { font-family: var(--font-mono); letter-spacing: .15em; text-align: center; font-size: 1.1rem; }

.select {
  padding: 6px 10px;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font-size: .875rem;
  cursor: pointer;
  height: 26px;
  box-sizing: border-box;
  line-height: 1;
}
.select--sm   { padding: 0 8px; font-size: .8rem; height: 26px; }
.select:focus { outline: none; border-color: var(--border-focus); }

.label { display: block; margin-bottom: 4px; font-size: .8rem; font-weight: 500; color: var(--text-muted); text-transform: uppercase; letter-spacing: .06em; }
.hint  { margin-top: 4px; font-size: .78rem; color: var(--text-muted); }

.form-group { margin-bottom: 16px; }
.form-hint { margin-top: 4px; font-size: .78rem; color: var(--text-muted); }

/* ─── Toggle switch ──────────────────────────────────────────────────────── */
.toggle-label { display: flex; align-items: center; gap: 10px; cursor: pointer; user-select: none; }
.toggle-input { position: absolute; opacity: 0; width: 0; height: 0; }
.toggle-track {
  position: relative; display: inline-block; flex-shrink: 0;
  width: 38px; height: 22px; border-radius: 11px;
  background: var(--border); transition: background .2s;
}
.toggle-track::after {
  content: ''; position: absolute; top: 3px; left: 3px;
  width: 16px; height: 16px; border-radius: 50%;
  background: #fff; transition: transform .2s;
}
.toggle-input:checked + .toggle-track { background: var(--accent); }
.toggle-input:checked + .toggle-track::after { transform: translateX(16px); }
.toggle-text { font-size: .9rem; color: var(--text-normal); }

/* ─── Auth ────────────────────────────────────────────────────────────────── */
.auth-layout {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.auth-card {
  width: 100%;
  max-width: 420px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow);
}

.auth-card__logo { text-align: center; margin-bottom: 28px; }
.auth-card__logo-img { width: 52px; height: 52px; display: block; margin: 0 auto 10px; }
.auth-card__title { font-size: 1.5rem; font-weight: 700; color: var(--text-strong); margin: 4px 0 0; }
.auth-card__subtitle { color: var(--text-muted); font-size: .9rem; margin-top: 4px; }

.auth-tabs { display: flex; border-bottom: 1px solid var(--border); margin-bottom: 24px; }
.auth-tab {
  flex: 1;
  background: none;
  border: none;
  padding: 10px;
  color: var(--text-muted);
  cursor: pointer;
  font-size: .9rem;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
}
.auth-tab--active { color: var(--accent); border-bottom-color: var(--accent); }

.auth-panel { display: none; }
.auth-panel--active { display: block; }

.auth-divider { text-align: center; margin: 16px 0; color: var(--text-muted); font-size: .8rem; position: relative; }
.auth-divider::before { content: ''; position: absolute; top: 50%; left: 0; right: 0; height: 1px; background: var(--border); }
.auth-divider span { position: relative; background: var(--bg-surface); padding: 0 10px; }

.auth-error { margin-top: 14px; padding: 10px 12px; background: rgba(247,118,142,.12); border: 1px solid var(--danger); border-radius: var(--radius); color: var(--danger); font-size: .875rem; }

/* ─── Dashboard ───────────────────────────────────────────────────────────── */
.dashboard { padding: 24px; overflow-y: auto; flex: 1; }
.dashboard__header { display: flex; align-items: center; margin-bottom: 20px; }
.dashboard__title-group { display: flex; align-items: center; gap: 4px; }
.dashboard__title { font-size: 1.25rem; font-weight: 600; color: var(--text-strong); }

.project-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }

.project-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color .15s, transform .1s;
  color: var(--text);
}
.project-card:hover { border-color: var(--accent); transform: translateY(-1px); }
.project-card__color-bar { height: 4px; background: var(--project-color, var(--accent)); }
.project-card__body { padding: 16px; flex: 1; }
.project-card__name-row { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; }
.project-card__name { font-size: .95rem; font-weight: 600; color: var(--text-strong); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.project-card__star {
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  background: none; border: none; padding: 2px; cursor: pointer;
  color: var(--text-muted); transition: color .15s;
}
.project-card__star.starred { color: var(--warning); }
.project-card__star.starred svg { fill: var(--warning); }
.project-card__star:hover { color: var(--warning); }
.project-card__desc { font-size: .8rem; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.project-card__footer {
  display: flex; align-items: center; gap: 4px;
  padding: 6px 12px 8px;
  border-top: 1px solid var(--border);
}
.project-card__icon-btn {
  display: flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; padding: 0;
  background: none; border: none; border-radius: var(--radius);
  color: var(--text-muted); cursor: pointer;
  transition: color .15s, background .15s;
}
.project-card__icon-btn:hover { color: var(--text); background: var(--bg-raised); }
.project-card__delete-btn:hover { color: var(--danger) !important; background: rgba(247,118,142,.1) !important; }

/* ─── Favorites + Recent panels ─────────────────────────────────────────── */
.dashboard__top-panels {
  display: flex;
  gap: 20px;
  margin-bottom: 8px;
}
.dashboard__panel {
  flex: 1;
  min-width: 0;
}
.dashboard__title--favorites { color: var(--warning); }
.favorites-list {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.recent-list {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.recent-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
}
.recent-row:last-child { border-bottom: none; }
.recent-row__title {
  flex: 1; font-size: .9rem; color: var(--text);
  text-decoration: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.recent-row__title:hover { color: var(--accent); }
.recent-row__meta {
  font-size: .78rem; color: var(--text-muted);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 90px;
}
.recent-row__time {
  flex-shrink: 0; font-size: .75rem; color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}
.fav-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
}
.fav-row:last-child { border-bottom: none; }
.fav-row__star {
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; padding: 0;
  background: none; border: none; cursor: pointer;
  color: var(--warning); transition: opacity .15s;
}
.fav-row__star svg { fill: var(--warning); }
.fav-row__star:hover { opacity: .6; }
.fav-row__title {
  flex: 1; font-size: .9rem; color: var(--text);
  text-decoration: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.fav-row__title:hover { color: var(--accent); }

/* ─── Dashboard shared sections ───────────────────────────────────────────── */
.dashboard__title--section { margin-top: 36px; margin-bottom: 16px; }

.shared-sections {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 24px;
}

.shared-section {
  display: flex;
  flex-direction: column;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color .15s, transform .1s;
}
.shared-section:hover { border-color: var(--section-color, var(--accent)); transform: translateY(-1px); }

.shared-section__color-bar { height: 4px; background: var(--section-color, var(--accent)); }

.shared-section__title {
  font-size: .95rem;
  font-weight: 600;
  color: var(--text-strong);
  padding: 14px 16px 12px;
  border-bottom: 1px solid var(--border);
}

.shared-snippet-list { padding: 4px 6px; min-height: 60px; flex: 1; }
.shared-section__empty { font-size: .875rem; color: var(--text-muted); padding: 16px; }
.snippet-row__shared-with { font-size: .75rem; color: var(--accent); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 160px; }

@media (max-width: 760px) {
  .shared-sections { grid-template-columns: 1fr; }
}

/* ─── Project layout ──────────────────────────────────────────────────────── */
.project-layout { display: flex; flex: 1; overflow: hidden; }

.sidebar {
  width: var(--sidebar-w);
  flex-shrink: 0;
  background: var(--bg-surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}
.sidebar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
}
.sidebar__header-left   { display: flex; align-items: center; gap: 2px; }
.sidebar__header-actions { display: flex; align-items: center; gap: 2px; margin-left: auto; }
.sidebar__icon-btn {
  display: flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; padding: 0;
  background: none; border: none; border-radius: var(--radius);
  color: var(--text-muted); cursor: pointer;
  transition: color .15s, background .15s;
}
.sidebar__icon-btn:hover { color: var(--text); background: var(--bg-raised); }
.sidebar__icon-btn--danger:hover { color: var(--danger) !important; background: rgba(247,118,142,.1) !important; }
.sidebar__star-btn.starred { color: var(--warning); }
.sidebar__star-btn.starred svg { fill: var(--warning); }
.sidebar__star-btn:hover { color: var(--warning) !important; }

/* ─── Topbar snippet star ─────────────────────────────────────────────────── */
.topbar__star-btn {
  display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; padding: 0; flex-shrink: 0;
  background: none; border: none; border-radius: var(--radius);
  color: var(--text-muted); cursor: pointer;
  transition: color .15s, background .15s;
}
.topbar__star-btn:hover { color: var(--warning); background: var(--bg-raised); }
.topbar__star-btn.starred { color: var(--warning); }
.topbar__star-btn.starred svg { fill: var(--warning); }
.topbar__info-btn {
  display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; padding: 0; flex-shrink: 0;
  background: none; border: none; border-radius: var(--radius);
  color: var(--text-muted); cursor: pointer;
  transition: color .15s, background .15s;
}
.topbar__info-btn:hover { color: var(--accent); background: var(--bg-raised); }
.topbar__auto-reload-btn {
  display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; padding: 0; flex-shrink: 0;
  background: none; border: none; border-radius: var(--radius);
  color: var(--text-muted); cursor: pointer;
  transition: color .15s, background .15s;
}
.topbar__auto-reload-btn:hover { color: var(--text); background: var(--bg-raised); }
.topbar__auto-reload-btn.active { color: var(--success); }
.topbar__auto-reload-btn.active:hover { color: var(--success); background: rgba(158,206,106,.12); }

.folder-tree { padding: 8px; }

/* ─── Sidebar resize handle ──────────────────────────────────────────────── */
.sidebar__resizer {
  width: 4px;
  flex-shrink: 0;
  cursor: col-resize;
  background: transparent;
  transition: background .15s;
  position: relative;
}
/* Widen the interactive hit area without affecting the visual width */
.sidebar__resizer::after {
  content: '';
  position: absolute;
  inset: 0 -4px;
}
.sidebar__resizer:hover,
.sidebar__resizer--active { background: var(--accent); }

/* Folder tree */
.tree { list-style: none; padding: 0; margin: 0; }
.tree ul { list-style: none; padding-left: 16px; margin: 0; }
.tree__folder-row {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 6px;
  border-radius: var(--radius);
  cursor: pointer;
}
.tree__folder-row:hover { background: var(--bg-raised); }
.tree__label { flex: 1; font-size: .875rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; cursor: pointer; }
.tree__chevron { font-size: .65rem; color: var(--text-muted); flex-shrink: 0; width: 12px; transition: color .15s; }
.tree__folder-row:hover .tree__chevron { color: var(--text); }
/* Tree action buttons (shown on hover) */
.tree__actions {
  display: flex; align-items: center; gap: 1px;
  flex-shrink: 0; opacity: 0; transition: opacity .1s;
}
.tree__folder-row:hover .tree__actions,
.tree__snippet:hover    .tree__actions { opacity: 1; }

.tree__act-btn {
  display: flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; padding: 0;
  background: none; border: none; border-radius: var(--radius);
  color: var(--text-muted); cursor: pointer;
  transition: color .15s, background .15s;
}
.tree__act-btn:hover                  { color: var(--text); background: var(--bg-hover, var(--bg-raised)); }
.tree__act-delete:hover               { color: var(--danger); }
.tree__act-add-snippet                { color: var(--accent); }
.tree__act-add-snippet:hover          { color: var(--accent-hover, var(--accent)); background: var(--bg-raised); }
.tree__acts-sep {
  display: block; width: 1px; height: 12px;
  background: var(--border); flex-shrink: 0; margin: 0 2px;
}
.tree__snippet {
  display: flex; align-items: center;
  padding: 2px 4px; gap: 2px;
}
.tree__snippet-link {
  font-size: .875rem; color: var(--text-muted); flex: 1; min-width: 0;
  padding: 3px 6px; border-radius: var(--radius);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  text-decoration: none;
}
.tree__snippet-link:hover { color: var(--text); background: var(--bg-raised); }
.tree__snippet-link--active { color: var(--accent) !important; background: rgba(122,162,247,.12); }
.tree__empty { font-size: .8rem; color: var(--text-muted); padding: 8px; }

/* Snippet list */
.snippet-list-area { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
.snippet-list-header { display: flex; align-items: center; padding: 12px 20px; border-bottom: 1px solid var(--border); }
.snippet-list-header__title-group { display: flex; align-items: center; gap: 4px; }
.snippet-list-header__title { font-size: 1rem; font-weight: 600; color: var(--text-strong); }
.snippet-list { flex: 1; overflow-y: auto; padding: 8px; }

.snippet-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: var(--radius);
  color: var(--text);
  text-decoration: none;
  transition: background .1s;
}
.snippet-row:hover { background: var(--bg-raised); }
.snippet-row__title { flex: 1; font-size: .9rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.snippet-row__date { font-size: .75rem; color: var(--text-muted); white-space: nowrap; }
.snippet-row__owner { font-size: .75rem; color: var(--text-muted); }
.snippet-row__perm { font-size: .7rem; }

/* Language badges */
.lang-badge {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 4px;
  font-size: .7rem;
  font-family: var(--font-mono);
  font-weight: 600;
  white-space: nowrap;
  background: var(--bg-raised);
  color: var(--text-muted);
  border: 1px solid var(--border);
}
.lang-badge--powershell  { background: rgba(0,120,215,.15);    color: #5eb0ef; border-color: rgba(0,120,215,.3); }
.lang-badge--bash,
.lang-badge--shell       { background: rgba(158,206,106,.1);   color: #9ece6a; border-color: rgba(158,206,106,.3); }
.lang-badge--python      { background: rgba(224,175,104,.1);   color: #e0af68; border-color: rgba(224,175,104,.3); }
.lang-badge--javascript  { background: rgba(247,201,64,.1);    color: #f7c948; border-color: rgba(247,201,64,.3); }
.lang-badge--typescript  { background: rgba(77,157,224,.15);   color: #4d9de0; border-color: rgba(77,157,224,.3); }
.lang-badge--php         { background: rgba(133,100,210,.15);  color: #c6a0f6; border-color: rgba(133,100,210,.3); }
.lang-badge--sql         { background: rgba(62,149,173,.1);    color: #7dcfff; border-color: rgba(62,149,173,.3); }
.lang-badge--html        { background: rgba(224,108,117,.12);  color: #e06c75; border-color: rgba(224,108,117,.3); }
.lang-badge--css         { background: rgba(86,182,194,.12);   color: #56b6c2; border-color: rgba(86,182,194,.3); }
.lang-badge--json        { background: rgba(212,212,212,.08);  color: #d4d4d4; border-color: rgba(212,212,212,.2); }
.lang-badge--yaml        { background: rgba(187,154,247,.12);  color: #bb9af7; border-color: rgba(187,154,247,.3); }
.lang-badge--xml         { background: rgba(229,192,123,.12);  color: #e5c07b; border-color: rgba(229,192,123,.3); }
.lang-badge--markdown    { background: rgba(122,162,247,.12);  color: #7aa2f7; border-color: rgba(122,162,247,.3); }
.lang-badge--swift       { background: rgba(255,107,53,.12);   color: #ff6b35; border-color: rgba(255,107,53,.3); }
.lang-badge--go          { background: rgba(0,173,216,.12);    color: #00add8; border-color: rgba(0,173,216,.3); }
.lang-badge--rust        { background: rgba(206,106,75,.12);   color: #ce6a4b; border-color: rgba(206,106,75,.3); }
.lang-badge--java        { background: rgba(240,128,48,.12);   color: #f08030; border-color: rgba(240,128,48,.3); }
.lang-badge--csharp      { background: rgba(160,99,208,.15);   color: #a063d0; border-color: rgba(160,99,208,.3); }
.lang-badge--cpp         { background: rgba(96,148,199,.15);   color: #6094c7; border-color: rgba(96,148,199,.3); }
.lang-badge--c           { background: rgba(91,134,204,.15);   color: #5b86cc; border-color: rgba(91,134,204,.3); }
.lang-badge--ruby        { background: rgba(224,92,110,.12);   color: #e05c6e; border-color: rgba(224,92,110,.3); }
.lang-badge--project     { background: rgba(255,255,255,.08);  color: #fff;    border-color: rgba(255,255,255,.25); }

/* ─── Editor ──────────────────────────────────────────────────────────────── */
.editor-title { font-size: .95rem; font-weight: 600; color: var(--text-strong); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 300px; }
.editor-mount { flex: 1; overflow: hidden; display: flex; flex-direction: column; }
.editor-mount .cm-editor { height: 100%; }
.editor-mount .cm-scroller { overflow: auto; }
.fallback-editor { width: 100%; height: 100%; background: var(--bg-input); border: none; color: var(--text); font-family: var(--font-mono); font-size: 14px; padding: 16px; resize: none; }
.fallback-editor:focus { outline: none; }

/* ─── Settings ────────────────────────────────────────────────────────────── */
.settings-area { padding: 24px; overflow-y: auto; flex: 1; }
.settings-area__inner { max-width: 640px; margin: 0 auto; }
.settings-section { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 24px; margin-bottom: 20px; }
.settings-section__title { font-size: 1rem; font-weight: 600; color: var(--text-strong); margin-bottom: 16px; }
.settings-section--danger { border-color: rgba(247,118,142,.35); }
.settings-section--danger .settings-section__title { color: var(--danger); }
.danger-zone { display: flex; flex-direction: column; gap: 16px; }
.danger-zone__item { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 16px; background: rgba(247,118,142,.05); border: 1px solid rgba(247,118,142,.2); border-radius: var(--radius); }
.danger-zone__info { flex: 1; }
.danger-zone__info strong { display: block; color: var(--text-strong); margin-bottom: 4px; }
.danger-zone__info p { color: var(--text-muted); font-size: .875rem; margin: 0; }
.settings-form { max-width: 400px; }
.settings-status { color: var(--text-muted); font-size: .875rem; margin-bottom: 12px; }
.settings-status--active { color: var(--success); }
.settings-empty { color: var(--text-muted); font-size: .875rem; padding: 8px 0; }

/* ─── Admin section ──────────────────────────────────────────────────────── */
.settings-section--admin { border-color: rgba(122,162,247,.35); }
.settings-section--admin .settings-section__title { color: var(--accent); }
.admin-block__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.admin-block__header strong { display: block; color: var(--text-strong); margin-bottom: 4px; }
.admin-user-list { margin-top: 12px; overflow-x: auto; }
.admin-user-table td, .admin-user-table th { vertical-align: middle; }
.admin-user-table__save { width: 64px; }
.input--sm { font-size: .8rem; padding: 4px 8px; height: auto; }

/* ─── Maintenance overlay ─────────────────────────────────────────────────── */
#maintenance-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--bg-base, #1a1b26);
  display: flex; align-items: center; justify-content: center;
}
.maintenance-box {
  text-align: center; max-width: 400px; padding: 40px 24px;
  color: var(--text, #c0caf5);
}
.maintenance-box svg { color: var(--accent, #7aa2f7); margin-bottom: 20px; }
.maintenance-box h2 { font-size: 1.5rem; font-weight: 600; margin-bottom: 12px; color: var(--text-strong, #fff); }
.maintenance-box p { color: var(--text-muted, #565f89); line-height: 1.6; }

/* Invite tokens */
.invite-result { display: flex; align-items: center; gap: 8px; margin-top: 12px; max-width: 500px; }
.invite-result__input { flex: 1; font-family: var(--font-mono); font-size: .8rem; }
.invite-table { width: 100%; border-collapse: collapse; font-size: .8rem; margin-top: 4px; }
.invite-table th { text-align: left; color: var(--text-muted); font-weight: 600; padding: 4px 8px 6px; border-bottom: 1px solid var(--border); }
.invite-table td { padding: 6px 8px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.invite-table__token { font-family: var(--font-mono); color: var(--text-muted); font-size: .75rem; word-break: break-all; }
.invite-table__used    { color: var(--text-muted); }
.invite-table__pending { color: var(--success); font-weight: 500; }

.passkey-row { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border); }
.passkey-row:last-of-type { border-bottom: none; }
.passkey-row__icon { font-size: 1.3rem; }
.passkey-row__info { flex: 1; }
.passkey-row__name { display: block; font-size: .9rem; color: var(--text-strong); }
.passkey-row__date { font-size: .75rem; color: var(--text-muted); }

.totp-setup { margin-top: 16px; }
.totp-setup p { font-size: .875rem; color: var(--text-muted); margin-bottom: 12px; }
.qr-code { margin-bottom: 16px; }
.totp-secret-text { font-size: .8rem; color: var(--text-muted); word-break: break-all; }
.totp-secret-text code { background: var(--bg-raised); padding: 2px 6px; border-radius: 4px; font-size: .85rem; }

/* ─── Share panel ─────────────────────────────────────────────────────────── */
.share-panel { position: fixed; inset: 0; z-index: 100; display: none; }
.share-panel--open { display: block; }
.share-panel__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.5); }
.share-panel__drawer {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 360px;
  background: var(--bg-surface);
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 0;
  box-shadow: var(--shadow);
}
.share-panel__header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border); }
.share-panel__header h3 { font-size: 1rem; font-weight: 600; color: var(--text-strong); }
.share-panel__close { background: none; border: none; color: var(--text-muted); font-size: 1.4rem; cursor: pointer; line-height: 1; }
.share-panel__content { padding: 16px 20px; flex: 1; overflow-y: auto; }
.share-panel__add { display: flex; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.share-panel__add .input { flex: 1; min-width: 0; }

.share-suggestions { margin-bottom: 8px; }
.share-suggestion { padding: 6px 10px; background: var(--bg-raised); border-radius: var(--radius); cursor: pointer; font-size: .875rem; }
.share-suggestion:hover { background: var(--bg-input); color: var(--accent); }

.share-list { margin-top: 12px; }
.share-row { display: flex; align-items: center; gap: 8px; padding: 8px 0; border-bottom: 1px solid var(--border); }
.share-row:last-of-type { border-bottom: none; }
.share-row__user { flex: 1; font-size: .9rem; }
.share-list__loading,
.share-list__empty,
.share-list__error { font-size: .875rem; color: var(--text-muted); padding: 8px 0; }

/* ─── Info panel ──────────────────────────────────────────────────────────── */
.info-panel { position: fixed; inset: 0; z-index: 100; display: none; }
.info-panel--open { display: block; }
.info-panel__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.5); }
.info-panel__drawer {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 320px;
  background: var(--bg-surface);
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow);
}
.info-panel__header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border); }
.info-panel__header h3 { font-size: 1rem; font-weight: 600; color: var(--text-strong); }
.info-panel__close { background: none; border: none; color: var(--text-muted); font-size: 1.4rem; cursor: pointer; line-height: 1; }
.info-panel__content { padding: 20px; flex: 1; overflow-y: auto; }
.info-panel__list { display: flex; flex-direction: column; gap: 16px; }
.info-panel__row { display: flex; flex-direction: column; gap: 3px; }
.info-panel__label { font-size: .75rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; color: var(--text-muted); }
.info-panel__value { font-size: .9rem; color: var(--text-strong); word-break: break-word; }

/* ─── Modal ───────────────────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,.6);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.modal-overlay--visible { opacity: 1; pointer-events: all; }
.modal {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  width: 480px;
  max-width: calc(100vw - 32px);
  box-shadow: var(--shadow);
  transform: translateY(-8px);
  transition: transform .2s;
}
.modal-overlay--visible .modal { transform: none; }
.modal__header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border); }
.modal__title { font-size: 1rem; font-weight: 600; color: var(--text-strong); }
.modal__close { background: none; border: none; color: var(--text-muted); font-size: 1.4rem; cursor: pointer; line-height: 1; }
.modal__body { padding: 20px; }
.modal__message { color: var(--text); font-size: .9rem; margin-bottom: 12px; }
.modal__body .input { margin-top: 8px; }
.modal-form { display: flex; flex-direction: column; gap: 14px; }
.modal-form__label { display: flex; flex-direction: column; gap: 6px; font-size: .85rem; color: var(--text-muted); }
.modal-form__label .input { margin-top: 0; }
.modal__footer { display: flex; gap: 10px; justify-content: flex-end; padding: 12px 20px; border-top: 1px solid var(--border); }

/* ─── Toasts ──────────────────────────────────────────────────────────────── */
.toast-container { position: fixed; bottom: 64px; right: 24px; z-index: 300; display: flex; flex-direction: column; gap: 8px; }
.toast {
  padding: 10px 16px;
  border-radius: var(--radius);
  font-size: .875rem;
  min-width: 220px;
  max-width: 380px;
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .2s, transform .2s;
  pointer-events: none;
}
.toast--visible { opacity: 1; transform: none; pointer-events: all; }
.toast--info    { background: var(--bg-raised); border: 1px solid var(--border); color: var(--text); }
.toast--success { background: rgba(158,206,106,.15); border: 1px solid var(--success); color: var(--success); }
.toast--error   { background: rgba(247,118,142,.12); border: 1px solid var(--danger); color: var(--danger); }

/* ─── Utility ─────────────────────────────────────────────────────────────── */
.spinner {
  width: 24px; height: 24px;
  border: 3px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin .7s linear infinite;
  margin: 32px auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

.app-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100vh;
}

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  color: var(--text-muted);
  gap: 16px;
}
.empty-state p { font-size: .95rem; }

.error-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 48px 24px;
  color: var(--text-muted);
  gap: 16px;
  text-align: center;
}
.error-state h2 { color: var(--text-strong); }

.error-text { color: var(--danger); font-size: .875rem; }

.badge { display: inline-block; padding: 2px 7px; border-radius: 4px; font-size: .7rem; font-weight: 600; background: var(--bg-raised); border: 1px solid var(--border); }

/* ─── Shared list ─────────────────────────────────────────────────────────── */
.shared-list-area { flex: 1; overflow-y: auto; padding: 8px 16px; }

/* ─── Footer ──────────────────────────────────────────────────────────────── */
.app-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 6px 16px;
  background: var(--bg-surface);
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}

/* On the login page the auth-layout is a centered row-flex,
   so pin the footer to the bottom of the viewport instead. */
.auth-layout .app-footer {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--bg-surface);
}
.app-footer__copy    { font-size: .75rem; color: var(--text-muted); }
.app-footer__sep     { font-size: .75rem; color: var(--border); user-select: none; }
.app-footer__version { font-size: .75rem; color: var(--text-muted); margin-left: auto; opacity: .6; }
.app-footer__link {
  font-size: .75rem; color: var(--text-muted);
  background: none; border: none; cursor: pointer; padding: 0; text-decoration: none;
}
.app-footer__link:hover { color: var(--accent); }

/* Impressum modal — wider than default */
.modal--wide { width: 600px; max-height: 80vh; display: flex; flex-direction: column; }
.modal--wide .modal__body { overflow-y: auto; flex: 1; }

/* Impressum body content */
.impressum-body h3 {
  font-size: .85rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-muted);
  margin: 20px 0 6px;
}
.impressum-body h3:first-child { margin-top: 0; }
.impressum-body p {
  font-size: .875rem; color: var(--text); line-height: 1.6; margin-bottom: 4px;
}
.impressum-body a { color: var(--accent); }
.impressum-body a:hover { color: var(--accent-hover); }
.impressum-body em { color: var(--text-muted); font-style: normal; }

/* ─── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .sidebar { width: 200px; }
  .project-grid { grid-template-columns: 1fr; }
  .share-panel__drawer { width: 100%; }
  .modal--wide { width: calc(100vw - 32px); }
}
