/* ============================================================
   Agently — Agent Command Center (dashboard)
   Premium neutral base, purple as a single sparing accent
   ============================================================ */

:root{
  --bg:#ffffff;
  --bg-gray:#f5f5f7;
  --bg-stage:#fbfbfd;
  --bg-dark:#0a0a0c;
  --ink:#1d1d1f;
  --ink-soft:#6e6e73;
  --ink-faint:#86868b;
  --line:#e7e7ec;
  --line-strong:#d2d2d7;

  --accent:#7c3aed;
  --accent-press:#6d28d9;
  --accent-soft:#f4f0fe;

  --green:#1a8d4a; --green-soft:#e8f7ee;
  --red:#d23b3b;   --red-soft:#fdecec;

  --shadow-sm:0 1px 2px rgba(0,0,0,.04), 0 2px 8px rgba(0,0,0,.04);
  --shadow:0 8px 28px rgba(0,0,0,.08);
  --shadow-lg:0 24px 60px rgba(0,0,0,.16);

  --r:18px; --r-sm:12px; --pill:980px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Geist','Inter',system-ui,-apple-system,sans-serif;
  letter-spacing:-.012em;
  color:var(--ink); background:var(--bg-stage);
  display:grid; grid-template-columns:268px 1fr; height:100vh; overflow:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ---------- blur fade up ---------- */
@keyframes blurUp{from{opacity:0;transform:translateY(16px);filter:blur(8px)}to{opacity:1;transform:none;filter:blur(0)}}
.fade-up{opacity:0;animation:blurUp .8s var(--ease) forwards;animation-delay:calc(var(--d,0)*80ms)}

/* ===================== SIDEBAR ===================== */
.sidebar{
  background:var(--bg);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 14px;gap:16px;overflow-y:auto;
}
.brand{display:flex;align-items:center;gap:11px;padding:6px;text-decoration:none;color:inherit;border-radius:10px;transition:.15s}
.brand:hover{background:var(--bg-gray)}
.brand-mark{width:38px;height:38px;border-radius:11px;background:var(--bg-dark);display:grid;place-items:center;overflow:hidden}
.brand-mark img{width:100%;height:100%;object-fit:cover;display:block}
.brand-mark svg{width:20px;height:20px}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-name{font-weight:600;font-size:17px;letter-spacing:-.02em}
.brand-sub{font-size:11px;color:var(--ink-faint);font-weight:450}

.nav{display:flex;flex-direction:column;gap:2px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:9px;
  font-size:13.5px;font-weight:450;color:var(--ink-soft);cursor:pointer;transition:.15s var(--ease)}
.nav-item .nav-ic{width:17px;display:grid;place-items:center;color:var(--ink-faint)}
.nav-item:hover{background:var(--bg-gray);color:var(--ink)}
.nav-item.active{background:var(--accent-soft);color:var(--accent-press)}
.nav-item.active .nav-ic{color:var(--accent)}
.nav-ic svg{width:16px;height:16px}

.panel{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:14px}
.panel-title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;text-align:center}
.stat{display:flex;flex-direction:column;gap:2px}
.stat-num{font-size:23px;font-weight:600;letter-spacing:-.03em;color:var(--ink)}
.stat-num.running{color:var(--accent)}
.stat-num.done{color:var(--green)}
.stat-label{font-size:10.5px;color:var(--ink-faint);font-weight:450}

.templates{display:flex;flex-direction:column;gap:6px}
.tpl{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:10px;border:1px solid var(--line);
  background:var(--bg);cursor:pointer;transition:.18s var(--ease);text-align:left;width:100%;font-family:inherit}
.tpl:hover{border-color:var(--line-strong);background:var(--bg-gray)}
.tpl-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-size:15px;flex-shrink:0;color:#fff}
.tpl-ic svg{width:16px;height:16px}
.card-ic svg{width:17px;height:17px}
.tpl-body{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.tpl-name{font-size:13px;font-weight:600}
.tpl-desc{font-size:10.5px;color:var(--ink-faint);font-weight:450;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tpl-plus{margin-left:auto;color:var(--ink-faint);font-size:16px;font-weight:500}
.tpl:hover .tpl-plus{color:var(--accent)}

.legend{display:flex;flex-direction:column;gap:8px}
.legend-row{display:flex;align-items:center;gap:9px;font-size:12.5px;font-weight:450;color:var(--ink-soft)}
.legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}

.sidebar-foot{margin-top:auto;display:flex;align-items:center;gap:10px;padding:8px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg)}
.avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:var(--accent);color:#fff;
  display:grid;place-items:center;font-weight:600;font-size:12.5px;overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}
