/* SmartText — reusable rich text field component */
.vault-smart-text-wrap {
  display: block;
}

.vault-smart-text-toolbar {
  display: flex;
  gap: 0.2rem;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 0.25rem;
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--vault-bg-elevated);
  padding: 0.1rem 0;
}
.vault-smart-text-toolbar-sep {
  align-self: stretch;
  width: 1px;
  min-height: 1.35rem;
  margin: 0 0.18rem;
  background: var(--vault-border);
  flex-shrink: 0;
}
.vault-smart-text-toolbar-right {
  margin-left: auto;
  display: flex;
  gap: 0.2rem;
  align-items: center;
}
.vault-smart-text-toolbar-btn--icon {
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.vault-smart-text-toolbar-btn--icon svg {
  display: block;
  width: 1.0625rem;
  height: 1.0625rem;
}

.vault-smart-text-toolbar-btn {
  box-sizing: border-box;
  width: 1.75rem;
  height: 1.75rem;
  min-width: 1.75rem;
  min-height: 1.75rem;
  padding: 0;
  font-size: 0.8125rem;
  border: 1px solid var(--vault-border);
  border-radius: 0.375rem;
  background: var(--vault-bg-elevated);
  color: var(--vault-text);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.vault-smart-text-toolbar-btn:hover {
  background: var(--vault-border);
}

/* Button styling to match function */
.vault-smart-text-toolbar-btn[data-id="bold"] { font-weight: 700; }
.vault-smart-text-toolbar-btn[data-id="italic"] { font-style: italic; }
.vault-smart-text-toolbar-btn[data-id="underline"] { text-decoration: underline; }
.vault-smart-text-toolbar-btn[data-id="mark"] { background: rgba(250, 204, 21, 0.35); }
.vault-smart-text-toolbar-btn[data-id="mark"]:hover { background: rgba(250, 204, 21, 0.5); }
.vault-smart-text-highlight-trigger svg { display: block; width: 1.0625rem; height: 1.0625rem; }

.vault-smart-text-toolbar-btn svg {
  display: block;
  width: 1.0625rem;
  height: 1.0625rem;
}
.vault-smart-text-toolbar-option-icon {
  display: inline-flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  line-height: 0;
}
.vault-smart-text-toolbar-option-icon svg {
  width: 0.9375rem;
  height: 0.9375rem;
  display: block;
}
.vault-smart-text-toolbar-dropdown-option--row .vault-smart-text-toolbar-option-icon svg {
  width: 0.875rem;
  height: 0.875rem;
}

/* Shell wraps editor + floating block-copy control (positioned to inner right) */
.vault-smart-text-editor-shell {
  position: relative;
  display: block;
}

.vault-smart-text-copy-block-btn {
  position: absolute;
  right: 0.35rem;
  z-index: 6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: 1px solid var(--vault-border);
  border-radius: 0.25rem;
  background: var(--vault-bg-elevated);
  color: var(--vault-text-muted);
  cursor: pointer;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
  transition: background 0.12s, color 0.12s;
}
.vault-smart-text-copy-block-btn.hidden {
  display: none;
}
@media (hover: hover) {
  .vault-smart-text-copy-block-btn:hover {
    background: var(--vault-border);
    color: var(--vault-text);
  }
}
.vault-smart-text-copy-block-btn svg {
  display: block;
  width: 1rem;
  height: 1rem;
}

/* Ephemeral “copied!” near pointer; pointer-events none; 10deg tilt */
.vault-smart-text-copy-toast {
  position: fixed;
  z-index: 10060;
  pointer-events: none;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.2;
  color: var(--vault-text);
  background: var(--vault-bg-elevated);
  border: 1px solid var(--vault-border);
  padding: 0.2rem 0.45rem;
  border-radius: 0.25rem;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
  opacity: 0;
  transform: translate(-50%, calc(-100% - 6px)) rotate(var(--vault-copy-toast-rotate, 10deg));
  transition: opacity 0.18s ease, transform 0.18s ease;
}
.vault-smart-text-copy-toast--visible {
  opacity: 1;
  transform: translate(-50%, calc(-100% - 10px)) rotate(var(--vault-copy-toast-rotate, 10deg));
}

.vault-smart-text-editor {
  min-height: 80px;
  min-width: 0;
  padding: 0.5rem;
  border: 1px solid var(--vault-border);
  border-radius: 0.375rem;
  font-size: 0.875rem;
  outline: none;
  color: var(--vault-text);
  background: var(--vault-bg-elevated);
}
/* Paragraph and div (block content): same styling, reduced padding and margin so blocks are compact */
.vault-smart-text-editor > p,
.vault-smart-text-editor > div:not([class]) {
  margin: 0.125rem 0;
  padding: 0;
  line-height: 1.5;
}

/*
 * Blockquote — editor + read-only note HTML (shared selectors).
 * Left accent bar + minimal padding only; no decorative quotes.
 */
.vault-smart-text-editor blockquote,
.vault-note-body blockquote,
.vault-note-detail-modal-body blockquote,
.vault-general-notes-card-content--html blockquote {
  margin: 0.35rem 0;
  margin-left: 0;
  padding: 0;
  padding-left: 0.5rem;
  border: none;
  border-left: 3px solid var(--vault-border);
  color: var(--vault-blockquote-text, #64748b);
  font-weight: 600;
  font-style: italic;
}
.vault-smart-text-editor blockquote p,
.vault-note-body blockquote p,
.vault-note-detail-modal-body blockquote p,
.vault-general-notes-card-content--html blockquote p {
  margin: 0.15rem 0;
}
/* First block starts at first row (no extra top margin) */
.vault-smart-text-editor > *:first-child {
  margin-top: 0;
}

.vault-smart-text-editor:focus {
  border-color: var(--vault-text-subtle);
}

.vault-smart-text-editor:empty::before {
  content: attr(data-placeholder);
  color: var(--vault-text-subtle);
}

.vault-smart-text-editor ul,
.vault-smart-text-editor ol {
  margin: 0.25rem 0;
  padding-left: 1.25rem;
}

.vault-smart-text-editor ul {
  list-style: disc;
}

/* Checklist: ul with checkbox + editable span per item */
.vault-smart-text-editor ul.vault-smart-text-checklist {
  list-style: none;
  padding-left: 0;
  margin: 0.25rem 0;
}
.vault-smart-text-editor ul.vault-smart-text-checklist > li {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
  margin: 0.15rem 0;
  padding: 0;
  list-style: none;
}
.vault-smart-text-editor .vault-smart-text-checklist-cb {
  flex-shrink: 0;
  margin: 0.2rem 0 0 0;
  cursor: pointer;
  accent-color: var(--vault-primary, #0ea5e9);
}
.vault-smart-text-editor .vault-smart-text-checklist-content {
  flex: 1;
  min-width: 0;
}

/* Hierarchical numbered list: 1, 1.1, 1.1.1 */
.vault-smart-text-editor ol {
  list-style: none;
  counter-reset: item;
}
.vault-smart-text-editor ol li {
  margin: 0.125rem 0;
  display: block;
  counter-increment: item;
}
.vault-smart-text-editor ol li::before {
  content: counters(item, ".") ". ";
  font-variant-numeric: tabular-nums;
}

.vault-smart-text-editor li {
  margin: 0.125rem 0;
}

/* Nested lists (second level) */
.vault-smart-text-editor ul ul,
.vault-smart-text-editor ol ol,
.vault-smart-text-editor ul ol,
.vault-smart-text-editor ol ul {
  margin: 0.125rem 0;
  padding-left: 1.25rem;
}

/* Headings: varying font size */
.vault-smart-text-editor h1 { font-size: 1.5rem; font-weight: 700; margin: 0.5rem 0; line-height: 1.25; }
.vault-smart-text-editor h2 { font-size: 1.25rem; font-weight: 600; margin: 0.5rem 0; line-height: 1.3; }
.vault-smart-text-editor h3 { font-size: 1.125rem; font-weight: 600; margin: 0.375rem 0; line-height: 1.35; }

/* Inline code: very light subtle gray background, no border (avoids extra border on select) */
.vault-smart-text-editor code {
  font-family: ui-monospace, monospace;
  font-size: 0.875em;
  padding: 0.125rem 0.25rem;
  border-radius: 0.25rem;
  background: var(--vault-code-bg, rgba(255, 255, 255, 0.08));
  border: none;
  outline: none;
}
/* Code section: wrapper + one bordered block with subtle gray fill */
.vault-smart-text-code-block-wrap {
  position: relative;
  margin: 0.35rem 0;
}
.vault-smart-text-code-block-remove {
  position: absolute;
  top: 0.3rem;
  right: 0.3rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  border: none;
  border-radius: 0.25rem;
  background: rgba(148, 163, 184, 0.2);
  color: var(--vault-text-muted);
  cursor: pointer;
  line-height: 0;
}
@media (hover: hover) {
  .vault-smart-text-code-block-remove:hover {
    background: rgba(148, 163, 184, 0.35);
    color: var(--vault-text);
  }
}
.vault-smart-text-editor pre.vault-smart-text-code-block {
  display: block;
  margin: 0;
  padding: 0.5rem 2rem 0.5rem 0.75rem;
  min-height: 2.75em;
  cursor: text;
  border: 1px solid var(--vault-border);
  border-radius: 0.375rem;
  background: rgba(148, 163, 184, 0.14);
  font-family: ui-monospace, monospace;
  font-size: 0.8125rem;
  line-height: 1.45;
  white-space: pre-wrap;
  word-break: break-word;
  tab-size: 2;
}
.vault-smart-text-editor pre.vault-smart-text-code-block code.vault-smart-text-code-block-inner,
.vault-smart-text-editor pre.vault-smart-text-code-block code {
  display: block;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
  white-space: inherit;
  word-break: inherit;
}
.vault-smart-text-editor code:focus {
  outline: none;
}
.vault-smart-text-editor mark {
  padding: 0 0.125rem;
  border-radius: 0.125rem;
}
.vault-smart-text-editor mark[data-vault-highlight="yellow"],
.vault-smart-text-editor mark:not([data-vault-highlight]) { background: rgba(250, 204, 21, 0.45); }
.vault-smart-text-editor mark[data-vault-highlight="green"] { background: rgba(34, 197, 94, 0.4); }
.vault-smart-text-editor mark[data-vault-highlight="pink"] { background: rgba(236, 72, 153, 0.4); }
.vault-smart-text-editor mark[data-vault-highlight="blue"] { background: rgba(59, 130, 246, 0.35); }
.vault-smart-text-editor mark[data-vault-highlight="orange"] { background: rgba(249, 115, 22, 0.4); }
.vault-smart-text-editor mark[data-vault-highlight="purple"] { background: rgba(168, 85, 247, 0.4); }
.vault-smart-text-editor mark[data-vault-highlight="cyan"] { background: rgba(6, 182, 212, 0.4); }
.vault-smart-text-editor mark[data-vault-highlight="red"] { background: rgba(255, 45, 85, 0.5); box-shadow: 0 0 0 1px rgba(255, 45, 85, 0.25); }
/* Neon highlighter tokens — HEX / alpha synced with config/vault-neon-palette.js */
.vault-smart-text-editor mark[data-vault-highlight="neon-cream"] { background: rgba(255, 246, 184, 0.78); }
.vault-smart-text-editor mark[data-vault-highlight="neon-mint"] { background: rgba(184, 255, 198, 0.78); }
.vault-smart-text-editor mark[data-vault-highlight="neon-aqua"] { background: rgba(149, 255, 247, 0.78); }
.vault-smart-text-editor mark[data-vault-highlight="neon-periwinkle"] { background: rgba(174, 181, 255, 0.72); }
.vault-smart-text-editor mark[data-vault-highlight="neon-peach"] { background: rgba(255, 212, 184, 0.78); }
.vault-smart-text-editor mark[data-vault-highlight="neon-coral"] { background: rgba(255, 179, 167, 0.75); box-shadow: 0 0 0 1px rgba(255, 107, 90, 0.18); }
.vault-smart-text-editor mark[data-vault-highlight="neon-lavender"] { background: rgba(222, 172, 249, 0.72); }
.vault-smart-text-editor mark[data-vault-highlight="neon-lime"] { background: rgba(212, 255, 50, 0.52); box-shadow: 0 0 0 1px rgba(120, 150, 20, 0.12); }

/* Insert table modal: row/col fields + scrollable size preview */
.vault-smart-text-table-modal .vault-smart-text-table-modal-body {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.vault-smart-text-table-modal-fields {
  display: flex;
  flex-direction: row;
  gap: 1rem;
  align-items: flex-end;
}
.vault-smart-text-table-modal-field {
  flex: 1 1 0;
  min-width: 0;
}
.vault-smart-text-table-modal-preview-scroll {
  max-height: 11rem;
  overflow: auto;
  border: 1px solid var(--vault-border);
  border-radius: 0.375rem;
  padding: 0.5rem;
  background: rgba(148, 163, 184, 0.06);
}
.vault-smart-text-table-modal-preview-inner {
  display: flex;
  justify-content: center;
  min-width: min-content;
}
.vault-smart-text-table-modal-grid {
  display: grid;
  gap: 3px;
  width: max-content;
}
.vault-smart-text-table-modal-grid-corner {
  min-width: 1.35rem;
  min-height: 1.25rem;
}
.vault-smart-text-table-modal-grid-axis {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 600;
  color: var(--vault-text-muted);
  line-height: 1;
  user-select: none;
}
.vault-smart-text-table-modal-grid-cell {
  width: 1.125rem;
  height: 1.125rem;
  border-radius: 2px;
  background: rgba(148, 163, 184, 0.22);
  border: 1px solid var(--vault-border);
  box-sizing: border-box;
}

/* Highlight dropdown */
.vault-smart-text-highlight-wrap { position: relative; display: inline-block; }
.vault-smart-text-highlight-panel {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 2px;
  padding: 0.25rem;
  min-width: 8rem;
  background: var(--vault-bg-elevated);
  border: 1px solid var(--vault-border);
  border-radius: 0.375rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.vault-smart-text-highlight-panel.hidden { display: none !important; }
.vault-smart-text-highlight-option {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.35rem;
  font-size: 0.75rem;
  border: none;
  border-radius: 0.25rem;
  background: transparent;
  color: var(--vault-text);
  cursor: pointer;
  text-align: left;
}
.vault-smart-text-highlight-option:hover { background: var(--vault-border); }
.vault-smart-text-highlight-swatch { width: 1rem; height: 1rem; border-radius: 0.2rem; flex-shrink: 0; }
.vault-smart-text-highlight-option--none { font-style: italic; }

/* Toolbar: view-aware heading + list dropdowns */
.vault-smart-text-toolbar-dropdown {
  position: relative;
  display: inline-block;
  vertical-align: middle;
}
.vault-smart-text-toolbar-dropdown-trigger {
  width: auto;
  min-width: 1.75rem;
  height: 1.75rem;
  min-height: 1.75rem;
  padding: 0 0.32rem 0 0.4rem;
  gap: 0.22rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.vault-smart-text-toolbar-dropdown-trigger__label {
  max-width: 6.5rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.75rem;
  line-height: 1.2;
}
.vault-smart-text-toolbar-dropdown-trigger__chev {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  opacity: 0.72;
}
.vault-smart-text-toolbar-dropdown-trigger__chev svg {
  display: block;
  width: 12px;
  height: 12px;
  transition: transform 0.15s ease;
}
.vault-smart-text-toolbar-dropdown-trigger[aria-expanded="true"] .vault-smart-text-toolbar-dropdown-trigger__chev svg {
  transform: rotate(180deg);
}
.vault-smart-text-toolbar-dropdown-panel {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 2px;
  padding: 0.22rem;
  min-width: 9.25rem;
  background: var(--vault-bg-elevated);
  border: 1px solid var(--vault-border);
  border-radius: 0.375rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.vault-smart-text-toolbar-dropdown-panel.hidden {
  display: none !important;
}
.vault-smart-text-toolbar-dropdown-option {
  display: block;
  width: 100%;
  padding: 0.22rem 0.38rem;
  font-size: 0.75rem;
  border: none;
  border-radius: 0.3125rem;
  background: transparent;
  color: var(--vault-text);
  cursor: pointer;
  text-align: left;
}
.vault-smart-text-toolbar-dropdown-option:hover {
  background: var(--vault-border);
}

/* List menu (icon + label): fixed icon column, gap, padding override base option */
.vault-smart-text-toolbar-dropdown-option.vault-smart-text-toolbar-dropdown-option--row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.625rem;
  min-height: 1.875rem;
  padding: 0.375rem 0.55rem 0.375rem 0.5rem;
  line-height: 1;
  font-size: 0.8125rem;
}
.vault-smart-text-toolbar-dropdown-option--row .vault-smart-text-toolbar-option-icon {
  width: 1.125rem;
  min-width: 1.125rem;
  flex-shrink: 0;
  align-self: center;
}
.vault-smart-text-toolbar-dropdown-option--row .vault-smart-text-toolbar-dropdown-option__label {
  flex: 1;
  min-width: 0;
  line-height: 1.3;
  text-align: left;
}

.vault-smart-text-toolbar-dropdown-panel .vault-smart-text-toolbar-heading-option {
  font-family: inherit;
  color: var(--vault-text);
}
.vault-smart-text-toolbar-heading-option--text {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.35;
}
.vault-smart-text-toolbar-heading-option--h1 {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.15;
  padding-top: 0.35rem;
  padding-bottom: 0.35rem;
}
.vault-smart-text-toolbar-heading-option--h2 {
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.2;
  padding-top: 0.28rem;
  padding-bottom: 0.28rem;
}
.vault-smart-text-toolbar-heading-option--h3 {
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.25;
}

.vault-smart-text-editor a {
  color: var(--vault-link, #60a5fa);
  text-decoration: underline;
}
.vault-smart-text-editor a:hover {
  text-decoration: underline;
}

/* Tables: wrap (scroll + menu), header row, resize */
.vault-smart-text-editor .vault-smart-text-table-wrap {
  position: relative;
  margin: 0.5rem 0;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.vault-smart-text-editor .vault-smart-text-table-scroll {
  overflow-x: auto;
  overflow-y: auto;
  max-width: 100%;
  min-width: 0;
  position: relative;
  margin-top: 2.25rem;
  padding-top: 1rem;
}
.vault-smart-text-editor .vault-smart-text-table-menu {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 4;
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem;
  padding: 0.2rem;
  background: var(--vault-bg-card, #1e293b);
  border: 1px solid var(--vault-border);
  border-radius: 0.25rem;
  opacity: 0;
  transition: opacity 0.15s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.vault-smart-text-editor .vault-smart-text-table-wrap {
  padding-top: 0.25rem;
}
.vault-smart-text-editor .vault-smart-text-table-wrap:hover .vault-smart-text-table-menu,
.vault-smart-text-editor .vault-smart-text-table-menu.vault-smart-text-table-menu--visible {
  opacity: 1;
}
.vault-smart-text-editor .vault-smart-text-table-menu button {
  padding: 0.25rem 0.4rem;
  font-size: 0.7rem;
  border: none;
  border-radius: 0.2rem;
  background: var(--vault-input-bg);
  color: var(--vault-text);
  cursor: pointer;
}
.vault-smart-text-editor .vault-smart-text-table-menu button:hover {
  filter: brightness(0.97);
}
/* Table menu tints — map to config/vault-neon-palette.js SMART_TEXT_TABLE_MENU_COLORS */
.vault-smart-text-editor .vault-smart-text-table-menu button[data-action="add-row"] {
  background: rgba(184, 255, 198, 0.72);
  color: #0f172a;
}
.vault-smart-text-editor .vault-smart-text-table-menu button[data-action="add-col"] {
  background: rgba(149, 255, 247, 0.72);
  color: #0f172a;
}
.vault-smart-text-editor .vault-smart-text-table-menu button[data-action="delete-row"] {
  background: rgba(255, 212, 184, 0.78);
  color: #0f172a;
}
.vault-smart-text-editor .vault-smart-text-table-menu button[data-action="delete-col"] {
  background: rgba(255, 179, 167, 0.78);
  color: #1e293b;
}
.vault-smart-text-editor .vault-smart-text-table-menu button[data-action="toggle-header"] {
  background: rgba(174, 181, 255, 0.75);
  color: #0f172a;
}
.vault-smart-text-editor .vault-smart-text-table-menu button[data-action="delete-table"] {
  background: rgba(255, 179, 167, 0.85);
  color: #7f1d1d;
  box-shadow: inset 0 0 0 1px rgba(185, 28, 28, 0.22);
}
.vault-smart-text-editor .vault-smart-text-table {
  border-collapse: collapse;
  width: max-content;
  min-width: 100%;
  font-size: 0.875rem;
  table-layout: auto;
}
.vault-smart-text-editor .vault-smart-text-table thead th {
  background: rgba(148, 163, 184, 0.12);
  color: var(--vault-text);
  font-weight: 700;
  border: 1px solid var(--vault-border);
  padding: 0.35rem 0.4rem;
  vertical-align: top;
  min-width: 2rem;
  min-height: 1.25em;
  text-align: left;
}
.vault-smart-text-editor .vault-smart-text-table td,
.vault-smart-text-editor .vault-smart-text-table tbody th {
  border: 1px solid var(--vault-border);
  padding: 0.35rem 0.4rem;
  vertical-align: top;
  min-width: 2rem;
  min-height: 1.25em;
}
.vault-smart-text-editor .vault-smart-text-table td:focus,
.vault-smart-text-editor .vault-smart-text-table th:focus {
  outline: 2px solid var(--vault-focus-ring);
  outline-offset: -1px;
}
.vault-smart-text-editor .vault-smart-text-table-resize-handle {
  position: absolute;
  z-index: 2;
  background: transparent;
}
.vault-smart-text-editor .vault-smart-text-table-resize-col {
  top: 0;
  right: 0;
  width: 6px;
  height: 100%;
  cursor: col-resize;
}
.vault-smart-text-editor .vault-smart-text-table-resize-col:hover {
  background: var(--vault-focus-ring);
  opacity: 0.5;
}

/* Divider: full width, padding top/bottom */
.vault-smart-text-editor .vault-smart-text-divider {
  display: block;
  width: 100%;
  padding: 0.75rem 0;
  margin: 0.25rem 0;
  border: none;
  border-top: 1px solid var(--vault-border);
  background: transparent;
}

/* Media (image) wrap: bubble menu, resize handle, alignment */
.vault-smart-text-editor .vault-smart-text-media-wrap {
  position: relative;
  margin: 0.5rem 0;
  display: block;
}
.vault-smart-text-editor .vault-smart-text-media-wrap[data-align="left"] .vault-smart-text-media-inner {
  text-align: left;
}
.vault-smart-text-editor .vault-smart-text-media-wrap[data-align="center"] .vault-smart-text-media-inner {
  text-align: center;
}
.vault-smart-text-editor .vault-smart-text-media-wrap[data-align="right"] .vault-smart-text-media-inner {
  text-align: right;
}
.vault-smart-text-editor .vault-smart-text-media-inner {
  position: relative;
  display: inline-block;
  max-width: 100%;
  vertical-align: top;
}
.vault-smart-text-editor .vault-smart-text-media-inner img {
  display: block;
  max-width: 100%;
  height: auto;
  vertical-align: top;
}
.vault-smart-text-editor .vault-smart-text-media-menu {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 4;
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem;
  padding: 0.2rem;
  background: var(--vault-bg-card, #1e293b);
  border: 1px solid var(--vault-border);
  border-radius: 0.25rem;
  opacity: 0;
  transition: opacity 0.15s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.vault-smart-text-editor .vault-smart-text-media-wrap:hover .vault-smart-text-media-menu,
.vault-smart-text-editor .vault-smart-text-media-menu.vault-smart-text-media-menu--visible {
  opacity: 1;
}
.vault-smart-text-editor .vault-smart-text-media-menu button {
  padding: 0.25rem 0.4rem;
  font-size: 0.7rem;
  border: none;
  border-radius: 0.2rem;
  background: var(--vault-input-bg);
  color: var(--vault-text);
  cursor: pointer;
}
.vault-smart-text-editor .vault-smart-text-media-menu button:hover {
  background: var(--vault-border);
}
.vault-smart-text-editor .vault-smart-text-media-resize-handle {
  position: absolute;
  z-index: 2;
  opacity: 0.7;
  background: var(--vault-border);
}
.vault-smart-text-editor .vault-smart-text-media-resize-handle:not(.vault-smart-text-media-resize-handle--right):not(.vault-smart-text-media-resize-handle--bottom) {
  right: 0;
  bottom: 0;
  width: 14px;
  height: 14px;
  cursor: se-resize;
  background: linear-gradient(135deg, transparent 50%, var(--vault-border) 50%);
  border-radius: 2px 0 0 0;
}
.vault-smart-text-editor .vault-smart-text-media-resize-handle--right {
  top: 0;
  right: 0;
  width: 8px;
  height: 100%;
  cursor: col-resize;
}
.vault-smart-text-editor .vault-smart-text-media-resize-handle--bottom {
  bottom: 0;
  left: 0;
  width: 100%;
  height: 8px;
  cursor: row-resize;
}
.vault-smart-text-editor .vault-smart-text-media-inner:hover .vault-smart-text-media-resize-handle {
  opacity: 1;
}

/* Single-line mode: no toolbar, one line, input-like */
.vault-smart-text-wrap--single-line .vault-smart-text-editor {
  min-height: 0;
  height: auto;
  padding: 0.5rem 0.75rem;
  white-space: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
}
.vault-smart-text-wrap--single-line .vault-smart-text-editor br {
  display: none;
}

/* Footer with shortcuts info (multi-line mode only) */
.vault-smart-text-footer {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.25rem;
  min-height: 1.5rem;
}
.vault-smart-text-info-btn {
  padding: 0.25rem;
  border: none;
  border-radius: 0.25rem;
  background: transparent;
  color: var(--vault-text-subtle);
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
}
.vault-smart-text-info-btn:hover {
  color: var(--vault-text);
  background: var(--vault-bg-elevated);
}
.vault-smart-text-shortcuts {
  position: absolute;
  right: 0;
  bottom: 100%;
  margin-bottom: 0.25rem;
  padding: 0.5rem 0.75rem;
  font-size: 0.75rem;
  line-height: 1.5;
  background: var(--vault-bg-elevated);
  border: 1px solid var(--vault-border);
  border-radius: 0.375rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  max-width: 280px;
  z-index: 50;
  white-space: pre-wrap;
}
.vault-smart-text-shortcuts-title {
  font-weight: 600;
  margin-bottom: 0.25rem;
}
.vault-smart-text-footer-wrap {
  position: relative;
}
