/* EFL Full Studio — Phase 1b: the cinematic blueprint canvas.
   Built on the EFL theme design tokens (--bg/--panel/--panel2/--line/--muted/--white +
   accents) so it tracks light and dark mode automatically. Fallbacks keep it sane if
   loaded outside the theme. Nodes/links/inspector are injected by public.js. */
.efl-fs{color:var(--white,#e7edff);font:14px/1.5 var(--font,-apple-system,Segoe UI,Roboto,sans-serif);
  display:flex;flex-direction:column;gap:14px;min-height:0}
.efl-fs *{box-sizing:border-box}

/* ---- top bar ---- */
.efl-fs-bar{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap}
.efl-fs-title{font-family:var(--display,inherit);font-size:27px;font-weight:800;letter-spacing:-.5px;margin:0 0 3px;color:var(--white,#e7edff)}
.efl-fs-sub{margin:0;color:var(--muted,#9fb0d6);font-size:13.5px}
.efl-fs-bar-r{display:flex;gap:10px;flex-wrap:wrap}

.efl-fs-btn{appearance:none;border:1px solid var(--line,rgba(120,140,200,.28));
  background:rgba(128,144,200,.08);background:color-mix(in srgb,var(--muted,#8090c0) 10%,transparent);
  color:var(--white,#e7edff);font:inherit;font-weight:650;padding:9px 15px;border-radius:11px;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;transition:.16s;white-space:nowrap}
.efl-fs-btn:hover{border-color:var(--blue,#4f8ff7);background:color-mix(in srgb,var(--blue,#4f8ff7) 12%,transparent)}
.efl-fs-btn--primary{background:linear-gradient(95deg,var(--blue,#4f8ff7),var(--purple,#9168f0));border-color:transparent;color:#fff;box-shadow:0 8px 22px rgba(79,143,247,.26)}
.efl-fs-btn--primary:hover{filter:brightness(1.07);background:linear-gradient(95deg,var(--blue,#4f8ff7),var(--purple,#9168f0))}
.efl-fs-btn[disabled]{opacity:.5;cursor:default}
.efl-fs-plus{font-size:17px;line-height:1;margin-top:-1px}

/* ---- toolbar ---- */
.efl-fs-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.efl-fs-picker{position:relative}
.efl-fs-picker-btn{appearance:none;border:1px solid var(--line,rgba(120,140,200,.24));background:var(--panel2,rgba(12,18,40,.6));
  color:var(--white,#e7edff);font:inherit;font-weight:650;padding:8px 13px;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;gap:9px}
.efl-fs-caret{font-style:normal;font-size:10px;opacity:.7}
.efl-fs-picker-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:230px;z-index:40;display:none;
  background:var(--panel,#0e1424);border:1px solid var(--line,rgba(120,140,200,.24));border-radius:12px;
  box-shadow:var(--shadow,0 18px 50px rgba(2,6,20,.6));overflow:hidden;padding:6px}
.efl-fs-picker.is-open .efl-fs-picker-menu{display:block}
.efl-fs-pick{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;
  appearance:none;border:0;background:transparent;color:var(--white,#e7edff);font:inherit;padding:9px 10px;border-radius:8px;cursor:pointer}
.efl-fs-pick:hover{background:color-mix(in srgb,var(--blue,#4f8ff7) 12%,transparent)}
.efl-fs-pick small{color:var(--muted,#8aa0cf);font-size:11px}
.efl-fs-pick.is-active{color:var(--blue,#6fa8ff)}
.efl-fs-pick--new{border-top:1px solid var(--line,rgba(120,140,200,.18));margin-top:4px;color:var(--blue,#6fa8ff);font-weight:700}

.efl-fs-zoom{display:flex;align-items:center;gap:7px}
.efl-fs-z{appearance:none;border:1px solid var(--line,rgba(120,140,200,.24));background:var(--panel2,rgba(12,18,40,.6));
  color:var(--white,#e7edff);font:inherit;font-weight:600;padding:7px 12px;border-radius:9px;cursor:pointer}
.efl-fs-z:hover{border-color:var(--blue,#4f8ff7)}
.efl-fs-z--ic{width:34px;padding:7px 0;text-align:center;font-size:16px;line-height:1}
.efl-fs-zlevel{min-width:46px;text-align:center;color:var(--muted,#aeb9d8);font-size:12.5px;font-variant-numeric:tabular-nums}

/* ---- board (canvas + inspector) ---- */
.efl-fs-board{display:grid;grid-template-columns:1fr 300px;gap:14px;align-items:stretch;min-height:430px}
.efl-fs-canvas{position:relative;overflow:hidden;border:1px solid var(--line,rgba(120,140,200,.18));border-radius:16px;
  background:var(--panel2,#0a1020);min-height:430px;cursor:grab;touch-action:none}
.efl-fs-canvas.is-panning{cursor:grabbing}
.efl-fs-canvas::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:radial-gradient(var(--line,rgba(120,140,200,.5)) 1px,transparent 1px);background-size:26px 26px}
.efl-fs-canvas::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(820px 300px at 22% -8%,rgba(79,143,247,.12),transparent 60%)}
.efl-fs-world{position:absolute;top:0;left:0;width:1720px;height:860px;transform-origin:0 0;will-change:transform}
.efl-fs-links{position:absolute;top:0;left:0;width:1720px;height:860px;overflow:visible;pointer-events:none}
.efl-fs-link{fill:none;stroke:var(--line,#3356b0);stroke-width:2.5;opacity:.45}
.efl-fs-link.is-active{stroke:url(#efl-fs-grad);stroke-width:3;opacity:1;filter:drop-shadow(0 0 5px rgba(0,200,255,.45))}
.efl-fs-nodes{position:absolute;top:0;left:0;width:100%;height:100%}
.efl-fs-hint{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);color:var(--muted,#8aa0cf);font-size:12px;
  background:color-mix(in srgb,var(--panel,#0e1424) 80%,transparent);padding:6px 12px;border-radius:999px;pointer-events:none;border:1px solid var(--line,rgba(120,140,200,.16))}

/* ---- node card ---- */
.efl-fs-node{position:absolute;width:208px;min-width:168px;min-height:140px;display:flex;flex-direction:column;
  border:1px solid var(--line,rgba(120,140,200,.34));border-radius:14px;overflow:hidden;
  background:linear-gradient(180deg,color-mix(in srgb,var(--panel,#101a30) 90%,transparent),var(--panel,#0b1322));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 0 0 1px rgba(0,200,255,.04),0 12px 30px rgba(2,8,22,.45);
  padding:13px;cursor:grab;user-select:none;transition:border-color .15s,box-shadow .15s}
.efl-fs-node:hover{border-color:color-mix(in srgb,var(--blue,#4f8ff7) 45%,var(--line,#345))}
.efl-fs-node.is-dragging{cursor:grabbing;z-index:6;box-shadow:0 0 0 2px var(--blue,#4f8ff7),0 22px 50px rgba(2,8,22,.6)}
.efl-fs-node.is-selected{border-color:var(--blue,#4f8ff7);box-shadow:0 0 0 2px var(--blue,#4f8ff7),0 0 26px color-mix(in srgb,var(--blue,#4f8ff7) 40%,transparent),0 16px 38px rgba(79,143,247,.32)}
.efl-fs-node-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.efl-fs-node-num{font-size:11px;font-weight:800;color:var(--muted,#8aa0cf);letter-spacing:.5px}
.efl-fs-pill{font-size:10px;font-weight:700;padding:3px 8px;border-radius:999px;border:1px solid transparent;white-space:nowrap}
.efl-fs-node-title{font-size:15.5px;font-weight:750;color:var(--white,#eaf1ff);margin-bottom:9px}
.efl-fs-node-rows{display:flex;flex-direction:column;gap:5px;margin-bottom:11px;flex:1 1 auto;overflow:hidden}
.efl-fs-node-row{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11.5px}
.efl-fs-node-row span{color:var(--muted,#8aa0cf)}
.efl-fs-node-row b{color:var(--white,#dde7fb);font-weight:650;max-width:118px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.efl-fs-node-act{width:100%;appearance:none;border:1px solid var(--line,rgba(120,140,200,.3));border-radius:9px;
  background:color-mix(in srgb,var(--blue,#4f8ff7) 14%,transparent);color:var(--white,#dfeaff);font:inherit;font-weight:650;
  font-size:12px;padding:7px;cursor:pointer;transition:.15s;margin-top:auto;flex:0 0 auto}
.efl-fs-node-act:hover{background:color-mix(in srgb,var(--blue,#4f8ff7) 24%,transparent);border-color:var(--blue,#4f8ff7)}
.efl-fs-node-resize{position:absolute;right:0;bottom:0;width:18px;height:18px;cursor:nwse-resize;z-index:3;
  background:linear-gradient(135deg,transparent 46%,var(--muted,#8aa0cf) 46%,var(--muted,#8aa0cf) 60%,transparent 60%);opacity:.4}
.efl-fs-node-resize:hover{opacity:.85}

/* node states — neon glow tuned toward the reference */
.efl-fs-node.is-locked{opacity:.6;filter:saturate(.65)}
.efl-fs-node.is-locked .efl-fs-node-act{background:transparent;color:var(--muted,#8aa0cf);cursor:not-allowed}
.efl-fs-node.is-ready{border-color:color-mix(in srgb,var(--blue,#4f8ff7) 60%,var(--line,#345));
  box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--blue,#4f8ff7) 30%,transparent),0 0 22px color-mix(in srgb,var(--blue,#4f8ff7) 22%,transparent),0 12px 30px rgba(2,8,22,.45)}
.efl-fs-node.is-complete{border-color:color-mix(in srgb,var(--green,#00f2bd) 62%,var(--line,#345));
  box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--green,#00f2bd) 34%,transparent),0 0 28px color-mix(in srgb,var(--green,#00f2bd) 30%,transparent),0 12px 30px rgba(2,8,22,.45)}
.efl-fs-node.is-approved{border-color:color-mix(in srgb,var(--green,#00f2bd) 66%,var(--line,#345));
  box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--green,#00f2bd) 38%,transparent),0 0 30px color-mix(in srgb,var(--green,#00f2bd) 34%,transparent),0 12px 30px rgba(2,8,22,.45)}
.efl-fs-node.is-generating{border-color:color-mix(in srgb,var(--orange,#ff9c32) 60%,var(--line,#345));animation:efl-fs-pulse 1.6s ease-in-out infinite}
.efl-fs-node.is-failed{border-color:color-mix(in srgb,#ff5c5c 60%,var(--line,#345));
  box-shadow:inset 0 0 0 1px color-mix(in srgb,#ff5c5c 32%,transparent),0 0 24px color-mix(in srgb,#ff5c5c 28%,transparent),0 12px 30px rgba(2,8,22,.45)}
@keyframes efl-fs-pulse{0%,100%{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--orange,#ff9c32) 32%,transparent),0 0 18px color-mix(in srgb,var(--orange,#ff9c32) 20%,transparent),0 12px 30px rgba(2,8,22,.45)}50%{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--orange,#ff9c32) 44%,transparent),0 0 34px color-mix(in srgb,var(--orange,#ff9c32) 42%,transparent),0 12px 30px rgba(2,8,22,.45)}}

.efl-fs-pill--complete,.efl-fs-pill--approved{color:#0a2a20;background:var(--green,#00f2bd);border-color:transparent}
.efl-fs-pill--ready{color:var(--blue,#6fa8ff);background:color-mix(in srgb,var(--blue,#4f8ff7) 16%,transparent);border-color:color-mix(in srgb,var(--blue,#4f8ff7) 35%,transparent)}
.efl-fs-pill--locked,.efl-fs-pill--draft{color:var(--muted,#9fb0d6);background:color-mix(in srgb,var(--muted,#8090c0) 14%,transparent);border-color:color-mix(in srgb,var(--muted,#8090c0) 25%,transparent)}
.efl-fs-pill--generating{color:var(--orange,#ffb35a);background:color-mix(in srgb,var(--orange,#ff9c32) 16%,transparent);border-color:color-mix(in srgb,var(--orange,#ff9c32) 35%,transparent)}
.efl-fs-pill--failed{color:#ff8a8a;background:color-mix(in srgb,#ff5c5c 16%,transparent);border-color:color-mix(in srgb,#ff5c5c 35%,transparent)}

/* ---- inspector ---- */
.efl-fs-inspector{border:1px solid var(--line,rgba(120,140,200,.18));border-radius:16px;background:var(--panel,#0d1426);
  padding:16px;display:flex;flex-direction:column;gap:12px;min-width:0}
.efl-fs-insp-head h2{margin:0 0 3px;font-size:17px;font-weight:750;color:var(--white,#eaf1ff)}
.efl-fs-insp-sub{margin:0;color:var(--muted,#8aa0cf);font-size:12px}
.efl-fs-insp-body{display:flex;flex-direction:column;gap:10px}
.efl-fs-insp-field{display:flex;flex-direction:column;gap:4px}
.efl-fs-insp-field>span{font-size:11px;color:var(--muted,#8aa0cf);text-transform:uppercase;letter-spacing:.4px}
.efl-fs-insp-field>b{font-size:13.5px;color:var(--white,#dde7fb);font-weight:600}
.efl-fs-insp-note{font-size:12px;color:var(--muted,#8aa0cf);line-height:1.5;border-top:1px dashed var(--line,rgba(120,140,200,.2));padding-top:10px}
.efl-fs-insp-empty{color:var(--muted,#8aa0cf);font-size:13px;text-align:center;padding:30px 6px}

/* ---- bottom panels ---- */
.efl-fs-bottom{display:grid;grid-template-columns:1.4fr 1.4fr 1fr auto;gap:14px;align-items:start}
.efl-fs-panel{border:1px solid var(--line,rgba(120,140,200,.18));border-radius:14px;background:var(--panel,#0d1426);padding:14px;min-width:0}
.efl-fs-panel-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.efl-fs-panel-head h3{margin:0;font-size:13.5px;font-weight:750;color:var(--white,#eaf1ff)}
.efl-fs-count{font-size:11px;font-weight:700;color:var(--blue,#6fa8ff);background:color-mix(in srgb,var(--blue,#4f8ff7) 16%,transparent);border-radius:999px;padding:2px 8px}
.efl-fs-panel-body{min-height:64px}
.efl-fs-panel-empty{margin:0;color:var(--muted,#8aa0cf);font-size:12px;line-height:1.5}
.efl-fs-ov-row{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12.5px;padding:3px 0}
.efl-fs-ov-row span{color:var(--muted,#8aa0cf)}
.efl-fs-ov-row b{color:var(--white,#dde7fb);font-weight:600}

.efl-fs-progress{position:relative;width:128px;height:128px;justify-self:center}
.efl-fs-progress svg{width:128px;height:128px;transform:rotate(-90deg)}
.efl-fs-prog-track{fill:none;stroke:var(--line,rgba(120,140,200,.3));stroke-width:9}
.efl-fs-prog-arc{fill:none;stroke:url(#efl-fs-grad);stroke-width:9;stroke-linecap:round;transition:stroke-dashoffset .6s ease}
.efl-fs-prog-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}
.efl-fs-prog-label b{font-size:22px;font-weight:800;color:var(--white,#eaf1ff)}
.efl-fs-prog-label span{font-size:11px;color:var(--muted,#8aa0cf)}

/* ---- modal (default hidden via base rule; opened with .is-open) ---- */
.efl-fs-modal-bg{position:fixed;inset:0;z-index:100000;background:rgba(4,8,20,.62);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  display:none;align-items:center;justify-content:center;padding:18px}
.efl-fs-modal-bg.is-open{display:flex}
.efl-fs-modal{width:min(680px,96vw);max-height:90vh;display:flex;flex-direction:column;overflow:hidden;background:var(--panel,#0e1424);
  border:1px solid var(--line,rgba(120,140,200,.24));border-radius:18px;box-shadow:var(--shadow,0 30px 80px rgba(2,6,20,.7))}
.efl-fs-modal-head{flex:none;display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line,rgba(120,140,200,.16))}
.efl-fs-modal-head h2{margin:0;font-size:19px;font-weight:700;color:var(--white,#e7edff)}
.efl-fs-x{appearance:none;border:0;background:transparent;color:var(--muted,#9fb0d6);font-size:24px;line-height:1;cursor:pointer;padding:0 4px}
.efl-fs-x:hover{color:var(--white,#fff)}
.efl-fs-modal-body{flex:1 1 auto;min-height:0;padding:20px;display:grid;grid-template-columns:1fr 1fr;gap:14px;overflow-y:auto;overflow-x:hidden;
  scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--muted,#8090c0) 40%,transparent) transparent}
.efl-fs-modal-body::-webkit-scrollbar{width:11px}
.efl-fs-modal-body::-webkit-scrollbar-track{background:transparent;margin:8px 0}
.efl-fs-modal-body::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--muted,#8090c0) 30%,transparent);border-radius:10px;border:3px solid transparent;background-clip:padding-box}
.efl-fs-modal-body::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--muted,#8090c0) 52%,transparent);background-clip:padding-box}
.efl-fs-field{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--muted,#aeb9d8)}
.efl-fs-field--full{grid-column:1/-1}
.efl-fs-field[hidden]{display:none}
.efl-fs-field i{color:var(--muted,#6f7da0);font-style:normal;opacity:.85}
.efl-fs-field input,.efl-fs-field select,.efl-fs-field textarea{appearance:none;-webkit-appearance:none;
  background-color:rgba(128,144,200,.07);background-color:color-mix(in srgb,var(--muted,#8090c0) 7%,transparent);
  border:1px solid var(--line,rgba(120,140,200,.22));border-radius:10px;color:var(--white,#e7edff);font:inherit;padding:10px 12px;width:100%}
.efl-fs-field input:focus,.efl-fs-field select:focus,.efl-fs-field textarea:focus{outline:none;border-color:var(--blue,#4f8ff7);background-color:color-mix(in srgb,var(--blue,#4f8ff7) 7%,transparent)}
.efl-fs-field textarea{resize:vertical;min-height:64px}
.efl-fs-field select{padding-right:36px;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5 6 6.5 11 1.5' stroke='%238da0c8' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 13px center}
.efl-fs-field select option{color:#1f2738}
.efl-fs-modal-foot{flex:none;display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--line,rgba(120,140,200,.16))}
.efl-fs-modal--wide{width:min(860px,96vw)}
.efl-fs-sb-intro{grid-column:1/-1;margin:0 0 2px;font-size:12.5px;line-height:1.5;color:var(--muted,#aeb9d8)}
.efl-fs-sb-intro b{color:var(--white,#e7edff);font-weight:650}
/* Script modal: notebook on the left, settings on the right */
.efl-fs-modal-body.efl-fs-script-body{grid-template-columns:1fr 300px;align-items:stretch}
.efl-fs-script-left{display:flex;min-width:0;min-height:0}
.efl-fs-script-right{display:flex;flex-direction:column;gap:12px;min-width:0}
.efl-fs-script-meta{margin-top:auto;font-size:12px;color:var(--muted,#aeb9d8)}
.efl-fs-script-meta b{color:var(--white,#e7edff);font-weight:700}
.efl-fs-notebook{flex:1 1 auto;width:100%;min-height:400px;resize:none;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:26px;
  padding:7px 16px;border-radius:12px;color:var(--white,#e7edff);border:1px solid var(--line,rgba(120,140,200,.22));
  background-color:rgba(128,144,200,.05);background-color:color-mix(in srgb,var(--muted,#8090c0) 5%,transparent);
  background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 25px,rgba(120,140,200,.16) 25px,rgba(120,140,200,.16) 26px);
  background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 25px,color-mix(in srgb,var(--muted,#8090c0) 20%,transparent) 25px,color-mix(in srgb,var(--muted,#8090c0) 20%,transparent) 26px);
  background-attachment:local}
.efl-fs-notebook:focus{outline:none;border-color:var(--blue,#4f8ff7)}
@media(max-width:760px){.efl-fs-modal-body.efl-fs-script-body{grid-template-columns:1fr}.efl-fs-notebook{min-height:300px}}
.efl-fs-sb-list{display:flex;flex-direction:column;gap:10px}
.efl-fs-sb-empty{color:var(--muted,#aeb9d8);font-size:13px;padding:8px 2px}
.efl-fs-sb-item{display:flex;gap:12px;align-items:flex-start;padding:10px;border:1px solid var(--line,rgba(120,140,200,.18));border-radius:12px;
  background:rgba(128,144,200,.05);background:color-mix(in srgb,var(--muted,#8090c0) 5%,transparent)}
.efl-fs-sb-thumb{width:104px;height:58px;flex:none;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;
  font-size:10.5px;color:var(--muted,#8090c0);text-align:center;border:1px solid var(--line,rgba(120,140,200,.2));
  background:rgba(128,144,200,.08);background:color-mix(in srgb,var(--muted,#8090c0) 8%,transparent)}
.efl-fs-sb-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.efl-fs-sb-meta{flex:1 1 auto;min-width:0}
.efl-fs-sb-meta b{display:block;color:var(--white,#e7edff);font-size:13px;font-weight:650;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.efl-fs-sb-meta b i{font-style:normal;font-weight:600;color:var(--muted,#9fb0d6);font-size:11.5px}
.efl-fs-sb-beats{margin-top:5px;display:flex;flex-direction:column;gap:2px}
.efl-fs-sb-beat{color:var(--muted,#9fb0d6);font-size:11.5px;line-height:1.5;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.efl-fs-sb-beat--plain{font-family:inherit}
.efl-fs-sb-t{color:var(--cyan,#46d6e0);font-weight:600}
.efl-fs-sb-act{flex:none}
.efl-fs-sb-act .efl-fs-btn{padding:7px 12px;font-size:12px}

/* ---- toast ---- */
.efl-fs-toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);z-index:100001;
  background:var(--panel,#101a30);border:1px solid var(--blue,#4f8ff7);color:var(--white,#dce8ff);padding:12px 18px;border-radius:12px;
  box-shadow:var(--shadow,0 16px 40px rgba(2,6,20,.6));font-size:13px;opacity:0;transition:.22s;pointer-events:none;max-width:90vw}
.efl-fs-toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
.efl-fs-toast.err{border-color:#ff5c5c;color:#ffd9d9}

/* light-mode contrast fixes for non-flipping accents */
html[data-theme="light"] .efl-fs-toast{color:var(--white,#1f2738)}
html[data-theme="light"] .efl-fs-link{stroke:#b8c2dc}

/* responsive */
@media(max-width:1080px){.efl-fs-board{grid-template-columns:1fr}.efl-fs-inspector{order:2}
  .efl-fs-bottom{grid-template-columns:1fr 1fr}.efl-fs-progress{grid-column:1/-1}}
@media(max-width:640px){.efl-fs-modal-body{grid-template-columns:1fr}.efl-fs-bottom{grid-template-columns:1fr}.efl-fs-title{font-size:23px}}
