*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0f0f0f;
  --surface:#1a1a1a;
  --node-bg:#1c1c1e;
  --border:rgba(255,255,255,0.08);
  --text:#f1f1f1;
  --muted:rgba(241,241,241,0.42);
  --body-text:rgba(241,241,241,0.68);
  --primary:#e07b39;
  --primary-dim:rgba(224,123,57,0.18);
  --font:'Inter',system-ui,sans-serif;
}

html,body{width:100%;height:100%;overflow:hidden;background:var(--bg);
  font-family:var(--font);-webkit-font-smoothing:antialiased}

/* ── canvas ── */
#bg{position:fixed;inset:0;width:100%;height:100%;display:block;pointer-events:none}

/* ── stage ── */
#stage{position:fixed;inset:0;transform-origin:0 0;pointer-events:none}

/* toolbar removed */

/* ── statusbar ── */
.statusbar{
  position:fixed;bottom:16px;left:50%;transform:translateX(-50%);
  z-index:200;display:flex;align-items:center;gap:8px;
  padding:5px 14px;background:var(--surface);border:1px solid var(--border);
  border-radius:99px;font-size:12px;font-weight:500;color:var(--muted);
  letter-spacing:.02em;box-shadow:0 4px 20px rgba(0,0,0,.4);
  pointer-events:none;user-select:none}
.sep{opacity:.3}

/* ── node ── */
.node{
  position:absolute;pointer-events:all;
  background:var(--node-bg);
  border:1.5px solid rgba(255,255,255,.09);
  border-radius:11px;
  box-shadow:0 8px 32px rgba(0,0,0,.55),0 2px 8px rgba(0,0,0,.4);
  display:flex;flex-direction:column;
  min-width:160px;min-height:80px;
  overflow:visible;
  transition:box-shadow 120ms,border-color 120ms;
  will-change:transform}
.node.selected{
  border-color:var(--accent,var(--primary));
  box-shadow:0 8px 32px rgba(0,0,0,.55),0 2px 8px rgba(0,0,0,.4),
             0 0 0 2px var(--accent,var(--primary))}
.node.multi-selected{
  border-color:var(--accent,var(--primary));
  box-shadow:0 8px 32px rgba(0,0,0,.55),0 2px 8px rgba(0,0,0,.4),
             0 0 0 2px var(--accent,var(--primary));
  opacity:.92}

/* header */
.node-header{
  display:flex;align-items:center;gap:8px;
  padding:10px 13px 9px;border-radius:10px 10px 0 0;
  cursor:grab;flex-shrink:0;user-select:none}
.node-header.dragging{cursor:grabbing}

.color-dot{
  flex-shrink:0;width:11px;height:11px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.22);cursor:pointer;
  transition:transform 150ms,border-color 150ms;pointer-events:all}
.color-dot:hover{transform:scale(1.35);border-color:rgba(255,255,255,.6)}

.node-title{
  flex:1;font-size:14px;font-weight:600;color:var(--text);
  outline:none;background:transparent;
  font-family:var(--font);line-height:1.4;min-width:0;
  cursor:text;pointer-events:all}
.node-title:empty::before{content:attr(data-ph);color:var(--muted);pointer-events:none}

/* body */
.node-body{flex:1;padding:2px 13px 13px;overflow:hidden;min-height:44px}
.node-content{
  width:100%;height:100%;min-height:44px;
  font-size:13px;color:var(--body-text);line-height:1.68;
  outline:none;background:transparent;font-family:var(--font);
  cursor:text;pointer-events:all}
.node-content:empty::before{content:attr(data-ph);color:var(--muted);pointer-events:none}

/* ── node component section ── */
.node-comp-section{
  display:flex;flex-direction:column;
  border-top:1px solid rgba(255,255,255,.07);
  border-radius:0 0 10px 10px;
  flex-shrink:0;overflow:hidden}
.node-comp-section:empty{display:none}
.node-body:has(+ .node-comp-section:not(:empty)){padding-bottom:8px}

/* ── node header props button ── */
.node-props-btn{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;width:22px;height:22px;
  border:none;border-radius:5px;
  background:transparent;
  color:rgba(255,255,255,.0);
  opacity:0;pointer-events:none;
  cursor:pointer;transition:background 120ms,color 120ms,opacity 120ms}
/* visible only when has-attrs */
.node-props-btn.has-attrs{opacity:1;pointer-events:all;color:rgba(255,255,255,.45)}
.node-props-btn.has-attrs:hover{background:rgba(255,255,255,.12);color:rgba(255,255,255,.85)}
.npb-badge{
  position:absolute;top:-4px;right:-4px;
  min-width:14px;height:14px;border-radius:7px;
  background:var(--primary);color:#fff;
  font-size:8px;font-weight:700;line-height:14px;
  text-align:center;padding:0 3px;
  pointer-events:none}

/* ── node attrs hover popup ── */
#node-attrs-popup{
  z-index:9999;
  background:#1e1e1e;border:1px solid rgba(255,255,255,.12);
  border-radius:9px;padding:6px 0 8px;
  box-shadow:0 8px 28px rgba(0,0,0,.7);
  pointer-events:none;
  opacity:0;transition:opacity 80ms}
#node-attrs-popup.visible{
  opacity:1;
  animation:nap-in 120ms ease}
