/*
  Builder Blockly Panel
  ------------------------------------------------------------------
  This file owns the Blockly panel appearance. Keep visual work here so
  the panel can be restyled without chasing Blockly's generated DOM.
*/
:root{
  --builder-blockly-bg:#060b16;
  --builder-blockly-panel:#091223;
  --builder-blockly-panel-2:#0d1b33;
  --builder-blockly-line:rgba(96,165,250,.28);
  --builder-blockly-text:#eef6ff;
  --builder-blockly-muted:#94a3b8;
  --builder-blockly-toolbox-width:274px;
  --builder-blockly-flyout-width:520px;
  --builder-blockly-flyout-margin:30px;
  --builder-blockly-block-text:#14233b;
  --builder-blockly-block-text-soft:#1b2f4f;
  --builder-blockly-block-text-contrast:#0f1b30;
}


#centerBlocklyWorkspace,
#blocklyWorkspace{
  position:absolute;
  inset:0;
  min-width:0;
  min-height:0;
  background:
    radial-gradient(circle at 18% 0%,rgba(59,130,246,.22),rgba(59,130,246,0) 30%),
    radial-gradient(circle at 82% 0%,rgba(34,197,94,.12),rgba(34,197,94,0) 25%),
    var(--builder-blockly-bg);
}

.builder-blockly-panel{
  isolation:isolate;
  overflow:hidden;
  color:var(--builder-blockly-text);
}

.builder-blockly-panel .blocklySvg{
  width:100% !important;
  height:100% !important;
  display:block;
  background:
    radial-gradient(circle at top,#182845 0%,#0b1324 48%,#060b16 100%) !important;
}

.builder-blockly-panel .blocklyMainBackground{
  fill:#08101f !important;
  stroke:#1f3256 !important;
}

.builder-blockly-panel .blocklyGridPattern line{
  stroke:#1d3152 !important;
}

/* Left category/toolbox panel */
.builder-blockly-panel .blocklyToolboxDiv,
.builder-blockly-panel .builder-blockly-toolbox{
  width:var(--builder-blockly-toolbox-width) !important;
  min-width:var(--builder-blockly-toolbox-width) !important;
  max-width:var(--builder-blockly-toolbox-width) !important;
  padding:48px 12px 14px !important;
  box-sizing:border-box !important;
  color:var(--builder-blockly-text) !important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,0) 26%),
    linear-gradient(180deg,rgba(9,18,35,.99) 0%,rgba(12,25,48,.99) 52%,rgba(6,12,24,.99) 100%) !important;
  border-right:1px solid var(--builder-blockly-line) !important;
  box-shadow:
    inset -1px 0 0 rgba(255,255,255,.06),
    12px 0 32px rgba(2,6,23,.36) !important;
  overflow-x:hidden !important;
  overflow-y:auto !important;
  scrollbar-color:#35537e #07101d;
  scrollbar-width:thin;
  position:relative !important;
}

.builder-blockly-panel .blocklyToolboxDiv::before{
  content:'Blockly Blocks';
  position:absolute;
  left:14px;
  right:14px;
  top:12px;
  height:26px;
  display:flex;
  align-items:center;
  padding-left:12px;
  border-radius:999px;
  border:1px solid rgba(125,211,252,.35);
  background:
    linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.055)),
    linear-gradient(135deg,rgba(37,99,235,.55),rgba(14,165,233,.20));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 12px 22px rgba(2,6,23,.28);
  color:#f8fbff;
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  pointer-events:none;
}

.builder-blockly-panel .blocklyTreeRoot{
  min-width:100% !important;
  background:transparent !important;
  color:var(--builder-blockly-text) !important;
  padding:0 !important;
  box-sizing:border-box !important;
}

.builder-blockly-panel .blocklyToolboxCategory{
  margin:0 0 9px !important;
}

.builder-blockly-panel .blocklyTreeRow,
.builder-blockly-panel .builder-blockly-category-row{
  min-width:100% !important;
  min-height:42px !important;
  height:auto !important;
  margin:0 !important;
  padding:8px 12px !important;
  box-sizing:border-box !important;
  border-radius:16px !important;
  border:1px solid rgba(148,163,184,.22) !important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.14) 0%,rgba(255,255,255,.045) 100%) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.18),
    0 10px 20px rgba(2,6,23,.22) !important;
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  color:var(--builder-blockly-text) !important;
  position:relative !important;
  overflow:hidden !important;
  transition:transform .14s ease,background .14s ease,box-shadow .14s ease,border-color .14s ease;
}

.builder-blockly-panel .blocklyTreeRow::before{
  content:'';
  position:absolute;
  left:9px;
  right:9px;
  top:1px;
  height:48%;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.22) 0%,rgba(255,255,255,0) 100%);
  pointer-events:none;
}

