/* client-editor v0.2 — стили UI редактора. Префикс .ce-* (client-editor). */

:root {
  --ce-bg: #1A1F16;
  --ce-bg-2: #232a1f;
  --ce-text: #fff;
  --ce-text-mut: rgba(255,255,255,.6);
  --ce-accent: #F4B942;
  --ce-accent-2: #FFCE5E;
  --ce-good: #6FA84A;
  --ce-bad: #ff8a7a;
  --ce-line: rgba(255,255,255,.1);
  --ce-shadow: 0 12px 32px rgba(0,0,0,.35);
}

/* ── корневой режим ─────────────────────────────────────────────── */
html.ce-on { padding-top: 56px; }
html.ce-on body { cursor: default; }

/* ── глушим page-эффекты в editor mode ─────────────────────────── */
html.ce-on *, html.ce-on *::before, html.ce-on *::after {
  animation: none !important;
  transition: none !important;
}
/* hero-параллакс/взрывы — ставим всё в исходное видимое состояние */
html.ce-on .bhero { height: auto !important; min-height: 0 !important; }
html.ce-on .bhero-stage { position: static !important; height: auto !important; padding: 80px 0 !important; }
html.ce-on .bhero, html.ce-on .bhero *, html.ce-on .bhero *::before, html.ce-on .bhero *::after {
  transform: none !important; opacity: 1 !important; filter: none !important; visibility: visible !important;
}
html.ce-on .bhero-line { pointer-events: auto !important; }
html.ce-on .bhero-reward {
  position: static !important; padding: 60px 24px !important;
  background: rgba(244,185,66,.08); margin-top: 40px;
  border-top: 2px dashed rgba(244,185,66,.4);
}
html.ce-on .bhero-text.is-rewarded > * { opacity: 1 !important; pointer-events: auto !important; }
html.ce-on [class*="sticky"], html.ce-on [style*="position:sticky"], html.ce-on [style*="position: sticky"] {
  position: static !important; top: auto !important;
}
html.ce-on .yh-mobile { transform: translateX(100%) !important; }
html.ce-on .marquee, html.ce-on .ticker { animation: none !important; transform: none !important; }
/* анимации появления отключены в editor mode — видим всё сразу */
html.ce-on [data-ce-anim] { opacity: 1 !important; transform: none !important; transition: none !important; }
html.ce-on .hero-arrow, html.ce-on #hero-dots .hero-dot {
  outline: 2px solid rgba(244,185,66,.5); outline-offset: 2px;
}

/* ── подсветка editable элементов ──────────────────────────────── */
html.ce-on .ce-hot-text { outline: 2px dashed rgba(111,168,74,.6); outline-offset: 2px; cursor: text; }
html.ce-on .ce-hot-img  { outline: 2px dashed rgba(244,185,66,.85); outline-offset: 2px; cursor: zoom-in; }
html.ce-on [contenteditable="true"] {
  outline: 2px solid var(--ce-good); outline-offset: 2px;
  background: rgba(255,255,200,.15); min-width: 1ch;
}
html.ce-on .ce-block-hover { outline: 2px solid var(--ce-accent); outline-offset: -2px; }
/* locked element — дашед-рамка серая, hover-подсветка не работает */
html.ce-on [data-ce-locked="1"] {
  outline: 2px dashed rgba(0,0,0,.2); outline-offset: 2px;
}
html.ce-on [data-ce-locked="1"]::after {
  content: '🔒 locked'; position: absolute; top: 4px; left: 4px; z-index: 5;
  font: 600 10px/1 system-ui, sans-serif;
  background: rgba(255,255,255,.92); color: #1A1F16;
  padding: 4px 8px; border-radius: 999px; pointer-events: none;
}

/* бейджи на data-include / data-dynamic */
html.ce-on [data-dynamic], html.ce-on [data-include] { position: relative; }
html.ce-on [data-dynamic]::before, html.ce-on [data-include]::before {
  content: attr(data-edit-label); position: absolute; top: 4px; right: 4px; z-index: 5;
  font: 600 10px/1 system-ui, sans-serif; background: rgba(26,31,22,.78); color: var(--ce-accent);
  padding: 4px 8px; border-radius: 999px; letter-spacing: .04em; text-transform: uppercase;
  pointer-events: none;
}

/* фикс штрихи на самом теле, чтоб не переехало */
html.ce-on { box-sizing: border-box; }

/* ── ВЕРХНЯЯ ПАНЕЛЬ ─────────────────────────────────────────────── */
.ce-bar {
  position: fixed; top: 0; left: 0; right: 0; height: 56px; z-index: 99990;
  background: var(--ce-bg); color: var(--ce-text);
  display: flex; align-items: center; gap: 16px; padding: 0 16px;
  font: 500 14px/1 'Onest', system-ui, sans-serif;
  border-bottom: 1px solid var(--ce-line);
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
}
.ce-bar-left, .ce-bar-center, .ce-bar-right {
  display: flex; align-items: center; gap: 10px;
}
.ce-bar-center { flex: 1; justify-content: center; }