@keyframes nap-in{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
@keyframes card-resize{0%{opacity:.5;transform:scaleX(.97)}100%{opacity:1;transform:scaleX(1)}}
.nap-header{
  display:flex;align-items:center;gap:5px;
  padding:4px 12px 6px;
  border-bottom:1px solid rgba(255,255,255,.06);
  margin-bottom:4px}
.nap-count{font-size:10px;font-weight:700;color:rgba(255,255,255,.55);letter-spacing:.04em}
.nap-label{font-size:10px;font-weight:700;color:rgba(255,255,255,.28);letter-spacing:.08em}
.nap-row{
  display:flex;align-items:center;gap:8px;
  padding:4px 12px}
.nap-icon{
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;width:16px;height:16px;border-radius:3px;
  background:rgba(255,255,255,.07);color:rgba(255,255,255,.45)}
.nap-name{font-size:12px;color:rgba(255,255,255,.65);white-space:nowrap}
.nap-empty{display:block;padding:6px 12px;font-size:11px;color:rgba(255,255,255,.25)}

/* ── comp modal node-props mode: hide name/cover ── */
.cmp-modal.node-props-mode .cmp-preview-area,
.cmp-modal.node-props-mode .cmp-field-row{display:none}

/* ── attr card resize flash ── */
.cmp-attr-card.resizing{animation:card-resize 180ms ease}

/* ── node reference chip section ── */
/* Sits right after header (or cover), before body */
.node-ref-section{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:8px 10px 6px;
  border-bottom:1px solid rgba(255,255,255,.07);
  flex-shrink:0}
.node-ref-section--empty{display:none}

/* chip */
.node-ref-chip{
  position:relative;
  width:64px;height:64px;border-radius:8px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  overflow:hidden;cursor:pointer;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:4px;
  flex-shrink:0;
  transition:border-color 120ms,background 120ms}
.node-ref-chip:hover{
  border-color:rgba(255,255,255,.25);
  background:rgba(255,255,255,.1)}
.node-ref-chip-img{
  width:100%;height:100%;object-fit:cover;display:block}
.node-ref-chip svg{
  color:rgba(255,255,255,.35);flex-shrink:0}
.node-ref-chip-label{
  font-size:9px;font-weight:600;
  color:rgba(255,255,255,.45);
  letter-spacing:.03em;text-transform:uppercase;
  text-align:center;
  overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;width:calc(100% - 8px);
  padding:0 2px;line-height:1.2}

/* node-ref context menu */
.node-ref-ctx-menu{
  position:fixed;z-index:9999;
  background:#252525;border:1px solid rgba(255,255,255,.12);
  border-radius:8px;padding:4px;
  min-width:170px;box-shadow:0 8px 28px rgba(0,0,0,.7);
  display:none}
.node-ref-ctx-menu.open{display:block}
.node-ref-ctx-item{
  display:block;width:100%;text-align:left;
  background:none;border:none;
  padding:8px 12px;border-radius:6px;
  font-size:12.5px;font-family:var(--font);
  color:#e8e8e8;cursor:pointer;
  transition:background 100ms,color 100ms}
.node-ref-ctx-item:hover{background:rgba(255,255,255,.09);color:#fff}
.node-ref-ctx-item.danger{color:#f87171}
.node-ref-ctx-item.danger:hover{background:rgba(248,113,113,.15);color:#ff8080}

/* drop target highlight */
.node.comp-drop-target{
  box-shadow:0 0 0 2px var(--primary), 0 0 20px rgba(224,123,57,.25)!important;
  transition:box-shadow 100ms}

/* component block */
.nc-block{
  border-bottom:1px solid rgba(255,255,255,.06);
  padding:0}
.nc-block:last-child{border-bottom:none}

/* component header row */
.nc-header{
  display:flex;align-items:center;gap:7px;
  padding:7px 10px 6px;
  cursor:default}
.nc-icon{
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;width:18px;height:18px;border-radius:4px;
  background:rgba(255,255,255,.07);color:rgba(255,255,255,.5)}
.nc-cover-thumb{width:18px;height:18px;border-radius:4px;object-fit:cover;display:block}
.nc-name{
  flex:1;font-size:11px;font-weight:700;
  color:rgba(255,255,255,.55);letter-spacing:.04em;text-transform:uppercase;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nc-remove{
  display:flex;align-items:center;justify-content:center;
  width:18px;height:18px;border:none;border-radius:4px;
  background:transparent;color:rgba(255,255,255,.2);
  cursor:pointer;opacity:0;flex-shrink:0;
  transition:opacity 120ms,background 100ms,color 100ms}
.nc-block:hover .nc-remove{opacity:1}
.nc-remove:hover{background:rgba(248,113,113,.15);color:#f87171}

/* attribute fields */
.nc-fields{
  display:flex;flex-direction:column;
  padding:0 10px 8px}
.nc-field-row{
  display:flex;flex-direction:column;
  gap:3px;margin-bottom:6px}
.nc-field-row:last-child{margin-bottom:0}
.nc-field-label{
  font-size:10px;font-weight:600;color:rgba(255,255,255,.3);
  letter-spacing:.04em;text-transform:uppercase;padding:0 1px}
.nc-field-input{
  width:100%;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  border-radius:5px;outline:none;
  font-size:12px;font-family:var(--font);
  color:rgba(255,255,255,.7);
  padding:5px 8px;box-sizing:border-box;
  transition:border-color 150ms,background 150ms}
.nc-field-input:focus{
  border-color:rgba(255,255,255,.22);
  background:rgba(255,255,255,.08);color:#fff}
.nc-field-input::placeholder{color:rgba(255,255,255,.18)}
.nc-field-dropzone{
  border:1.5px dashed rgba(255,255,255,.12);
  border-radius:5px;padding:10px;
  text-align:center;
  font-size:9px;font-weight:700;letter-spacing:.08em;
  color:rgba(255,255,255,.18);text-transform:uppercase}

/* ── resize handles ── */
.rh{
  position:absolute;width:9px;height:9px;
  background:#fff;border:1.5px solid var(--accent,var(--primary));
  border-radius:2px;z-index:10;pointer-events:all;
  transition:transform 120ms}
.rh:hover{transform:scale(1.3)!important}
.rh[data-d=nw]{top:-4px;left:-4px;cursor:nw-resize}
.rh[data-d=n] {top:-4px;left:calc(50% - 4px);cursor:n-resize}
.rh[data-d=ne]{top:-4px;right:-4px;cursor:ne-resize}
.rh[data-d=e] {top:calc(50% - 4px);right:-4px;cursor:e-resize}
.rh[data-d=se]{bottom:-4px;right:-4px;cursor:se-resize}
.rh[data-d=s] {bottom:-4px;left:calc(50% - 4px);cursor:s-resize}
.rh[data-d=sw]{bottom:-4px;left:-4px;cursor:sw-resize}
.rh[data-d=w] {top:calc(50% - 4px);left:-4px;cursor:w-resize}

/* ── connection ports ── */
.port{
  position:absolute;width:14px;height:14px;border-radius:50%;
  background:var(--node-bg);border:2.5px solid var(--accent,var(--primary));
  cursor:crosshair;z-index:15;pointer-events:all;
  opacity:0;transition:opacity 150ms,transform 150ms,background 150ms;
  box-shadow:0 0 0 3px rgba(0,0,0,.6)}
.node:hover .port,.node.selected .port{opacity:1}
.port:hover{transform:scale(1.4)!important;background:var(--accent,var(--primary))}
/* base positions — hover scale overrides without breaking translate */
.port[data-s=right] {top:50%;right:-7px; transform:translateY(-50%)}
.port[data-s=left]  {top:50%;left:-7px;  transform:translateY(-50%)}
.port[data-s=top]   {left:50%;top:-7px;  transform:translateX(-50%)}
.port[data-s=bottom]{left:50%;bottom:-7px;transform:translateX(-50%)}
.port[data-s=right]:hover {transform:translateY(-50%) scale(1.4)}
.port[data-s=left]:hover  {transform:translateY(-50%) scale(1.4)}
.port[data-s=top]:hover   {transform:translateX(-50%) scale(1.4)}
.port[data-s=bottom]:hover{transform:translateX(-50%) scale(1.4)}

/* ── color popup ── */
#color-popup{
  position:fixed;z-index:500;display:none;flex-wrap:wrap;gap:6px;
  padding:9px 10px;background:#242424;
  border:1px solid rgba(255,255,255,.12);border-radius:10px;
  box-shadow:0 8px 28px rgba(0,0,0,.7);max-width:210px}
#color-popup.open{display:flex}
.swatch{
  width:22px;height:22px;border-radius:50%;border:2px solid transparent;
  cursor:pointer;flex-shrink:0;transition:transform 120ms,border-color 120ms}
.swatch:hover{transform:scale(1.28);border-color:rgba(255,255,255,.5)}
#color-custom{width:26px;height:22px;border:none;border-radius:4px;
  padding:0;cursor:pointer;background:transparent}

/* ── fmt bar ── */
#fmt-bar{
  position:fixed;z-index:400;display:none;align-items:center;gap:2px;
  padding:5px 8px;background:#242424;
  border:1px solid rgba(255,255,255,.12);border-radius:8px;
  box-shadow:0 4px 20px rgba(0,0,0,.65)}
#fmt-bar.open{display:flex}
.fmt-btn{
  display:flex;align-items:center;justify-content:center;
  width:30px;height:27px;border:none;border-radius:5px;
  background:transparent;color:var(--muted);cursor:pointer;
  font-size:13px;font-weight:600;font-family:var(--font);
  transition:background 120ms,color 120ms}
.fmt-btn:hover{background:rgba(255,255,255,.08);color:var(--text)}
.fmt-btn.on{background:var(--primary-dim);color:var(--primary)}
.fmt-sep{width:1px;height:18px;background:rgba(255,255,255,.1);margin:0 2px}

/* ── editing mode ── */
.node.editing .node-title,
.node.editing .node-content{pointer-events:all!important;user-select:text!important;cursor:text!important}
.node.editing{cursor:default}

/* ── port-tab: small tab outside node edge, shown on proximity ── */
.port-tab{
  position:absolute;
  background:#1e1e1e;
  border:1.5px solid var(--accent,var(--primary));
  border-radius:3px;
  cursor:crosshair;
  z-index:20;
  pointer-events:all;
  opacity:0;
  transition:opacity 180ms ease, background 150ms ease;
}
.port-tab.visible{opacity:1}

/* left/right: narrow pill — height set by JS (node.h - 30px) */
.port-tab[data-s=right]{
  width:10px;
  right:-13px;top:50%;transform:translateY(-50%);
  border-radius:0 5px 5px 0;border-left:none;
}
.port-tab[data-s=left]{
  width:10px;
  left:-13px;top:50%;transform:translateY(-50%);
  border-radius:5px 0 0 5px;border-right:none;
}
/* top/bottom: short pill — width set by JS (node.w - 30px) */
.port-tab[data-s=top]{
  height:10px;
  top:-13px;left:50%;transform:translateX(-50%);
  border-radius:5px 5px 0 0;border-bottom:none;
}
.port-tab[data-s=bottom]{
  height:10px;
  bottom:-13px;left:50%;transform:translateX(-50%);
  border-radius:0 0 5px 5px;border-top:none;
}
.port-tab[data-s=right]:hover {background:var(--accent,var(--primary));transform:translateY(-50%) scaleX(1.35)}
.port-tab[data-s=left]:hover  {background:var(--accent,var(--primary));transform:translateY(-50%) scaleX(1.35)}
.port-tab[data-s=top]:hover   {background:var(--accent,var(--primary));transform:translateX(-50%) scaleY(1.35)}
.port-tab[data-s=bottom]:hover{background:var(--accent,var(--primary));transform:translateX(-50%) scaleY(1.35)}
/* snap highlight during wire drag */
.port-tab.snap-target{
  background:var(--accent,var(--primary));
  box-shadow:0 0 0 3px rgba(224,123,57,.35);
  transition:opacity 100ms,background 80ms,box-shadow 80ms}
.port-tab[data-s=right].snap-target{transform:translateY(-50%) scaleX(1.5)}
.port-tab[data-s=left].snap-target{transform:translateY(-50%) scaleX(1.5)}
.port-tab[data-s=top].snap-target{transform:translateX(-50%) scaleY(1.5)}
.port-tab[data-s=bottom].snap-target{transform:translateX(-50%) scaleY(1.5)}

/* ── branch node ── */
.branch-node{
  flex-direction:column;align-items:stretch;
  padding:0;gap:0;
  border-radius:8px;cursor:grab;
  min-height:unset!important;overflow:visible}
.branch-node:active{cursor:grabbing}
.branch-node.editing{cursor:default}

.branch-rows{
  display:flex;flex-direction:column;width:100%;
  border-radius:8px;overflow:hidden}

.branch-row{
  display:flex;align-items:center;gap:0;
  padding:0 14px 0 14px;
  height:46px;flex-shrink:0}
.branch-row--sep{border-top:1px solid rgba(255,255,255,.07)}

.branch-if{
  font-size:13px;font-weight:600;font-style:italic;
  color:var(--accent,var(--primary));flex-shrink:0;user-select:none;
  min-width:56px}
.branch-if[data-btype="elseif"]{font-size:12px}
.branch-if[data-btype="else"]{color:rgba(255,255,255,.4)}

.branch-cond{
  flex:1;font-size:13px;color:var(--muted);
  outline:none;background:transparent;font-family:var(--font);
  line-height:1.4}
.branch-cond:empty::before{content:attr(data-ph);color:var(--muted);pointer-events:none}
.branch-cond:focus{color:var(--text)}
.branch-node.editing .branch-cond{pointer-events:all!important;user-select:text!important;cursor:text!important}

/* ── Jumper node ── */
.jumper-node{
  min-width:unset!important;min-height:unset!important;
  width:220px;height:60px;
  padding:0;border-radius:10px;cursor:grab;overflow:visible;
  background:rgba(255,255,255,.04)!important;
  border-color:rgba(255,255,255,.1)!important;
  transition:box-shadow 120ms,border-color 120ms,background 150ms!important}
.jumper-node:active{cursor:grabbing}
.jumper-node:hover{
  border-color:rgba(255,255,255,.18)!important;
  background:rgba(255,255,255,.06)!important}
.jumper-node.selected{
  border-color:rgba(255,255,255,.28)!important;
  box-shadow:0 8px 32px rgba(0,0,0,.55),0 2px 8px rgba(0,0,0,.4),
             0 0 0 2px rgba(255,255,255,.2)!important}
.jumper-node.jumper-drag-over{
  border-color:var(--primary)!important;
  background:rgba(224,123,57,.08)!important;
  box-shadow:0 0 0 2px var(--primary),0 8px 32px rgba(0,0,0,.55)!important}

.jumper-inner{width:100%;height:100%;display:flex;align-items:stretch;position:relative;border-radius:inherit;overflow:hidden}

/* ── empty state ── */
.jumper-empty{
  display:flex;align-items:center;gap:10px;
  width:100%;height:100%;padding:0 14px;
  user-select:none;pointer-events:none}
.jumper-empty-icon{
  flex-shrink:0;width:28px;height:28px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.3);
  border:1px solid rgba(255,255,255,.08)}
.jumper-empty-text{
  display:flex;flex-direction:column;gap:2px;min-width:0}
.jumper-empty-title{
  font-size:12px;font-weight:600;color:rgba(255,255,255,.45);line-height:1.2}
.jumper-empty-hint{
  font-size:11px;color:rgba(255,255,255,.2);line-height:1.2}

/* ── linked state ── */
.jumper-link-btn{
  display:flex;align-items:center;gap:0;
  width:100%;height:100%;
  background:transparent;border:none;cursor:pointer;padding:0 0 0 12px;
  font-family:var(--font);text-align:left}
.jumper-link-left{
  flex-shrink:0;width:28px;height:28px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.07);
  color:rgba(255,255,255,.5);margin-right:10px;
  border:1px solid rgba(255,255,255,.1);
  transition:background 150ms,border-color 150ms,color 150ms}
.jumper-link-btn:hover .jumper-link-left{
  background:rgba(255,255,255,.11);border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.8)}
.jumper-link-info{
  flex:1;display:flex;flex-direction:column;justify-content:center;
  gap:3px;min-width:0}
.jumper-link-name{
  font-size:12px;font-weight:600;color:rgba(255,255,255,.8);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.jumper-link-board{
  display:flex;align-items:center;gap:3px;
  font-size:11px;color:rgba(255,255,255,.28);line-height:1.2;
  min-width:0;overflow:hidden}
.jumper-link-board svg{flex-shrink:0;opacity:.5}
.jumper-link-board-text{
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.jumper-link-go{
  flex-shrink:0;width:24px;height:100%;
  display:flex;align-items:center;justify-content:center;
  margin-right:8px;color:rgba(255,255,255,.18);
  transition:color 150ms,transform 150ms}
.jumper-link-btn:hover .jumper-link-go{color:rgba(255,255,255,.6);transform:translateX(2px)}

/* ── dashed drop zone ring when empty ── */
.jumper-node:not(.jumper-linked) .jumper-inner::after{
  content:'';position:absolute;inset:5px;border-radius:7px;
  border:1.5px dashed rgba(255,255,255,.08);pointer-events:none;
  transition:border-color 150ms}
.jumper-node.jumper-drag-over .jumper-inner::after{
  border-color:rgba(224,123,57,.5)}

/* ── branch dot ports (right side only) ── */
.branch-dot{
  width:8px;height:8px;border-radius:50%;
  position:absolute;right:-5px;
  cursor:crosshair;z-index:10;pointer-events:all;
  transform:translateY(-50%);
  transition:transform 150ms ease,opacity 150ms ease;
  opacity:.75;outline:none}
.branch-dot:hover{transform:translateY(-50%) scale(1.6);opacity:1}

/* ── context menu ── */
#ctx-menu{
  position:fixed;z-index:600;display:none;flex-direction:column;
  min-width:190px;padding:6px;
  background:#1e1e1e;border:1px solid rgba(255,255,255,.13);
  border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.7),0 2px 8px rgba(0,0,0,.5);
  font-family:var(--font);pointer-events:all}
#ctx-menu.open{display:flex}

#ctx-menu button{
  display:block;width:100%;padding:9px 14px;text-align:left;
  background:transparent;border:none;border-radius:6px;
  font-size:13px;font-weight:500;color:var(--text);
  cursor:pointer;transition:background 120ms}