.builder-blockly-panel .blocklyTreeRow:hover{
  transform:translateY(-1px);
  border-color:rgba(147,197,253,.44) !important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,.08) 100%) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.24),
    0 14px 24px rgba(15,23,42,.32) !important;
}

.builder-blockly-panel .blocklyTreeSelected,
.builder-blockly-panel .blocklyTreeRow.blocklyTreeSelected{
  border-color:rgba(125,211,252,.70) !important;
  background:
    linear-gradient(180deg,rgba(59,130,246,.48) 0%,rgba(37,99,235,.26) 100%) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.24),
    0 16px 30px rgba(30,64,175,.36) !important;
}

.builder-blockly-panel .blocklyTreeIcon,
.builder-blockly-panel .blocklyTreeIconNone{
  display:none !important;
}

.builder-blockly-panel .builder-blockly-category-icon{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:28px !important;
  height:28px !important;
  flex:0 0 28px !important;
  border-radius:999px !important;
  color:#f8fbff !important;
  font-size:14px !important;
  font-weight:900 !important;
  line-height:1 !important;
  letter-spacing:0 !important;
  background:
    radial-gradient(circle at 28% 24%,rgba(255,255,255,.92) 0%,rgba(255,255,255,.48) 16%,rgba(255,255,255,.14) 34%,rgba(255,255,255,0) 50%),
    linear-gradient(180deg,rgba(255,255,255,.22),rgba(255,255,255,.04) 52%,rgba(255,255,255,0) 100%),
    var(--builder-icon-accent,linear-gradient(135deg,#60a5fa,#2563eb)) !important;
  border:1px solid rgba(255,255,255,.28) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55),
    inset 0 -8px 12px rgba(15,23,42,.16),
    0 10px 18px rgba(2,6,23,.34),
    0 0 0 1px rgba(96,165,250,.18) !important;
  position:relative;
  isolation:isolate;
  z-index:1;
  text-shadow:0 1px 0 rgba(15,23,42,.32) !important;
}

.builder-blockly-panel .builder-blockly-category-icon::before{
  content:'';
  position:absolute;
  inset:2px;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.24),rgba(255,255,255,0) 62%);
  pointer-events:none;
  z-index:-1;
}

.builder-blockly-panel .builder-blockly-category-icon::after{
  content:'';
  position:absolute;
  left:5px;
  right:5px;
  top:4px;
  height:34%;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(255,255,255,0));
  opacity:.88;
  pointer-events:none;
}

.builder-blockly-panel .blocklyTreeLabel,
.builder-blockly-panel .blocklyTreeRowContentContainer,
.builder-blockly-panel .blocklyTreeRowContentContainer span,
.builder-blockly-panel .builder-blockly-category-label{
  min-width:0 !important;
  max-width:none !important;
  overflow:visible !important;
  text-overflow:clip !important;
  white-space:nowrap !important;
  color:var(--builder-blockly-text) !important;
  fill:var(--builder-blockly-text) !important;
  font-size:13px !important;
  line-height:20px !important;
  font-weight:850 !important;
  text-shadow:0 1px 0 rgba(2,6,23,.50) !important;
  position:relative;
  z-index:1;
}

/* Flyout and workspace blocks */
.builder-blockly-panel .blocklyFlyout{
  overflow:visible !important;
  clip-path:none !important;
}

.builder-blockly-panel .blocklyFlyoutBackground{
  width:var(--builder-blockly-flyout-width) !important;
  fill:#0c1528 !important;
  fill-opacity:1 !important;
  stroke:#27477a !important;
  stroke-width:1px !important;
}

.builder-blockly-panel .blocklyFlyout .blocklyBlockCanvas,
.builder-blockly-panel .blocklyFlyout .blocklyBubbleCanvas{
  overflow:visible !important;
  clip-path:none !important;
}

.builder-blockly-panel .blocklyText,
.builder-blockly-panel .blocklyNonEditableText > text,
.builder-blockly-panel .blocklyEditableText > text,
.builder-blockly-panel .blocklyFlyoutLabelText{
  fill:var(--builder-blockly-block-text) !important;
  color:var(--builder-blockly-block-text) !important;
  font-weight:800 !important;
  text-shadow:none !important;
}

.builder-blockly-panel .blocklyDropdownText,
.builder-blockly-panel .blocklyHtmlInput,
.builder-blockly-panel .blocklyFieldText,
.builder-blockly-panel .blocklyFlyoutLabelText text{
  color:var(--builder-blockly-block-text-soft) !important;
  fill:var(--builder-blockly-block-text-soft) !important;
}

.builder-blockly-panel .blocklyEditableText > rect,
.builder-blockly-panel .blocklyNonEditableText > rect{
  fill:#ffffff !important;
  fill-opacity:.28 !important;
  stroke:rgba(15,23,42,.18) !important;
}