/* ── VIEWPORT SWITCHER ──────────────────────────────────────────── */
.ce-vp-switch {
  display: flex; gap: 2px;
  background: rgba(255,255,255,.06); border: 1px solid var(--ce-line);
  padding: 3px; border-radius: 8px;
}
.ce-bar .ce-vp-switch button {
  height: 30px; min-width: 36px; border: none; padding: 0 8px;
  border-radius: 6px; background: transparent; color: rgba(255,255,255,.6);
}
.ce-bar .ce-vp-switch button:hover { color: #fff; background: rgba(255,255,255,.08); }
.ce-bar .ce-vp-switch button.is-active {
  background: var(--ce-accent); color: var(--ce-bg);
}

/* viewport simulation: тёмный фон вокруг + белая рамка body */
html.ce-vp-tablet, html.ce-vp-mobile { background: #2a2a2a !important; }
html.ce-vp-tablet body, html.ce-vp-mobile body {
  margin: 0 auto !important; box-shadow: 0 0 60px rgba(0,0,0,.4) !important;
  position: relative; min-height: calc(100vh - 56px);
}
html.ce-vp-tablet body { max-width: 768px !important; }
html.ce-vp-mobile body { max-width: 375px !important; }
/* виджеты редактора остаются на полную ширину */
html.ce-vp-tablet .ce-bar, html.ce-vp-mobile .ce-bar,
html.ce-vp-tablet .ce-panel, html.ce-vp-mobile .ce-panel,
html.ce-vp-tablet .ce-toasts, html.ce-vp-mobile .ce-toasts { max-width: none !important; }
.ce-brand {
  font-weight: 800; letter-spacing: -.02em; color: var(--ce-accent);
  padding: 6px 12px; background: rgba(244,185,66,.1); border-radius: 8px;
}
.ce-nav {
  background: var(--ce-bg-2); color: var(--ce-text); border: 1px solid var(--ce-line);
  padding: 8px 12px; border-radius: 8px; font: 500 14px/1 inherit; cursor: pointer; max-width: 280px;
}
.ce-nav option { background: var(--ce-bg); }
.ce-status {
  font-size: 13px; color: var(--ce-text-mut); padding: 6px 12px;
  border-radius: 999px; background: rgba(255,255,255,.04);
}
.ce-status.dirty { color: var(--ce-accent); background: rgba(244,185,66,.1); }
.ce-status.saving { color: rgba(255,255,255,.85); background: rgba(255,255,255,.08); animation: ce-pulse 1.2s ease-in-out infinite; }
.ce-status.saved { color: var(--ce-good); background: rgba(111,168,74,.12); }
.ce-status.error { color: var(--ce-bad); background: rgba(255,138,122,.12); }
@keyframes ce-pulse { 0%, 100% { opacity: 1; } 50% { opacity: .55; } }
.ce-bar .ce-autosave {
  font-size: 11px; font-weight: 700; padding: 0 10px; min-width: auto;
  letter-spacing: .04em; text-transform: uppercase;
  background: rgba(255,255,255,.04); color: rgba(255,255,255,.4);
}
.ce-bar .ce-autosave.is-on { background: rgba(111,168,74,.2); color: var(--ce-good); }
.ce-bar .ce-autosave:hover { background: rgba(111,168,74,.3); }
.ce-bar button {
  background: rgba(255,255,255,.06); color: var(--ce-text); border: 1px solid var(--ce-line);
  padding: 0; min-width: 36px; height: 36px; border-radius: 8px; font: 600 13px/1 inherit;
  cursor: pointer; transition: background-color .12s, transform .08s, color .12s;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding-inline: 8px;
}
.ce-bar button .ce-btn-text { padding-right: 4px; }
.ce-bar button:hover { background: rgba(255,255,255,.12); }
.ce-bar button:active { transform: scale(.97); }
.ce-bar button.is-active { background: var(--ce-accent); color: var(--ce-bg); border-color: transparent; }
.ce-bar button.ce-primary { background: var(--ce-accent); color: var(--ce-bg); border-color: transparent; padding-inline: 14px; }
.ce-bar button.ce-primary:hover { background: var(--ce-accent-2); }
.ce-bar button.ce-primary[disabled] { opacity: .5; cursor: not-allowed; }
.ce-bar button.ce-danger { background: rgba(194,57,47,.6); border-color: transparent; padding-inline: 14px; }
.ce-bar button.ce-danger:hover { background: #c2392f; }
.ce-bar svg { display: block; }

/* ── SIDE PANEL ─────────────────────────────────────────────────── */
.ce-panel {
  position: fixed; top: 56px; right: 0; bottom: 0; width: 380px;
  background: #fff; color: #1A1F16; z-index: 99989;
  transform: translateX(100%); transition: transform .25s ease;
  display: flex; flex-direction: column;
  box-shadow: -16px 0 40px rgba(0,0,0,.15);
  font: 14px/1.5 'Onest', system-ui, sans-serif;
}
.ce-panel.is-open { transform: translateX(0); }
.ce-panel-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid rgba(0,0,0,.08);
}
.ce-panel-title { margin: 0; font-size: 16px; font-weight: 800; letter-spacing: -.01em; }
.ce-panel-close {
  background: transparent; border: none; color: #6E6E6E; font: 700 16px/1 inherit;
  width: 32px; height: 32px; border-radius: 8px; cursor: pointer;
}
.ce-panel-close:hover { background: rgba(0,0,0,.06); color: #1A1F16; }
.ce-panel-body { flex: 1; overflow-y: auto; padding: 18px 20px; }

.ce-panel .ce-field { margin-bottom: 16px; }
.ce-panel .ce-label { display: block; font-size: 12px; font-weight: 700; color: #6E6E6E; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 6px; }
.ce-panel .ce-input {
  width: 100%; padding: 10px 12px; border: 1px solid rgba(0,0,0,.1); border-radius: 8px;
  font: 14px inherit; background: #F5F1E6; outline: none;
}
.ce-panel .ce-input:focus { background: #fff; border-color: #1A1F16; }
.ce-panel .ce-hint { font-size: 12px; color: #6E6E6E; margin: 6px 0 0; }
.ce-panel .ce-tabs { display: flex; gap: 6px; margin: 14px 0 12px; }
.ce-panel .ce-tabs button {
  background: transparent; color: #6E6E6E; border: 1px solid rgba(0,0,0,.08);
  padding: 8px 14px; border-radius: 999px; font: 600 13px/1 inherit; cursor: pointer;
}
.ce-panel .ce-tabs button.is-active { background: #1A1F16; color: #fff; border-color: #1A1F16; }
.ce-panel .ce-preview {
  padding: 12px; background: #F5F1E6; border-radius: 12px; text-align: center; min-height: 80px;
  display: flex; align-items: center; justify-content: center;
}
.ce-panel .ce-preview img { max-height: 200px; max-width: 100%; border-radius: 6px; }
.ce-panel .ce-gallery { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.ce-panel .ce-ic {
  background: #F5F1E6; border: 2px solid transparent; border-radius: 10px;
  padding: 8px; cursor: pointer; aspect-ratio: 1;
}
.ce-panel .ce-ic:hover { border-color: var(--ce-accent); }
.ce-panel .ce-ic img { width: 100%; height: 100%; object-fit: contain; }

/* ── ASSET LIBRARY GRID ─────────────────────────────────────────── */
.ce-asset-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px;
  max-height: 320px; overflow-y: auto;
  padding: 4px;
}
.ce-asset {
  background: #F5F1E6; border: 2px solid transparent; border-radius: 8px;
  padding: 0; cursor: pointer; aspect-ratio: 1; overflow: hidden;
}
.ce-asset:hover { border-color: var(--ce-accent); }
.ce-asset img { width: 100%; height: 100%; object-fit: cover; }
.ce-panel .ce-actions {
  display: flex; gap: 10px; justify-content: flex-end; margin-top: 22px;
  padding-top: 16px; border-top: 1px solid rgba(0,0,0,.06);
}
.ce-panel .ce-actions button {
  padding: 10px 18px; background: #1A1F16; color: #fff; border: none; border-radius: 8px;
  font: 700 14px/1 inherit; cursor: pointer;
}
.ce-panel .ce-ghost { background: transparent !important; color: #1A1F16 !important; border: 1px solid rgba(0,0,0,.12) !important; }
.ce-panel .ce-primary { background: var(--ce-accent) !important; color: #1A1F16 !important; }

.ce-vars { display: grid; gap: 10px; }
.ce-var-row { display: grid; grid-template-columns: 130px 50px 1fr; gap: 10px; align-items: center; }
.ce-var-row code { font: 12px/1.4 ui-monospace, monospace; color: #6E6E6E; }
.ce-var-row input[type=color] { padding: 2px; height: 36px; cursor: pointer; border: 1px solid rgba(0,0,0,.1); border-radius: 6px; }

.ce-hist { list-style: none; padding: 0; margin: 0; }
.ce-hist li { padding: 12px 0; border-bottom: 1px solid rgba(0,0,0,.06); }
.ce-hist li:last-child { border-bottom: none; }
.ce-hist .ce-when { font-size: 12px; color: #6E6E6E; }
.ce-hist .ce-h { font: 11px/1 ui-monospace, monospace; color: #6E6E6E; margin-left: 8px; }
.ce-hist .ce-msg { margin: 4px 0 8px; }
.ce-hist button { font: 600 12px/1 inherit; padding: 6px 12px; }

/* ── BLOCK HOVER TOOLBAR ────────────────────────────────────────── */
.ce-block-toolbar {
  position: absolute; z-index: 99988; display: flex; gap: 2px;
  background: var(--ce-bg); padding: 4px; border-radius: 999px;
  box-shadow: var(--ce-shadow);
}
.ce-block-toolbar button {
  background: transparent; color: var(--ce-text); border: none;
  width: 32px; height: 32px; border-radius: 50%;
  cursor: pointer; display: inline-flex;
  align-items: center; justify-content: center;
}
.ce-block-toolbar button:hover { background: rgba(255,255,255,.14); }
.ce-block-toolbar button.ce-danger:hover { background: #c2392f; }
.ce-block-toolbar .ce-drag-handle { cursor: grab; color: rgba(255,255,255,.5); }
.ce-block-toolbar .ce-drag-handle:hover { color: var(--ce-accent); background: rgba(244,185,66,.1); }
.ce-block-toolbar .ce-drag-handle:active { cursor: grabbing; }
.ce-block-toolbar svg { display: block; }

/* ── DRAG STATE ─────────────────────────────────────────────────── */
html.ce-is-dragging { cursor: grabbing !important; user-select: none; }
html.ce-is-dragging * { cursor: grabbing !important; }
section.ce-dragging { opacity: .3; }
.ce-drag-ghost {
  position: fixed !important; z-index: 99996; pointer-events: none;
  border: 2px solid var(--ce-accent); border-radius: 12px;
  background: rgba(244,185,66,.18); backdrop-filter: blur(2px);
  display: flex; align-items: center; justify-content: center;
  font: 700 14px ui-monospace, monospace; color: var(--ce-bg);
  letter-spacing: .04em; box-shadow: var(--ce-shadow);
}
.ce-drop-indicator {
  position: fixed; z-index: 99997; pointer-events: none;
  background: var(--ce-accent); border-radius: 4px; opacity: 0;
  transition: opacity .1s;
  box-shadow: 0 0 12px var(--ce-accent), 0 0 4px var(--ce-accent);
}
.ce-drop-indicator.is-on { opacity: 1; }

/* ── FORMAT POPUP ───────────────────────────────────────────────── */
.ce-fmt {
  position: absolute; z-index: 99988; display: none;
  background: var(--ce-bg); padding: 6px; border-radius: 10px;
  box-shadow: var(--ce-shadow); gap: 4px;
}
.ce-fmt.is-on { display: inline-flex; }
.ce-fmt button, .ce-fmt select {
  background: transparent; color: var(--ce-text); border: none;
  padding: 6px 8px; border-radius: 6px; font: 600 13px/1 inherit; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
}
.ce-fmt button:hover { background: rgba(255,255,255,.12); }
.ce-fmt button.is-active { background: var(--ce-accent); color: var(--ce-bg); }
.ce-fmt select { border: 1px solid rgba(255,255,255,.2); padding: 5px 8px; }
.ce-fmt svg { display: block; width: 14px; height: 14px; }
.ce-fmt-color {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 28px; cursor: pointer; border-radius: 6px;
  background: rgba(255,255,255,.05);
}
.ce-fmt-color:hover { background: rgba(255,255,255,.12); }
.ce-fmt-color span {
  display: block; width: 14px; height: 14px; border-radius: 3px;
  border: 1px solid rgba(255,255,255,.4);
}
.ce-fmt-color input[type=color] {
  position: absolute; inset: 0; width: 100%; height: 100%;
  opacity: 0; cursor: pointer; border: none; padding: 0;
}

/* ── ONBOARDING ─────────────────────────────────────────────────── */
.ce-onb {
  position: fixed; right: 18px; bottom: 18px; z-index: 99991;
  background: var(--ce-bg); color: var(--ce-text); padding: 18px 20px; border-radius: 14px;
  max-width: 360px; box-shadow: var(--ce-shadow);
  font: 13px/1.5 'Onest', system-ui, sans-serif;
}
.ce-onb h4 { margin: 0 0 8px; font-size: 14px; font-weight: 800; color: var(--ce-accent); }
.ce-onb p { margin: 0 0 8px; }
.ce-onb ul { margin: 0; padding-left: 18px; color: rgba(255,255,255,.85); }
.ce-onb button {
  margin-top: 12px; background: rgba(255,255,255,.12); color: #fff; border: none;
  padding: 7px 14px; border-radius: 6px; font: 600 12px/1 inherit; cursor: pointer;
}
.ce-onb button:hover { background: rgba(255,255,255,.22); }

/* ── REOPEN BUTTON (когда редактор закрыт) ─────────────────────── */
.ce-reopen { font-family: 'Onest', system-ui, sans-serif !important; }

/* ── INSERT ZONES (полоска "+ Добавить блок" между секциями) ───── */
html.ce-on .ce-insert-zone {
  display: flex; align-items: center; justify-content: center;
  height: 36px; margin: 6px 0;
  background: linear-gradient(to right, transparent 0%, rgba(244,185,66,.12) 50%, transparent 100%);
  color: var(--ce-accent); font: 600 12px/1 'Onest', system-ui, sans-serif;
  letter-spacing: .04em; cursor: pointer; opacity: .55;
  border: 2px dashed transparent; border-radius: 8px;
  transition: opacity .15s, border-color .15s, background .15s;
}
html.ce-on .ce-insert-zone:hover {
  opacity: 1; border-color: var(--ce-accent);
  background: linear-gradient(to right, transparent 0%, rgba(244,185,66,.25) 50%, transparent 100%);
}
html.ce-on .ce-insert-zone span {
  background: var(--ce-bg); color: var(--ce-accent);
  padding: 6px 14px; border-radius: 999px;
  text-transform: uppercase; letter-spacing: .08em;
}

/* ── BLOCK PICKER GRID ──────────────────────────────────────────── */
.ce-tabs-blocks { flex-wrap: wrap; }
.ce-blocks-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
.ce-blk {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 18px 10px; background: #F5F1E6; border: 2px solid transparent;
  border-radius: 12px; cursor: pointer; text-align: center;
  transition: border-color .12s, background .12s, transform .08s;
}
.ce-blk:hover { border-color: var(--ce-accent); background: #fff; }
.ce-blk:active { transform: scale(.97); }
.ce-blk-icon { font-size: 28px; line-height: 1; }
.ce-blk-label { font: 600 12px/1.3 inherit; color: #1A1F16; }

/* поиск в picker */
.ce-blk-search { margin-bottom: 12px; }
/* кастомные блоки с кнопкой удаления */
.ce-blk-wrap { position: relative; }
.ce-blk-wrap .ce-blk { width: 100%; }
.ce-blk-del {
  position: absolute; top: 4px; right: 4px;
  background: rgba(255,255,255,.95); border: 1px solid rgba(0,0,0,.08);
  width: 24px; height: 24px; border-radius: 6px; padding: 0;
  cursor: pointer; color: #c2392f; opacity: 0;
  display: inline-flex; align-items: center; justify-content: center;
  transition: opacity .12s, background .12s;
}
.ce-blk-wrap:hover .ce-blk-del { opacity: 1; }
.ce-blk-del:hover { background: #c2392f; color: #fff; }
.ce-blk-del svg { width: 12px; height: 12px; }
.ce-custom-grid { grid-template-columns: 1fr 1fr; }

/* keyboard shortcuts table */
.ce-kbd-tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.ce-kbd-tbl td { padding: 8px 10px; border-bottom: 1px solid rgba(0,0,0,.04); }
.ce-kbd-tbl td:first-child { width: 38%; }
.ce-kbd-tbl kbd {
  background: #F5F1E6; border: 1px solid rgba(0,0,0,.08); border-radius: 4px;
  padding: 3px 6px; font: 600 12px ui-monospace, monospace; color: #1A1F16;
}
.ce-leads-tbl { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 8px; }
.ce-leads-tbl td { padding: 6px 8px; border-bottom: 1px solid rgba(0,0,0,.04); vertical-align: top; }
.ce-leads-tbl td:first-child { width: 40%; color: #6E6E6E; }
.ce-leads-tbl code { font: 600 11px ui-monospace, monospace; }

/* ── OUTLINE / STRUCTURE PANEL ──────────────────────────────────── */
.ce-outline { list-style: none; padding: 0; margin: 0; }
.ce-out-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 12px;
  background: #F9F7F0; border: 1px solid transparent; border-radius: 8px;
  margin-bottom: 4px; cursor: pointer; user-select: none;
  transition: background .12s, border-color .12s;
}
.ce-out-item:hover { background: #fff; border-color: rgba(0,0,0,.08); }
.ce-out-item.is-dragging { opacity: .4; }
.ce-out-item.is-over { border-color: var(--ce-accent); border-style: dashed; }
.ce-out-num {
  width: 22px; height: 22px; flex-shrink: 0;
  background: var(--ce-bg); color: var(--ce-accent);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font: 700 11px ui-monospace, monospace;
}
.ce-out-name { flex: 1; font-weight: 600; font-size: 13px; color: #1A1F16; line-height: 1.3; }
.ce-out-grip { color: rgba(0,0,0,.3); cursor: grab; user-select: none; flex-shrink: 0; }
.ce-out-grip:active { cursor: grabbing; }

/* ── PAGE TEMPLATES GRID ────────────────────────────────────────── */
.ce-tpls {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.ce-tpl {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 16px 12px; background: #F5F1E6; border: 2px solid transparent;
  border-radius: 12px; cursor: pointer; text-align: center;
  font: inherit; color: inherit;
  transition: border-color .12s, background .12s, transform .08s;
}
.ce-tpl:hover { border-color: rgba(244,185,66,.5); background: #fff; }
.ce-tpl.is-active { border-color: var(--ce-accent); background: rgba(244,185,66,.08); }
.ce-tpl-icon { font-size: 32px; line-height: 1; margin-bottom: 4px; }
.ce-tpl-label { font: 700 13px/1.2 inherit; color: #1A1F16; }
.ce-tpl-desc { font: 500 11px/1.3 inherit; color: #6E6E6E; }

/* ── BLOCK SETTINGS row + segmented controls ───────────────────── */
.ce-row { display: flex; gap: 8px; align-items: center; }
.ce-row input[type=color] { width: 50px; height: 36px; padding: 2px; border: 1px solid rgba(0,0,0,.1); border-radius: 6px; cursor: pointer; }
.ce-row input[type=text] { flex: 1; }
.ce-mini { padding: 6px 12px !important; font-size: 12px !important; margin-top: 6px; }
.ce-seg { display: grid; grid-template-columns: repeat(auto-fit, minmax(80px, 1fr)); gap: 6px; }
.ce-seg button {
  background: transparent; color: #1A1F16; border: 1px solid rgba(0,0,0,.12);
  padding: 8px 6px; border-radius: 8px; font: 600 12px/1 inherit; cursor: pointer;
  transition: background .12s, border-color .12s;
}
.ce-seg button:hover { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.2); }
.ce-seg button.is-active { background: var(--ce-accent); color: var(--ce-bg); border-color: transparent; }

/* кнопки undo/redo при disabled */
.ce-bar button[disabled] { opacity: .3; cursor: not-allowed; }

/* ── ADAPTIVE BADGE in inspector ────────────────────────────────── */
.ce-vp-badge {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 10px 14px; margin: 0 0 14px;
  background: linear-gradient(135deg, rgba(244,185,66,.18) 0%, rgba(244,185,66,.05) 100%);
  border: 1px solid rgba(244,185,66,.4); border-radius: 10px;
  font: 500 13px/1.4 inherit; color: #1A1F16;
}
.ce-vp-badge b { font-weight: 800; }
.ce-vp-badge button {
  background: transparent; color: #1A1F16; border: 1px solid rgba(0,0,0,.15);
  width: 28px; height: 28px; border-radius: 6px; cursor: pointer;
  font-weight: 700; flex-shrink: 0;
}
.ce-vp-badge button:hover { background: rgba(0,0,0,.06); }
.ce-hover-badge {
  background: linear-gradient(135deg, rgba(79,134,247,.15) 0%, rgba(79,134,247,.04) 100%);
  border-color: rgba(79,134,247,.4);
}

.ce-state-switch {
  display: flex; gap: 2px; margin-bottom: 12px;
  background: rgba(0,0,0,.04); padding: 3px; border-radius: 8px;
}
.ce-state-switch button {
  flex: 1; padding: 7px 10px; background: transparent; border: none;
  border-radius: 6px; cursor: pointer; font: 600 12px/1 inherit; color: #6E6E6E;
}
.ce-state-switch button:hover { color: #1A1F16; }
.ce-state-switch button.is-active { background: #fff; color: #1A1F16; box-shadow: 0 1px 2px rgba(0,0,0,.06); }

/* ── SELECTED ELEMENT ───────────────────────────────────────────── */
html.ce-on .ce-selected {
  outline: 2px solid #4F86F7 !important; outline-offset: 2px;
  position: relative;
}
html.ce-on .ce-selected[contenteditable="true"] {
  outline: 2px solid var(--ce-good) !important;
  background: rgba(255,255,200,.12);
}

/* ── BREADCRUMB ─────────────────────────────────────────────────── */
.ce-bc {
  display: flex; flex-wrap: wrap; align-items: center; gap: 2px;
  margin-bottom: 10px; padding: 6px 10px; background: #F9F7F0;
  border-radius: 8px; font: 600 11px/1 ui-monospace, monospace;
  color: #888;
}
.ce-bc-item {
  background: transparent; border: none; padding: 4px 6px; border-radius: 4px;
  cursor: pointer; color: #888; font: inherit;
  text-transform: lowercase; letter-spacing: .02em;
}
.ce-bc-item:hover { background: rgba(0,0,0,.06); color: #1A1F16; }
.ce-bc-item.is-active { color: #1A1F16; background: rgba(244,185,66,.2); }
.ce-bc-sep { color: rgba(0,0,0,.2); padding: 0 2px; }

/* ── INSPECTOR (header + tabs внутри ce-panel) ─────────────────── */
.ce-insp-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 12px 14px; margin-bottom: 12px;
  background: #F5F1E6; border-radius: 10px;
}
.ce-insp-head .ce-tag {
  font: 600 12px/1 ui-monospace, monospace; color: #1A1F16;
  background: #fff; padding: 5px 10px; border-radius: 6px; border: 1px solid rgba(0,0,0,.06);
}
.ce-insp-head > div { display: flex; gap: 6px; }
.ce-insp-head button {
  background: transparent; color: #1A1F16; border: 1px solid rgba(0,0,0,.1);
  padding: 0; width: 32px; height: 32px; border-radius: 6px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
}
.ce-insp-head button:hover { background: rgba(0,0,0,.04); }
.ce-insp-head button.ce-danger { color: #c2392f; border-color: rgba(194,57,47,.3); }
.ce-insp-head button.ce-danger:hover { background: #c2392f; color: #fff; }
.ce-insp-head svg { display: block; }

.ce-insp-tabs button {
  background: transparent; color: #6E6E6E; border: none; border-bottom: 2px solid transparent;
  padding: 8px 14px; font: 600 13px/1 inherit; cursor: pointer;
  border-radius: 0;
}
.ce-insp-tabs button.is-active { color: #1A1F16; border-bottom-color: var(--ce-accent); }
.ce-insp-tabs { border-bottom: 1px solid rgba(0,0,0,.06); margin-bottom: 14px; gap: 0; }

.ce-insp-section {
  border: 1px solid rgba(0,0,0,.08); border-radius: 10px;
  margin-bottom: 10px; padding: 0; background: #fff;
}
.ce-insp-section summary {
  cursor: pointer; padding: 12px 14px; font-weight: 700; font-size: 13px;
  text-transform: uppercase; letter-spacing: .06em; color: #1A1F16;
  list-style: none; user-select: none;
  display: flex; align-items: center; justify-content: space-between;
}
.ce-insp-section summary::after {
  content: '▾'; font-size: 10px; color: #999;
  transition: transform .15s;
}
.ce-insp-section[open] summary::after { transform: rotate(180deg); }
.ce-insp-section summary::-webkit-details-marker { display: none; }
.ce-insp-section[open] { padding-bottom: 14px; }
.ce-insp-section > *:not(summary) { padding-inline: 14px; }

.ce-insp-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 6px;
}
.ce-insp-grid label {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 11px; color: #6E6E6E; text-transform: uppercase; letter-spacing: .05em; font-weight: 700;
}
.ce-insp-grid input, .ce-insp-grid select {
  padding: 8px 10px; border: 1px solid rgba(0,0,0,.1); border-radius: 7px;
  font: 13px inherit; background: #F9F7F0; outline: none; text-transform: none;
  color: #1A1F16;
}
.ce-insp-grid input[type=color] { padding: 2px; height: 34px; cursor: pointer; }
.ce-insp-grid input:focus { background: #fff; border-color: #1A1F16; }

.ce-pad-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-top: 6px;
}
.ce-pad-grid input {
  padding: 8px 6px; border: 1px solid rgba(0,0,0,.1); border-radius: 7px;
  font: 13px inherit; background: #F9F7F0; outline: none; text-align: center;
}

/* ── TOASTS (replace alerts) ────────────────────────────────────── */
.ce-toasts {
  position: fixed; right: 18px; bottom: 18px; z-index: 99995;
  display: flex; flex-direction: column-reverse; gap: 8px;
  pointer-events: none;
}
.ce-toast {
  display: flex; align-items: center; gap: 12px;
  background: var(--ce-bg); color: #fff; padding: 12px 16px;
  border-radius: 10px; font: 500 14px/1.4 'Onest', system-ui, sans-serif;
  box-shadow: var(--ce-shadow); pointer-events: auto;
  transform: translateY(20px); opacity: 0;
  transition: transform .25s, opacity .25s;
  min-width: 240px; max-width: 360px;
  border-left: 3px solid var(--ce-accent);
}
.ce-toast.is-on { transform: translateY(0); opacity: 1; }
.ce-toast-success { border-left-color: var(--ce-good); }
.ce-toast-error { border-left-color: var(--ce-bad); }
.ce-toast-info { border-left-color: var(--ce-accent); }
.ce-toast > span { flex: 1; }
.ce-toast-x {
  background: transparent; color: rgba(255,255,255,.5); border: none;
  font: 700 14px/1 inherit; cursor: pointer; padding: 4px 8px;
  border-radius: 4px;
}
.ce-toast-x:hover { background: rgba(255,255,255,.1); color: #fff; }

/* ── SITEMAP OVERLAY ────────────────────────────────────────────── */
.ce-sitemap {
  position: fixed; inset: 0; z-index: 99996;
  background: rgba(0,0,0,.55); display: flex;
  align-items: flex-start; justify-content: center;
  padding: 56px 24px 24px; overflow-y: auto;
}
.ce-sm-modal {
  background: #fff; color: #1A1F16; width: min(1100px, 100%);
  border-radius: 16px; box-shadow: 0 24px 80px rgba(0,0,0,.3);
  max-height: calc(100vh - 80px); display: flex; flex-direction: column;
  font: 14px/1.5 'Onest', system-ui, sans-serif;
}
.ce-sm-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 24px; border-bottom: 1px solid rgba(0,0,0,.06);
}
.ce-sm-head h2 { margin: 0; font-size: 18px; font-weight: 800; }
.ce-sm-close {
  background: transparent; border: none; padding: 6px; border-radius: 8px;
  cursor: pointer; color: #6E6E6E;
  display: inline-flex; align-items: center; justify-content: center;
}
.ce-sm-close:hover { background: rgba(0,0,0,.06); color: #1A1F16; }
.ce-sm-close svg { display: block; }
.ce-sm-body { flex: 1; overflow-y: auto; padding: 20px 24px; }
.ce-sm-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}
.ce-sm-card {
  background: #F5F1E6; border: 2px solid transparent;
  border-radius: 12px; cursor: pointer; overflow: hidden;
  transition: border-color .12s, transform .08s, box-shadow .12s;
  display: flex; flex-direction: column;
}
.ce-sm-card:hover { border-color: var(--ce-accent); box-shadow: 0 6px 18px rgba(0,0,0,.08); }
.ce-sm-card.is-current { border-color: var(--ce-good); background: rgba(111,168,74,.08); }
.ce-sm-thumb {
  aspect-ratio: 16/10; background: linear-gradient(135deg,#fff,#F5F1E6);
  display: flex; align-items: center; justify-content: center; color: rgba(0,0,0,.3);
  font: 700 13px ui-monospace, monospace; padding: 12px; text-align: center;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.ce-sm-card.is-current .ce-sm-thumb { color: var(--ce-good); }
.ce-sm-meta { padding: 12px 14px; flex: 1; }
.ce-sm-title { font-weight: 700; font-size: 14px; margin-bottom: 4px; }
.ce-sm-path { font: 500 11px/1 ui-monospace, monospace; color: #888; }
.ce-sm-actions {
  display: flex; gap: 6px; padding: 10px 12px; border-top: 1px solid rgba(0,0,0,.06);
  opacity: 0; transition: opacity .15s; background: rgba(255,255,255,.5);
}
.ce-sm-card:hover .ce-sm-actions, .ce-sm-card.is-current .ce-sm-actions { opacity: 1; }
.ce-sm-actions button {
  flex: 1; min-width: 32px; padding: 8px 10px; border: none; border-radius: 6px;
  font: 600 12px/1 inherit; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  background: transparent; color: #1A1F16; border: 1px solid rgba(0,0,0,.1);
}
.ce-sm-actions button.ce-primary {
  flex: 2; background: #1A1F16; color: #fff; border-color: transparent;
}
.ce-sm-actions button.ce-primary:hover { background: #2a3526; }
.ce-sm-actions button.ce-danger { color: #c2392f; border-color: rgba(194,57,47,.3); flex: 0 0 32px; }
.ce-sm-actions button.ce-danger:hover { background: #c2392f; color: #fff; }
.ce-sm-actions button:not(.ce-primary):not(.ce-danger):hover { background: rgba(0,0,0,.04); }
.ce-sm-actions svg { display: block; width: 14px; height: 14px; }

/* ── CONTEXT MENU (right-click) ────────────────────────────────── */
.ce-ctx {
  position: absolute; z-index: 99997; min-width: 200px;
  background: #fff; color: #1A1F16; border: 1px solid rgba(0,0,0,.08);
  border-radius: 10px; box-shadow: 0 12px 32px rgba(0,0,0,.18);
  padding: 6px; font: 14px/1 'Onest', system-ui, sans-serif;
}
.ce-ctx button {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; gap: 14px; padding: 8px 12px; border: none; background: transparent;
  border-radius: 6px; font: 500 13px/1.2 inherit; color: #1A1F16; cursor: pointer;
  text-align: left;
}
.ce-ctx button:hover { background: #F5F1E6; }
.ce-ctx button.ce-danger { color: #c2392f; }
.ce-ctx button.ce-danger:hover { background: #c2392f; color: #fff; }
.ce-ctx kbd {
  font: 600 11px ui-monospace, monospace; color: #999; padding: 2px 6px;
  background: rgba(0,0,0,.04); border-radius: 4px; flex-shrink: 0;
}
.ce-ctx button:hover kbd { background: #fff; }
.ce-ctx-sep { height: 1px; background: rgba(0,0,0,.06); margin: 4px 0; }

/* ── INLINE LINK EDITOR ─────────────────────────────────────────── */
.ce-link-ed {
  position: absolute; z-index: 99994;
  background: #fff; color: #1A1F16;
  border: 1px solid rgba(0,0,0,.08); border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.18);
  padding: 12px; min-width: 320px;
  display: flex; flex-direction: column; gap: 10px;
  font: 14px/1.4 'Onest', system-ui, sans-serif;
}
.ce-link-ed .ce-link-url {
  width: 100%; padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.1); border-radius: 8px;
  background: #F5F1E6; outline: none; font: 14px inherit;
}
.ce-link-ed .ce-link-url:focus { background: #fff; border-color: #1A1F16; }
.ce-link-ed .ce-link-target {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: #6E6E6E; cursor: pointer;
}
.ce-link-ed .ce-link-target input { accent-color: var(--ce-accent); }
.ce-link-ed .ce-link-actions {
  display: flex; gap: 8px; justify-content: flex-end;
}
.ce-link-ed button {
  padding: 8px 14px; border: none; border-radius: 8px;
  font: 600 13px/1 inherit; cursor: pointer;
}
.ce-link-ed .ce-primary { background: #1A1F16; color: #fff; }
.ce-link-ed .ce-primary:hover { background: #2a3526; }
.ce-link-ed .ce-ghost { background: transparent; color: #c2392f; border: 1px solid rgba(194,57,47,.3); }
.ce-link-ed .ce-ghost:hover { background: #c2392f; color: #fff; }

/* ── PREVIEW MODE (скрываем chrome, видим только сайт) ──────────── */
html.ce-preview .ce-bar,
html.ce-preview .ce-panel,
html.ce-preview .ce-block-toolbar,
html.ce-preview .ce-insert-zone,
html.ce-preview .ce-onb,
html.ce-preview .ce-fmt { display: none !important; }
html.ce-preview { padding-top: 0 !important; }
html.ce-preview .ce-selected,
html.ce-preview .ce-hot-text,
html.ce-preview .ce-hot-img,
html.ce-preview .ce-block-hover { outline: none !important; }
html.ce-preview [data-include]::before,
html.ce-preview [data-dynamic]::before { display: none !important; }
/* мини-кнопка возврата в правом нижнем — на случай если bar скрыт */
html.ce-preview::after {
  content: '↺ Назад в редактор'; position: fixed; right: 14px; bottom: 14px; z-index: 99999;
  background: var(--ce-bg); color: var(--ce-accent); padding: 8px 14px; border-radius: 999px;
  font: 600 12px/1 'Onest', system-ui, sans-serif; cursor: pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,.25); pointer-events: none;
}

/* ── CE-PANEL CLOSE BUTTON SVG fix ──────────────────────────────── */
.ce-panel-close { display: inline-flex !important; align-items: center; justify-content: center; }
.ce-panel-close svg { display: block; }