#ctx-menu button:hover{background:rgba(255,255,255,.08)}
#ctx-menu button.cancel{color:var(--muted);margin-top:2px}
#ctx-menu button.cancel:hover{background:rgba(255,255,255,.05);color:var(--text)}

/* divider before cancel */
#ctx-menu button.cancel{border-top:1px solid rgba(255,255,255,.06);padding-top:10px;margin-top:4px}

/* ── node right-click context menu ── */
#branch-ctx-menu,#jumper-ctx-menu{
  position:fixed;z-index:700;display:none;flex-direction:column;
  min-width:170px;padding:5px;
  background:#1e1e1e;border:1px solid rgba(255,255,255,.13);
  border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.7),0 2px 8px rgba(0,0,0,.5);
  font-family:var(--font);pointer-events:all}
#branch-ctx-menu.open,#jumper-ctx-menu.open{display:flex}

#node-ctx-menu{
  position:fixed;z-index:700;display:none;flex-direction:column;
  min-width:170px;padding:5px;
  background:#1e1e1e;border:1px solid rgba(255,255,255,.13);
  border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.7),0 2px 8px rgba(0,0,0,.5);
  font-family:var(--font);pointer-events:all}
#node-ctx-menu.open{display:flex}

.ncm-item{
  position:relative;display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:9px 12px;text-align:left;
  background:transparent;border:none;border-radius:6px;
  font-size:13px;font-weight:500;color:var(--text);font-family:var(--font);
  cursor:pointer;transition:background 120ms;gap:6px;user-select:none;
  box-sizing:border-box}