.who{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.who-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.who-plan{font-size:11px;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.signout{margin-left:auto;width:30px;height:30px;border-radius:8px;border:none;background:transparent;color:var(--ink-faint);
  cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:.15s}
.signout svg{width:16px;height:16px}
.signout:hover{background:var(--bg-gray);color:var(--ink)}

/* ===================== MAIN ===================== */
.main{display:flex;flex-direction:column;min-width:0;position:relative}
.topbar{display:flex;align-items:center;gap:16px;padding:13px 22px;background:rgba(255,255,255,.8);
  backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--line);z-index:5}
.topbar-left{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.board-title{font-size:17px;font-weight:600;letter-spacing:-.025em;color:var(--ink);border:none;background:transparent;
  outline:none;font-family:inherit;padding:2px 6px;border-radius:7px;margin-left:-6px;width:220px;transition:.15s}
.board-title:hover{background:var(--bg-gray)}
.board-title:focus{background:var(--bg-gray);box-shadow:0 0 0 4px var(--accent-soft)}
.board-meta{font-size:11.5px;color:var(--ink-faint);font-weight:450}

.search{margin-left:auto;display:flex;align-items:center;gap:9px;background:var(--bg-gray);border:1px solid transparent;
  border-radius:var(--pill);padding:9px 16px;width:min(380px,34vw);transition:.18s var(--ease)}
.search:focus-within{background:#fff;border-color:var(--line-strong)}
.search-ic{color:var(--ink-faint);font-size:15px}
.search input{border:none;outline:none;background:transparent;font-family:inherit;font-size:14px;width:100%;color:var(--ink)}

.topbar-right{display:flex;align-items:center;gap:9px}
.btn{display:inline-flex;align-items:center;gap:7px;font-family:inherit;font-size:13.5px;font-weight:500;
  padding:9px 16px;border-radius:var(--pill);cursor:pointer;border:1px solid transparent;transition:.18s var(--ease);white-space:nowrap}
.btn span{font-size:13px;line-height:1}
.btn.ghost{background:#fff;border-color:var(--line-strong);color:var(--ink)}
.btn.ghost:hover{background:var(--bg-gray)}
.btn.primary{background:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-press)}
.btn.lg{padding:13px 22px;font-size:15px}
.ic-play{display:inline-flex;align-items:center}
.ic-play svg{width:11px;height:11px}
.run-btn .ic-play svg{width:10px;height:10px}

/* ===================== STAGE / CANVAS ===================== */
.stage{position:relative;flex:1;overflow:hidden;cursor:grab;background-color:var(--bg-stage)}
.stage.panning{cursor:grabbing}
.world{position:absolute;top:0;left:0;width:8000px;height:6000px;transform-origin:0 0;
  background-image:radial-gradient(circle, rgba(0,0,0,.055) 1.2px, transparent 1.4px);background-size:26px 26px}
.wires{position:absolute;top:0;left:0;width:8000px;height:6000px;overflow:visible;pointer-events:none}
.wire{fill:none;stroke:var(--accent);stroke-width:2.2;opacity:.55}
.wire.temp{stroke-dasharray:6 6;opacity:.85}

/* ===================== AGENT CARD ===================== */
.card{position:absolute;width:286px;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
  transition:box-shadow .2s var(--ease),border-color .2s var(--ease),transform .05s;--accent:#7c3aed}
.card.spawn{animation:blurUp .5s var(--ease)}
.card:hover{box-shadow:var(--shadow);border-color:var(--line-strong)}
.card.dragging{box-shadow:var(--shadow-lg);cursor:grabbing;z-index:50!important}
.card.dim{opacity:.34;filter:grayscale(.2)}
.card.match{box-shadow:0 0 0 2px var(--accent), var(--shadow)}
.card-top{height:4px;border-radius:var(--r) var(--r) 0 0;background:var(--accent)}
.card-head{display:flex;align-items:center;gap:10px;padding:13px 14px 9px;cursor:grab}
.card-head:active{cursor:grabbing}
.card-ic{width:34px;height:34px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;font-size:16px;color:#fff;background:var(--accent)}
.card-name{font-size:14.5px;font-weight:600;color:var(--ink);border:none;background:transparent;outline:none;
  font-family:inherit;width:100%;padding:3px 5px;border-radius:7px;margin-left:-5px}
.card-name:hover{background:var(--bg-gray)}
.card-name:focus{background:var(--bg-gray);box-shadow:0 0 0 3px var(--accent-soft)}
.card-del{margin-left:auto;width:26px;height:26px;border-radius:8px;flex-shrink:0;border:none;background:transparent;
  color:var(--ink-faint);cursor:pointer;font-size:15px;display:grid;place-items:center;transition:.15s}
.card-del:hover{background:var(--red-soft);color:var(--red)}

.card-body{padding:2px 14px 14px;display:flex;flex-direction:column;gap:10px}
.field{display:flex;flex-direction:column;gap:5px}
.field-label{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-faint)}

.model-select{position:relative}
.model-select select{width:100%;appearance:none;font-family:inherit;font-size:13px;font-weight:500;color:var(--ink);
  padding:9px 32px 9px 30px;border-radius:10px;border:1px solid var(--line-strong);background:var(--bg-gray);cursor:pointer;outline:none;transition:.15s}
.model-select select:hover{border-color:var(--ink-faint)}
.model-select select:focus{box-shadow:0 0 0 4px var(--accent-soft);border-color:var(--accent)}
.model-select .ms-dot{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--accent);pointer-events:none}
.model-select .ms-caret{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--ink-faint);font-size:11px;pointer-events:none}

.task-input{width:100%;resize:none;font-family:inherit;font-size:13px;line-height:1.5;color:var(--ink);
  padding:10px 11px;border-radius:10px;border:1px solid var(--line-strong);background:#fff;outline:none;min-height:62px;transition:.15s}
.task-input::placeholder{color:var(--ink-faint)}
.task-input:hover{border-color:var(--ink-faint)}
.task-input:focus{box-shadow:0 0 0 4px var(--accent-soft);border-color:var(--accent)}

.card-foot{display:flex;align-items:center;gap:8px;padding:0 14px 14px}
.status{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:500;padding:5px 10px;border-radius:var(--pill)}
.status .sdot{width:7px;height:7px;border-radius:50%}
.status.idle{background:var(--bg-gray);color:var(--ink-soft)} .status.idle .sdot{background:var(--ink-faint)}
.status.running{background:var(--accent-soft);color:var(--accent-press)} .status.running .sdot{background:var(--accent);animation:pulse 1s infinite}
.status.done{background:var(--green-soft);color:var(--green)} .status.done .sdot{background:var(--green)}
.status.error{background:var(--red-soft);color:var(--red)} .status.error .sdot{background:var(--red)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

.run-btn{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-family:inherit;font-size:12.5px;font-weight:500;
  cursor:pointer;padding:7px 14px;border-radius:9px;border:1px solid var(--line-strong);background:#fff;color:var(--ink);transition:.15s var(--ease)}
.run-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

.progress{height:3px;background:var(--accent-soft);border-radius:0 0 var(--r) var(--r);overflow:hidden;display:none}
.card.is-running .progress{display:block}
.progress-bar{height:100%;width:0;background:var(--accent);border-radius:3px;transition:width .3s linear}

.port{position:absolute;right:-9px;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:50%;
  background:#fff;border:2.5px solid var(--accent);cursor:crosshair;z-index:3;transition:.15s}
.port:hover{background:var(--accent);transform:translateY(-50%) scale(1.25)}
.port.in{left:-9px;right:auto;border-color:var(--line-strong)}

/* ===================== EMPTY STATE ===================== */
.empty{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none}
.empty.hide{display:none}
.empty-card{position:relative;pointer-events:auto;text-align:center;background:#fff;border:1px solid var(--line);
  border-radius:24px;padding:44px 46px;max-width:430px;box-shadow:var(--shadow)}
.empty-glow{display:none}
.empty-ic{width:52px;height:52px;margin:0 auto 18px;border-radius:14px;display:grid;place-items:center;
  font-size:24px;color:var(--accent);background:var(--accent-soft)}
.empty-card h2{font-size:23px;font-weight:600;letter-spacing:-.025em;margin-bottom:9px}
.empty-card p{font-size:14.5px;color:var(--ink-soft);line-height:1.6;margin-bottom:24px;font-weight:400}

/* ===================== ZOOM BAR ===================== */
.zoombar{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:2px;
  background:rgba(255,255,255,.85);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:var(--pill);padding:5px;box-shadow:var(--shadow-sm)}
.zoombar button{border:none;background:transparent;font-family:inherit;cursor:pointer;color:var(--ink-soft);
  width:34px;height:34px;border-radius:var(--pill);font-size:16px;transition:.15s;display:grid;place-items:center}
.zoombar button:hover{background:var(--bg-gray);color:var(--ink)}
.zoombar .zoom-val{width:auto;padding:0 12px;font-size:12.5px;font-weight:500;color:var(--ink)}
.zoom-div{width:1px;height:20px;background:var(--line);margin:0 4px}

.hint{position:absolute;bottom:26px;right:22px;font-size:11.5px;color:var(--ink-faint);font-weight:450;
  background:rgba(255,255,255,.8);backdrop-filter:blur(8px);padding:7px 12px;border-radius:9px;border:1px solid var(--line)}

/* scrollbars */
.sidebar::-webkit-scrollbar{width:7px}
.sidebar::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px}
.task-input::-webkit-scrollbar{width:6px}
.task-input::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px}

@media (max-width:880px){
  body{grid-template-columns:1fr}
  .sidebar{display:none}
}

/* ===================== AGENT OUTPUT PANEL ===================== */
.card-out{border-top:1px solid var(--line);background:var(--bg-gray);border-radius:0 0 var(--r) var(--r)}
.card-out-head{display:flex;align-items:center;justify-content:space-between;padding:9px 14px 5px}
.card-out .out-label{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-faint)}
.card-out.err .out-label{color:var(--red)}
.out-copy{font-family:inherit;font-size:11px;font-weight:500;color:var(--ink-soft);background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:6px;transition:.15s}
.out-copy:hover{color:var(--ink);background:#fff}
.card-out-body{padding:0 14px 13px;font-size:12.5px;line-height:1.55;color:var(--ink);white-space:pre-wrap;word-break:break-word;max-height:200px;overflow:auto}
.card-out.err .card-out-body{color:var(--red)}
.card-out-body::-webkit-scrollbar{width:6px}
.card-out-body::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px}

/* indeterminate progress while a real request is in flight */
.progress-bar.indet{width:40% !important;border-radius:3px;animation:indet 1.1s var(--ease) infinite}
@keyframes indet{0%{margin-left:-45%}100%{margin-left:105%}}

/* ===================== SETTINGS / KEYS MODAL ===================== */
.modal-overlay{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:20px;
  background:rgba(10,10,12,.42);backdrop-filter:blur(4px);animation:fadeIn .18s var(--ease)}
.modal-overlay[hidden]{display:none}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{width:100%;max-width:460px;background:#fff;border:1px solid var(--line);border-radius:20px;
  box-shadow:var(--shadow-lg);padding:24px;animation:blurUp .35s var(--ease)}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.modal-head h3{font-size:19px;font-weight:600;letter-spacing:-.02em}
.modal-x{width:30px;height:30px;border-radius:8px;border:none;background:transparent;color:var(--ink-faint);
  cursor:pointer;font-size:14px;display:grid;place-items:center;transition:.15s}
.modal-x:hover{background:var(--bg-gray);color:var(--ink)}
.modal-sub{font-size:13px;color:var(--ink-soft);line-height:1.55;margin-bottom:18px}
.kfield{display:flex;flex-direction:column;gap:6px;margin-bottom:13px}
.kfield span{font-size:12.5px;font-weight:500;color:var(--ink-soft)}
.kfield input{font-family:inherit;font-size:14px;color:var(--ink);padding:11px 13px;border:1px solid var(--line-strong);
  border-radius:11px;outline:none;background:#fff;transition:.15s}
.kfield input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.modal-foot{display:flex;align-items:center;gap:10px;margin-top:20px}
.modal-foot .spacer{flex:1}
.modal-link{font-size:13px;font-weight:500;color:var(--accent)}
.modal-link:hover{text-decoration:underline}

/* ===================== ONBOARDING GUIDE ===================== */
.help-fab{position:absolute;bottom:22px;left:22px;z-index:6;width:40px;height:40px;border-radius:50%;
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);color:var(--ink-soft);
  font-family:inherit;font-size:18px;font-weight:600;cursor:pointer;display:grid;place-items:center;transition:.18s var(--ease)}
.help-fab:hover{color:var(--accent-press);border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}

/* ---- interactive spotlight tour (non-blocking; target stays clickable) ---- */
.tour{position:fixed;inset:0;z-index:300;pointer-events:none}
.tour[hidden]{display:none}
.tour-ring{position:fixed;border-radius:13px;pointer-events:none;
  box-shadow:0 0 0 100vmax rgba(10,10,12,.5), 0 0 0 3px var(--accent);
  transition:left .25s var(--ease),top .25s var(--ease),width .25s var(--ease),height .25s var(--ease)}
.tour-pop{position:fixed;width:280px;background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-lg);padding:16px 17px;animation:blurUp .3s var(--ease);pointer-events:auto}
.tour-pop-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.tour-count{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-faint)}
.tour-skip{font-family:inherit;font-size:12px;font-weight:500;color:var(--ink-faint);background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:6px}
.tour-skip:hover{color:var(--ink)}
.tour-title{font-size:16px;font-weight:600;letter-spacing:-.01em;margin-bottom:5px}
.tour-text{font-size:13.5px;line-height:1.55;color:var(--ink-soft)}
.tour-dots{display:flex;gap:5px;margin:14px 0 13px;flex-wrap:wrap}
.gdot{width:6px;height:6px;border-radius:50%;background:var(--line-strong);transition:.2s var(--ease)}
.gdot.on{background:var(--accent);width:16px;border-radius:6px}
.tour-nav{display:flex;gap:8px;justify-content:flex-end}
.tour-nav .btn{padding:8px 16px;font-size:13px;min-width:78px;justify-content:center}

/* ===================== RUNS / AUTOMATIONS VIEWS ===================== */
.modal-wide{max-width:580px}
.runs-list{display:flex;flex-direction:column;gap:8px;max-height:52vh;overflow:auto;margin-top:4px;padding-right:2px}
.runs-list::-webkit-scrollbar{width:7px}
.runs-list::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px}
.run-row{display:flex;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--line);border-radius:13px;background:#fff}
.run-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.run-meta{min-width:118px}
.run-name{font-size:13.5px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.run-sub{font-size:11px;color:var(--ink-faint)}
.run-snip{flex:1;min-width:0;font-size:12px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.run-actions{display:flex;gap:6px;flex-shrink:0}
.run-actions .btn{padding:6px 13px;font-size:12px;border-radius:9px;min-width:0}
.runs-empty{text-align:center;color:var(--ink-faint);font-size:14px;padding:34px 10px}

.auto-opts{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.auto-opt{display:flex;align-items:center;justify-content:space-between;width:100%;font-family:inherit;font-size:14px;
  font-weight:500;color:var(--ink);background:#fff;border:1px solid var(--line-strong);border-radius:12px;padding:13px 15px;cursor:pointer;transition:.15s var(--ease)}
.auto-opt:hover{background:var(--bg-gray)}
.auto-opt.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-press)}
.auto-check{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}
.auto-status{font-size:12.5px;color:var(--ink-soft)}

/* focus flash when jumping to an agent from Runs */
.card.focus-pulse{animation:focuspulse 1.2s var(--ease)}
@keyframes focuspulse{0%{box-shadow:0 0 0 0 rgba(124,58,237,.55), var(--shadow)}100%{box-shadow:0 0 0 16px rgba(124,58,237,0), var(--shadow)}}