.builder-blockly-panel .blocklyPathLight{
  stroke:rgba(255,255,255,.18) !important;
}

.builder-blockly-panel .blocklyPathDark{
  stroke:rgba(15,23,42,.22) !important;
}

.builder-blockly-panel .blocklyDropDownDiv{
  background:rgba(9,18,35,.96) !important;
  border:1px solid rgba(125,211,252,.28) !important;
  color:#eaf4ff !important;
  box-shadow:0 18px 34px rgba(2,6,23,.42) !important;
}

.builder-blockly-panel .blocklyDropDownDiv .goog-menuitem,
.builder-blockly-panel .blocklyDropDownDiv .goog-menuitem-content{
  color:#eaf4ff !important;
}

.builder-blockly-panel .blocklyDropDownDiv .goog-menuitem-highlight,
.builder-blockly-panel .blocklyDropDownDiv .goog-menuitem-hover{
  background:rgba(59,130,246,.24) !important;
}

.builder-blockly-panel .blocklyScrollbarHandle{
  fill:#3b5c8e !important;
}

.builder-blockly-panel .blocklyZoom > image{
  opacity:.86;
}

.logic-panel-card{
  border:1px solid #243041;
  border-radius:12px;
  background:#0b1220;
  padding:10px;
  display:grid;
  gap:8px;
}
.logic-panel-card strong{color:#f8fafc;font-size:13px}
.logic-panel-card small{color:#94a3b8;line-height:1.45}
.logic-target-chip{display:inline-flex;align-items:center;gap:6px;max-width:100%;border:1px solid #334155;background:#111827;color:#dbeafe;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logic-status{min-height:34px;border:1px solid #243041;background:#09111f;border-radius:10px;color:#cbd5e1;padding:8px 10px;font-size:12px;line-height:1.45}
.logic-status.warn{border-color:#7c5200;color:#fde68a;background:#1f1604}
.logic-status.good{border-color:#065f46;color:#bbf7d0;background:#04140f}
.logic-code-preview{width:100%;min-height:160px;border-radius:10px;border:1px solid #243041;background:#020617;color:#dbeafe;font-family:Consolas,"Courier New",monospace;font-size:12px;line-height:1.45;padding:10px;resize:vertical}
.logic-modal{width:min(1280px,96vw);height:min(840px,94vh)}
.logic-modal-body{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:0;min-height:0;background:#020617}
.logic-workspace-wrap{position:relative;min-width:0;min-height:0;background:#111827;overflow:hidden}
.logic-preview-pane{display:flex;flex-direction:column;min-width:0;min-height:0;border-left:1px solid #1e293b;background:#07101d}
.logic-preview-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid #1e293b;background:#0b1220}
.logic-preview-head strong{font-size:13px;color:#f8fafc}
.logic-preview-body{display:flex;flex-direction:column;gap:10px;min-height:0;padding:12px;overflow:auto}
.logic-generated-code{flex:1;min-height:280px;border-radius:10px;border:1px solid #243041;background:#020617;color:#dbeafe;font-family:Consolas,"Courier New",monospace;font-size:12px;line-height:1.45;padding:10px;resize:none}
.logic-help-list{margin:0;padding-left:18px;color:#94a3b8;font-size:12px;line-height:1.55}
.logic-modal-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:10px;border-bottom:1px solid #1e293b;background:#0b1220}
.logic-modal-target{margin-left:auto;color:#94a3b8;font-size:12px;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

@media (max-width:1100px){
  :root{--builder-blockly-flyout-width:440px}
  .center-logic-preview{width:min(430px,calc(100% - 20px));border-left:1px solid #243041;border-top:1px solid #243041;max-height:none}
  .center-logic-target{max-width:220px}
}
@media (max-width:900px){
  :root{--builder-blockly-toolbox-width:240px;--builder-blockly-flyout-width:380px;--builder-blockly-flyout-margin:22px}
  .logic-modal-body{grid-template-columns:1fr}
  .logic-preview-pane{border-left:0;border-top:1px solid #1e293b;max-height:320px}
  .logic-workspace-wrap{min-height:420px}
}
@media (max-width:720px){
  :root{--builder-blockly-toolbox-width:220px;--builder-blockly-flyout-width:340px}
  .center-tabbar{align-items:flex-start;height:auto;min-height:48px;flex-direction:column}
  .center-logic-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}
  .center-tabbar[data-active-tab="canvas"] .center-logic-actions{display:none}
  .center-logic-layout #centerBlocklyWorkspace{inset:0}
}

/* Override the older 26px Blockly offset now that the right panel auto-collapses in Logic mode. */
.center-logic-layout #centerBlocklyWorkspace.builder-blockly-panel{inset:0 !important}