.ncm-item:hover{background:rgba(255,255,255,.08)}
.ncm-item.danger{color:#f87171}
.ncm-item.danger:hover{background:rgba(248,113,113,.1)}

.ncm-divider{width:100%;height:1px;background:rgba(255,255,255,.07);margin:3px 0}

/* ncm disabled */
.ncm-item.disabled{opacity:.35;pointer-events:none;cursor:default}

/* cascading submenu */
.ncm-sub{
  position:absolute;left:calc(100% + 6px);top:-5px;
  display:none;flex-direction:column;min-width:150px;padding:5px;
  background:#1e1e1e;border:1px solid rgba(255,255,255,.13);
  border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.7);
  pointer-events:all;z-index:10}
.ncm-has-sub:hover .ncm-sub{display:flex}

/* bg canvas context menu */
#bg-ctx-menu{
  position:fixed;z-index:700;display:none;flex-direction:column;
  min-width:170px;padding:5px;
  background:#1e1e1e;border:1px solid rgba(255,255,255,.13);
  border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.7),0 2px 8px rgba(0,0,0,.5);
  font-family:var(--font);pointer-events:all}
#bg-ctx-menu.open{display:flex}

/* ── edge context menu ── */
#edge-ctx-menu{
  position:fixed;z-index:700;display:none;flex-direction:column;
  min-width:180px;padding:5px;
  background:#1e1e1e;border:1px solid rgba(255,255,255,.13);
  border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.7),0 2px 8px rgba(0,0,0,.5);
  font-family:var(--font);pointer-events:all}
#edge-ctx-menu.open{display:flex}

/* ── edge label inline input ── */
#edge-label-input-wrap{
  position:fixed;z-index:800;
  display:none;pointer-events:all;
  transform:translate(-50%,-50%)}
#edge-label-input-wrap.open{display:block}
#edge-label-input{
  width:160px;
  background:#1c1c1e;
  border:1.5px solid var(--primary);
  border-radius:7px;
  padding:6px 12px;
  font-size:12px;font-family:var(--font);
  color:#fff;outline:none;
  box-shadow:0 4px 24px rgba(0,0,0,.7),0 0 0 3px rgba(224,123,57,.18);
  text-align:center;
  display:block;
  caret-color:var(--primary)}
#edge-label-input::placeholder{color:rgba(255,255,255,.3)}

/* ── node cover area ── */
.node-cover{
  width:100%;height:180px;overflow:hidden;flex-shrink:0;
  background:#111;
  /* sits between header and body — no radius needed, header above is rounded */
}

/* ── cover modal ── */
#cover-modal{
  position:fixed;inset:0;z-index:800;display:none;
  align-items:center;justify-content:center}
#cover-modal.open{display:flex}

.cm-backdrop{
  position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}

.cm-panel{
  position:relative;z-index:1;width:480px;max-width:calc(100vw - 32px);
  background:#1c1c1e;border:1px solid rgba(255,255,255,.12);
  border-radius:14px;box-shadow:0 24px 64px rgba(0,0,0,.8);
  display:flex;flex-direction:column;overflow:hidden;max-height:calc(100vh - 64px)}

.cm-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px 0;flex-shrink:0}
.cm-title{font-size:15px;font-weight:600;color:var(--text)}
.cm-close{
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;border:none;border-radius:6px;
  background:transparent;color:var(--muted);cursor:pointer;
  transition:background 120ms,color 120ms}
.cm-close:hover{background:rgba(255,255,255,.08);color:var(--text)}

.cm-tabs{
  display:flex;gap:2px;padding:12px 14px 0;flex-shrink:0}
.cm-tab{
  padding:7px 14px;border:none;border-radius:7px;
  background:transparent;color:var(--muted);font-size:13px;font-weight:500;
  font-family:var(--font);cursor:pointer;transition:background 120ms,color 120ms}
.cm-tab:hover{background:rgba(255,255,255,.06);color:var(--text)}
.cm-tab.active{background:var(--primary-dim);color:var(--primary)}

.cm-body{flex:1;overflow:hidden;padding:14px;display:flex;flex-direction:column}

.cm-pane{display:none;flex-direction:column;gap:12px;flex:1;overflow-y:auto}
.cm-pane.active{display:flex}

/* ncm disabled */
.ncm-item.disabled,.ncm-item[disabled]{
  opacity:.38;cursor:default;pointer-events:none}

/* asset toolbar */
.cm-asset-toolbar{
  display:flex;align-items:center;gap:8px;flex-shrink:0}
.cm-search-wrap{
  flex:1;display:flex;align-items:center;gap:8px;
  padding:0 10px;background:#111;border:1px solid rgba(255,255,255,.1);
  border-radius:8px;color:var(--muted);transition:border-color 150ms}
.cm-search-wrap:focus-within{border-color:var(--primary)}
.cm-search{
  flex:1;padding:9px 0;background:transparent;border:none;
  color:var(--text);font-size:13px;font-family:var(--font);outline:none}
.cm-search::placeholder{color:var(--muted)}

/* asset drop zone (wraps grid + empty state) */
.cm-asset-dropzone{
  flex:1;min-height:180px;border:1.5px dashed transparent;
  border-radius:10px;transition:border-color 150ms,background 150ms;
  overflow-y:auto;position:relative}
.cm-asset-dropzone.drag-over{
  border-color:var(--primary);background:var(--primary-dim)}

/* asset grid */
.cm-asset-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));
  gap:8px;padding:4px}
.cm-asset-card{
  border-radius:8px;overflow:hidden;cursor:pointer;position:relative;
  background:#111;border:1.5px solid transparent;
  aspect-ratio:1;transition:border-color 120ms,transform 120ms}
.cm-asset-card:hover{border-color:var(--primary);transform:scale(1.03)}
.cm-asset-card img,.cm-asset-card video{
  width:100%;height:100%;object-fit:cover;display:block}
.cm-asset-name{
  position:absolute;bottom:0;left:0;right:0;padding:4px 6px;
  font-size:10px;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.7));
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* embed pane */
.cm-embed-section{display:flex;flex-direction:column;gap:6px}
.cm-label{font-size:12px;font-weight:500;color:var(--muted)}
.cm-input{
  width:100%;padding:9px 12px;background:#111;border:1px solid rgba(255,255,255,.1);
  border-radius:8px;color:var(--text);font-size:13px;font-family:var(--font);
  outline:none;transition:border-color 150ms,box-shadow 150ms}
.cm-input:focus{border-color:var(--primary)}
.cm-input::placeholder{color:var(--muted)}
.cm-input.cm-input-error{border-color:#f87171;box-shadow:0 0 0 3px rgba(248,113,113,.18)}

/* toggle switches for embed options */
.cm-embed-options{
  display:flex;flex-direction:row;gap:18px;
  padding:12px 14px;background:rgba(255,255,255,.04);
  border-radius:8px;border:1px solid rgba(255,255,255,.06)}
.cm-toggle{
  display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.cm-toggle input[type=checkbox]{display:none}
.cm-toggle-track{
  width:36px;height:20px;border-radius:99px;
  background:rgba(255,255,255,.12);position:relative;flex-shrink:0;
  transition:background 200ms}
.cm-toggle input:checked ~ .cm-toggle-track{background:var(--primary)}
.cm-toggle-thumb{
  position:absolute;top:3px;left:3px;width:14px;height:14px;
  border-radius:50%;background:#fff;
  box-shadow:0 1px 4px rgba(0,0,0,.4);transition:transform 200ms}
.cm-toggle input:checked ~ .cm-toggle-track .cm-toggle-thumb{transform:translateX(16px)}
.cm-toggle-label{font-size:13px;color:var(--text);font-weight:500}

.cm-btn-primary{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 16px;background:var(--primary);color:#fff;
  border:none;border-radius:8px;font-size:13px;font-weight:600;
  font-family:var(--font);cursor:pointer;align-self:flex-start;
  transition:opacity 150ms}
.cm-btn-primary:hover{opacity:.85}

.cm-empty{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;color:var(--muted);font-size:13px;text-align:center;
  padding:24px;line-height:1.6}

/* ══════════════════════════════════════════════════
   LEFT SIDEBAR (Boards + Companents)
══════════════════════════════════════════════════ */
.comp-sidebar{
  position:fixed;top:0;left:0;bottom:0;width:240px;z-index:150;
  background:#111;border-right:1px solid rgba(255,255,255,.07);
  display:flex;flex-direction:column;overflow:hidden;
  font-family:var(--font);user-select:none}

/* ── Boards panel — sits at bottom, fixed height, resizable upward ── */
.boards-panel{
  display:flex;flex-direction:column;
  flex:0 0 403px;
  min-height:80px;
  max-height:403px;
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,.07)}

.boards-tree{
  flex:1;overflow-y:auto;overflow-x:hidden;
  padding:4px 0}
.boards-tree::-webkit-scrollbar{width:3px}
.boards-tree::-webkit-scrollbar-track{background:transparent}
.boards-tree::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:99px}

/* ── Draggable resizer between Companents (top) and Boards (bottom) ── */
.sidebar-resizer{
  height:4px;flex-shrink:0;
  background:rgba(255,255,255,.06);
  cursor:row-resize;
  transition:background 150ms}
.sidebar-resizer:hover{background:rgba(224,123,57,.4)}

/* header */
.comp-sidebar-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 7px 0 14px;height:46px;flex-shrink:0;
  border-bottom:1px solid rgba(255,255,255,.07)}
.comp-sidebar-title{
  font-size:11px;font-weight:700;
  color:rgba(255,255,255,.28);
  letter-spacing:.07em;text-transform:uppercase}
.comp-sidebar-actions{display:flex;gap:1px}
.comp-action-btn{
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;border:none;border-radius:6px;
  background:transparent;color:rgba(255,255,255,.28);cursor:pointer;
  transition:background 140ms,color 140ms}
.comp-action-btn:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.7)}

/* scrollable tree area */
.comp-tree{
  flex:1;overflow-y:auto;overflow-x:hidden;
  padding:4px 0}
.comp-tree::-webkit-scrollbar{width:3px}
.comp-tree::-webkit-scrollbar-track{background:transparent}
.comp-tree::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:99px}

/* ── row base ── */
.ti-row{
  display:flex;align-items:center;
  height:28px;padding:0 8px;
  border-radius:5px;cursor:default;
  font-size:13px;color:rgba(255,255,255,.55);
  transition:background 100ms,color 100ms;
  white-space:nowrap;overflow:hidden;
  position:relative}
.ti-row:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.85)}
.ti-row.selected{background:var(--primary-dim);color:var(--primary)}
.ti-row.drag-over{
  background:rgba(224,123,57,.12)!important;
  outline:1.5px dashed var(--primary);
  outline-offset:-1px;
  color:var(--primary)!important}
.ti-row.dragging{opacity:.35;pointer-events:none}

/* chevron (folder toggle) */
.ti-chevron{
  flex-shrink:0;width:16px;height:16px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.25);
  transition:transform 150ms,color 150ms;
  cursor:pointer}
.ti-chevron svg{display:block}
.ti-row.open > .ti-chevron{transform:rotate(90deg)}

/* icon */
.ti-icon{
  flex-shrink:0;width:15px;height:15px;
  display:flex;align-items:center;justify-content:center;
  margin-right:5px;color:inherit;opacity:.65}
.ti-cover-thumb{
  width:15px;height:15px;border-radius:3px;object-fit:cover;display:block;opacity:1}

/* label */
.ti-label{
  flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;
  font-size:13px;font-weight:500;line-height:1}

/* indent spacer */
.ti-indent{flex-shrink:0;display:inline-block}

/* children wrapper */
.ti-children{display:none}
.ti-children.open{display:block}

/* drop-between line */
.drop-line{
  height:2px;border-radius:1px;
  background:var(--primary);margin:0 10px;
  pointer-events:none}

/* ── Board tree rows ── */
.bt-row{
  display:flex;align-items:center;
  height:28px;padding:0 8px;
  border-radius:5px;cursor:default;
  font-size:13px;color:rgba(255,255,255,.55);
  transition:background 100ms,color 100ms;
  white-space:nowrap;overflow:hidden;
  position:relative}
.bt-row:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.85)}
.bt-row.bt-active{background:var(--primary-dim);color:var(--primary)}
.bt-row.bt-folder{font-weight:500}

.bt-chevron{
  flex-shrink:0;width:16px;height:16px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.25);
  transition:transform 150ms;cursor:pointer}
.bt-chevron svg{display:block}
.bt-row.bt-open > .bt-chevron{transform:rotate(90deg)}

.bt-icon{
  flex-shrink:0;width:15px;height:15px;
  display:flex;align-items:center;justify-content:center;
  margin-right:5px;color:inherit;opacity:.65}

.bt-label{
  flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;
  font-size:13px;font-weight:500;line-height:1}

.bt-children{display:none}
.bt-children.bt-open{display:block}

/* element rows inside a board */
.bt-elem-row{
  display:flex;align-items:center;
  height:26px;padding:0 8px;
  border-radius:5px;cursor:default;
  font-size:12px;color:rgba(255,255,255,.4);
  transition:background 100ms,color 100ms;
  white-space:nowrap;overflow:hidden}
.bt-elem-row:hover{background:rgba(255,255,255,.04);color:rgba(255,255,255,.75);cursor:pointer}
.bt-elem-icon{
  flex-shrink:0;width:14px;height:14px;
  display:flex;align-items:center;justify-content:center;
  margin-right:6px;color:inherit;opacity:.5}
.bt-elem-label{
  flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;
  font-size:12px;line-height:1}

/* ── Boards context menu ── */
#bt-ctx-menu{
  position:fixed;z-index:900;display:none;flex-direction:column;
  min-width:180px;padding:4px;
  background:#1c1c1c;border:1px solid rgba(255,255,255,.11);
  border-radius:9px;
  box-shadow:0 16px 48px rgba(0,0,0,.75),0 2px 8px rgba(0,0,0,.5);
  font-family:var(--font)}
#bt-ctx-menu.open{display:flex}

/* focus flash when clicking element in boards panel */
@keyframes board-focus{0%{box-shadow:0 0 0 4px rgba(224,123,57,.7)}100%{box-shadow:0 0 0 0 rgba(224,123,57,0)}}
.node.board-focus-flash{animation:board-focus 600ms ease-out forwards}

/* drag state */
.bt-row.bt-dragging{opacity:.35;pointer-events:none}
.bt-row.bt-drag-over{background:rgba(224,123,57,.1)!important;outline:1.5px dashed var(--primary);outline-offset:-1px}
.bt-elem-row.bt-elem-dragging{opacity:.45;cursor:grabbing}

/* rename input inside board tree */
.bt-rename-input{
  position:fixed;z-index:960;display:none;
  background:#1e1e1e;border:1.5px solid var(--primary);
  border-radius:5px;color:var(--text);
  font-size:13px;font-weight:500;font-family:var(--font);
  padding:2px 7px;outline:none;
  box-shadow:0 4px 20px rgba(0,0,0,.6)}
.bt-rename-input.open{display:block}

/* ── Sidebar context menu ── */
.s-ctx{
  position:fixed;z-index:900;display:none;flex-direction:column;
  min-width:180px;padding:4px;
  background:#1c1c1c;border:1px solid rgba(255,255,255,.11);
  border-radius:9px;
  box-shadow:0 16px 48px rgba(0,0,0,.75),0 2px 8px rgba(0,0,0,.5);
  font-family:var(--font)}
.s-ctx.open{display:flex}
.s-ctx-item{
  display:block;width:100%;padding:8px 12px;text-align:left;
  background:transparent;border:none;border-radius:6px;
  font-size:13px;font-weight:500;color:rgba(255,255,255,.82);
  font-family:var(--font);cursor:pointer;
  transition:background 100ms}
.s-ctx-item:hover{background:rgba(255,255,255,.07)}
.s-ctx-item.danger{color:#f87171}
.s-ctx-item.danger:hover{background:rgba(248,113,113,.1)}
.s-ctx-sep{height:1px;background:rgba(255,255,255,.07);margin:3px 0}

/* ── Inline rename ── */
.s-rename-input{
  position:fixed;z-index:960;display:none;
  background:#1e1e1e;border:1.5px solid var(--primary);
  border-radius:5px;color:var(--text);
  font-size:13px;font-weight:500;font-family:var(--font);
  padding:2px 7px;outline:none;
  box-shadow:0 4px 20px rgba(0,0,0,.6)}
.s-rename-input.open{display:block}

/* ══════════════════════════════════════════════════
   COMPANENT MODAL
══════════════════════════════════════════════════ */
/* Backdrop: sadece karartma — z-index sidebar'ın (150) altında */
.cmp-modal-backdrop{
  position:fixed;inset:0;
  z-index:140;
  display:none;
  background:rgba(0,0,0,.55)}
.cmp-modal-backdrop.open{display:block}

/* Modal: backdrop'tan bağımsız, sidebar'ın üstünde */
.cmp-modal{
  position:fixed;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  z-index:900;
  width:480px;max-width:calc(100vw - 32px);
  max-height:calc(100vh - 48px);
  background:#161616;
  border:1px solid rgba(255,255,255,.09);
  border-radius:14px;
  box-shadow:0 32px 80px rgba(0,0,0,.85),0 0 0 1px rgba(255,255,255,.04) inset;
  display:flex;flex-direction:column;
  overflow:hidden;font-family:var(--font)}

/* scrollable inner area */
.cmp-modal-scroll{
  flex:1;overflow-y:auto;overflow-x:hidden;min-height:0}
.cmp-modal-scroll::-webkit-scrollbar{width:4px}
.cmp-modal-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:99px}

/* header */
.cmp-modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px 14px;flex-shrink:0;
  border-bottom:1px solid rgba(255,255,255,.06)}
.cmp-modal-title{font-size:14px;font-weight:600;color:var(--text)}
.cmp-modal-close{
  display:flex;align-items:center;justify-content:center;
  width:26px;height:26px;border:none;border-radius:6px;
  background:transparent;color:rgba(255,255,255,.3);cursor:pointer;
  transition:background 120ms,color 120ms}
.cmp-modal-close:hover{background:rgba(255,255,255,.07);color:var(--text)}

/* preview */
.cmp-preview-area{
  height:130px;background:#0d0d0d;
  border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;position:relative;overflow:hidden}
.cmp-preview-content{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center}
.cmp-preview-content img,
.cmp-preview-content video{
  width:100%;height:100%;object-fit:cover;display:block}
.cmp-preview-empty{color:rgba(255,255,255,.15)}

.cmp-change-cover-btn{
  position:absolute;bottom:9px;right:10px;
  display:flex;align-items:center;gap:5px;
  padding:5px 10px;
  background:rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.15);
  border-radius:6px;
  color:rgba(255,255,255,.75);font-size:11px;font-weight:600;
  font-family:var(--font);cursor:pointer;
  opacity:0;
  transition:opacity 160ms,background 120ms,color 120ms;
  backdrop-filter:blur(4px)}
.cmp-preview-area:hover .cmp-change-cover-btn{opacity:1}
.cmp-change-cover-btn:hover{background:rgba(0,0,0,.75);color:#fff}

/* name field */
.cmp-field-row{padding:14px 18px 0;display:flex;flex-direction:column;gap:6px}
.cmp-label{
  font-size:11px;font-weight:600;color:rgba(255,255,255,.28);
  letter-spacing:.06em;text-transform:uppercase}
.cmp-input{
  width:100%;padding:8px 11px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:7px;color:var(--text);
  font-size:13px;font-family:var(--font);outline:none;
  transition:border-color 140ms,background 140ms;box-sizing:border-box}
.cmp-input:focus{border-color:var(--primary);background:rgba(255,255,255,.07)}
.cmp-input::placeholder{color:rgba(255,255,255,.2)}

/* attributes section */
.cmp-attrs-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px 8px}
.cmp-attrs-count{
  font-size:11px;font-weight:600;color:rgba(255,255,255,.2);
  background:rgba(255,255,255,.07);border-radius:99px;padding:1px 7px}

/* ══════════════════════════════════════════
   ATTRIBUTES LIST
   ══════════════════════════════════════════ */

/* Liste her zaman 2 kolon grid */
.cmp-attrs-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
  padding:0 16px}


/* ── Kart: her zaman aynı yapı, wide olanlar iki kolonu kaplar ── */
.cmp-attr-card{
  position:relative;
  border-radius:10px;
  overflow:hidden;
  min-width:0;
  background:#161616;
  border:1px solid rgba(255,255,255,.08);
  transition:border-color 160ms,box-shadow 160ms,opacity 200ms}
.cmp-attr-card:hover{
  border-color:rgba(255,255,255,.16);
  box-shadow:0 2px 12px rgba(0,0,0,.3)}
.cmp-attr-card.dragging{
  opacity:.25;pointer-events:none;
  transform:scale(.97);transition:transform 100ms,opacity 100ms}
.cmp-attr-card.drop-over{
  border-color:var(--primary)!important;
  box-shadow:0 0 0 2px rgba(224,123,57,.25)!important}

/* wide kart: iki kolonu kapla */
.cmp-attr-card.wide{
  grid-column:1 / -1}

/* ── Kart içi yapı ── */
.cmp-attr-inner{
  display:flex;
  flex-direction:column}

/* üst bar: badge + isim + drag + dots */
.cmp-attr-row{
  display:flex;align-items:center;gap:0;
  min-height:42px}

/* Sol tip ikonu alanı */
.cmp-attr-badge{
  display:flex;align-items:center;justify-content:center;
  width:38px;flex-shrink:0;align-self:stretch;
  background:rgba(255,255,255,.04);
  border-right:1px solid rgba(255,255,255,.06);
  color:rgba(255,255,255,.4);
  transition:background 150ms,color 150ms}
.cmp-attr-card:hover .cmp-attr-badge{
  background:rgba(255,255,255,.07);
  color:rgba(255,255,255,.65)}
.cmp-attr-badge svg{display:block}

/* isim alanı */
.cmp-attr-name{
  flex:1;min-width:0;
  background:transparent;border:none;outline:none;
  font-size:12.5px;font-weight:500;font-family:var(--font);
  color:rgba(255,255,255,.6);
  padding:0 9px;
  transition:color 150ms;box-sizing:border-box;
  height:42px;line-height:42px}
.cmp-attr-name:focus{color:#fff}
.cmp-attr-name::placeholder{color:rgba(255,255,255,.2)}

/* drag handle */
.cmp-attr-drag{
  display:flex;align-items:center;justify-content:center;
  width:28px;flex-shrink:0;align-self:stretch;
  cursor:grab;
  color:rgba(255,255,255,.18);
  opacity:0;
  transition:opacity 150ms,color 150ms}
.cmp-attr-card:hover .cmp-attr-drag{opacity:1}
.cmp-attr-drag:hover{color:rgba(255,255,255,.5)}

/* üç nokta */
.cmp-attr-dots{
  display:flex;align-items:center;justify-content:center;
  width:34px;flex-shrink:0;align-self:stretch;
  background:transparent;border:none;cursor:pointer;
  color:rgba(255,255,255,.2);
  opacity:0;
  border-left:1px solid transparent;
  transition:opacity 150ms,background 100ms,color 100ms,border-color 100ms}
.cmp-attr-card:hover .cmp-attr-dots{opacity:1}
.cmp-attr-dots:hover{
  background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.7);
  border-left-color:rgba(255,255,255,.06)}

/* ── değer alanı (string / richtext) ── */
.cmp-attr-value{
  width:100%;
  background:rgba(255,255,255,.025);
  border:none;
  border-top:1px solid rgba(255,255,255,.06);
  outline:none;
  font-size:12px;font-family:var(--font);
  color:rgba(255,255,255,.35);
  padding:8px 10px 9px;
  transition:background 150ms,color 150ms;
  box-sizing:border-box;
  resize:none}
.cmp-attr-value:focus{
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.65)}
.cmp-attr-value::placeholder{color:rgba(255,255,255,.14)}

/* ── dropzone (complist / assetlist) ── */
.cmp-attr-dropzone{
  position:relative;
  border-top:1px solid rgba(255,255,255,.06);
  min-height:80px;
  padding:8px;
  display:flex;
  flex-wrap:wrap;
  align-items:flex-start;
  justify-content:flex-start;
  gap:5px;
  font-size:10px;font-weight:700;letter-spacing:.1em;
  color:rgba(255,255,255,.22);
  text-transform:uppercase;
  background:rgba(255,255,255,.015);
  transition:background 150ms}
/* chip yokken dashed border + label ortalanır */
.cmp-attr-dropzone:not(:has(.attr-ref-item)){
  align-items:center;
  justify-content:center}
/* dashed border */
.cmp-attr-dropzone::after{
  content:'';
  position:absolute;
  inset:5px;
  border:1.5px dashed rgba(255,255,255,.1);
  border-radius:7px;
  pointer-events:none;
  transition:border-color 150ms}
/* chip varken dashed border gizle */
.cmp-attr-dropzone:has(.attr-ref-item)::after{
  display:none}
.cmp-attr-card:hover .cmp-attr-dropzone::after{
  border-color:rgba(255,255,255,.18)}
.cmp-attr-card.drop-over .cmp-attr-dropzone::after{
  border-color:rgba(224,123,57,.5)}

/* ── dropzone: drag-active highlight ── */
.cmp-attr-dropzone.dz-active{
  background:rgba(224,123,57,.07)}
.cmp-attr-dropzone.dz-active::after{
  border-color:rgba(224,123,57,.5)}

/* dropzone label */
.dz-label{
  position:relative;z-index:1;
  pointer-events:none}

/* ── ref chip: sadece kare cover thumbnail ── */
.attr-ref-item{
  position:relative;z-index:1;
  width:52px;height:52px;
  border-radius:7px;
  overflow:hidden;
  background:#1e1e1e;
  border:1px solid rgba(255,255,255,.1);
  flex-shrink:0;
  cursor:default;
  transition:border-color 140ms,transform 100ms}
.attr-ref-item:hover{
  border-color:rgba(255,255,255,.28);
  transform:scale(1.04)}
/* cover resmi */
.attr-ref-thumb{
  width:100%;height:100%;
  object-fit:cover;
  display:block}
/* cover yoksa SVG ikonu ortada */
.attr-ref-icon{
  display:flex;align-items:center;justify-content:center;
  width:100%;height:100%;
  color:rgba(255,255,255,.25)}
.attr-ref-icon svg{display:block}

/* ── ref context menu ── */
.ref-ctx-menu{
  position:fixed;z-index:2000;display:none;flex-direction:column;
  width:170px;padding:4px;
  background:#1c1c1c;border:1px solid rgba(255,255,255,.11);
  border-radius:9px;
  box-shadow:0 12px 40px rgba(0,0,0,.8),0 2px 8px rgba(0,0,0,.4);
  font-family:var(--font)}
.ref-ctx-menu.open{display:flex}
.ref-ctx-item{
  display:flex;align-items:center;
  padding:8px 11px;background:transparent;border:none;border-radius:6px;
  font-size:13px;font-weight:500;color:rgba(255,255,255,.75);
  cursor:pointer;text-align:left;width:100%;
  transition:background 100ms,color 100ms}
.ref-ctx-item:hover{background:rgba(255,255,255,.07);color:#fff}
.ref-ctx-item.danger{color:#f87171}
.ref-ctx-item.danger:hover{background:rgba(248,113,113,.1);color:#fca5a5}

/* add attr wrapper */
.cmp-add-attr-wrap{margin:10px 16px 4px}
.cmp-add-attr-btn{
  display:flex;align-items:center;justify-content:center;gap:7px;
  padding:10px 0;width:100%;
  background:var(--primary);border:none;border-radius:9px;
  color:#fff;font-size:13px;font-weight:600;font-family:var(--font);
  cursor:pointer;
  box-shadow:0 2px 12px rgba(224,123,57,.25);
  transition:opacity 120ms,transform 80ms,box-shadow 120ms}
.cmp-add-attr-btn:hover{
  opacity:.9;
  box-shadow:0 4px 18px rgba(224,123,57,.35)}
.cmp-add-attr-btn:active{transform:scale(.98);box-shadow:none}

/* ── attr type picker popup (shared, fixed) ── */
.attr-type-menu{
  position:fixed;z-index:1100;display:none;flex-direction:column;
  width:200px;padding:4px;
  background:#1c1c1c;border:1px solid rgba(255,255,255,.11);
  border-radius:10px;
  box-shadow:0 16px 48px rgba(0,0,0,.85),0 2px 8px rgba(0,0,0,.5)}
.attr-type-menu.open{display:flex}
.attr-type-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 11px;background:transparent;border:none;border-radius:7px;
  color:rgba(255,255,255,.78);font-size:13px;font-weight:500;
  font-family:var(--font);cursor:pointer;text-align:left;
  transition:background 100ms,color 100ms}
.attr-type-item:hover{background:rgba(255,255,255,.07);color:#fff}
.attr-type-icon{
  display:flex;align-items:center;justify-content:center;
  width:20px;height:20px;border-radius:5px;flex-shrink:0;
  background:rgba(255,255,255,.07);color:rgba(255,255,255,.45)}

/* ── attr row context menu ── */
.attr-row-menu{
  position:fixed;z-index:1100;display:none;flex-direction:column;
  width:190px;padding:5px;
  background:#1c1c1c;border:1px solid rgba(255,255,255,.11);
  border-radius:10px;
  box-shadow:0 16px 48px rgba(0,0,0,.85),0 2px 8px rgba(0,0,0,.5);
  font-family:var(--font)}
.attr-row-menu.open{display:flex}
/* sub positioned to the right (not above) since menu is narrow */
.attr-row-menu .ncm-sub{left:calc(100% + 6px);top:-5px}

/* footer */
.cmp-modal-footer{
  display:flex;justify-content:flex-end;gap:8px;
  padding:12px 18px 14px;flex-shrink:0;
  border-top:1px solid rgba(255,255,255,.06)}
.cmp-btn-cancel{
  padding:7px 16px;background:transparent;
  border:1px solid rgba(255,255,255,.1);border-radius:7px;
  color:rgba(255,255,255,.4);font-size:13px;font-weight:500;
  font-family:var(--font);cursor:pointer;
  transition:background 120ms,color 120ms,border-color 120ms}
.cmp-btn-cancel:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.7);border-color:rgba(255,255,255,.18)}
.cmp-btn-create{
  padding:7px 20px;background:var(--primary);border:none;
  border-radius:7px;color:#fff;font-size:13px;font-weight:600;
  font-family:var(--font);cursor:pointer;
  transition:opacity 120ms,transform 80ms}
.cmp-btn-create:hover{opacity:.88}
.cmp-btn-create:active{transform:scale(.97)}

/* ── cursors ── */
body.pan{cursor:grab!important}
body.pan *{cursor:grab!important}
body.panning{cursor:grabbing!important}
body.panning *{cursor:grabbing!important}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:0ms!important}}

/* ── Save / Load bar ── */
#save-bar{
  position:fixed;bottom:18px;right:18px;
  display:flex;align-items:center;gap:6px;
  z-index:700;pointer-events:all}
#save-bar button{
  display:flex;align-items:center;gap:5px;
  padding:6px 12px;
  background:#1e1e1e;border:1px solid rgba(255,255,255,.12);
  border-radius:8px;color:rgba(255,255,255,.75);
  font-size:12px;font-weight:500;font-family:var(--font);
  cursor:pointer;transition:background 120ms,border-color 120ms,color 120ms}
#save-bar button:hover{background:#2a2a2a;border-color:rgba(255,255,255,.22);color:#fff}
#save-bar button:active{transform:scale(.96)}
#save-toast{
  font-size:11px;color:rgba(255,255,255,.45);font-family:var(--font);
  opacity:0;transition:opacity 300ms;pointer-events:none;white-space:nowrap}
#save-toast.show{opacity:1}
