:root{
  --bg: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  --glass-bg: rgba(255,255,255,0.06);
  --accent: rgba(255,255,255,0.85);
  --glass-border: rgba(255,255,255,0.12);
  color-scheme: dark;
}
*{box-sizing:border-box;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif}
html,body,#app{height:100%;margin:0;background:radial-gradient(circle at 10% 10%, #0f1724 0%, #081021 60%);color:var(--accent)}
header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px}
.glass{background:var(--glass-bg);backdrop-filter:blur(8px) saturate(120%);border:1px solid var(--glass-border);border-radius:12px;padding:12px}
.card{padding:12px;margin:12px}
.group.card{padding:0;margin:8px}
main{padding:12px}
.top-row{display:flex;gap:12px}
.panel{flex:1;min-height:120px}
.groups-wrap{position:relative}
#groupsArea{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px;position:relative;min-height:240px}
.group{width:220px;cursor:grab;height:110px;display:flex;align-items:stretch;padding:0;overflow:hidden}
.group.ungrouped{flex:0 0 220px;width:220px;height:110px;cursor:default;overflow:hidden}
.group.ungrouped .group-body{width:100%;max-width:100%;height:100%;overflow:auto}
.group.ungrouped .list-container{width:100%;max-width:100%}
.group.ungrouped .list{max-width:100%;overflow:hidden;padding-right:8px}
.group.ungrouped .list-title,.group.ungrouped .list-meta{max-width:100%;overflow-wrap:break-word;word-break:normal}
.group.ungrouped .list-actions{z-index:5;background:rgba(8,16,33,0.72);backdrop-filter:blur(6px) saturate(120%);padding:2px;border-radius:8px}
.group.ungrouped .list-title,.group.ungrouped .list-meta{padding-right:0}
/* floating groups (free placement) */
.group.floating{position:fixed;cursor:move;z-index:1400;box-shadow:0 12px 40px rgba(0,0,0,0.5);}
.group.floating .group-actions{opacity:1;visibility:visible}
.group-header{display:flex;flex-direction:column;justify-content:center;align-items:stretch;cursor:pointer;padding:8px 12px;border-radius:8px;transition:background 0.15s;height:100%;width:100%;box-sizing:border-box}
.group-header:hover{background:rgba(255,255,255,0.03)}
.group-head-row{display:flex;align-items:center;gap:8px}
.group-actions{display:flex;gap:6px;justify-content:center;width:100%;margin-top:8px}

.group-body{padding:8px}
.group-chevron{display:inline-block;transition:transform 0.2s;margin-right:6px;font-size:12px;min-width:12px}
.group-chevron.rotated{transform:rotate(90deg)}
.group-name{font-weight:700;display:flex;align-items:center;height:100%}
.list{padding:8px;padding-right:120px;margin:8px 0;background:rgba(255,255,255,0.03);border-radius:8px}
.list-title{font-weight:600}
.list.type-note .list-title,
.list.type-note .list-meta{white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace}

.controls{margin:12px 0}
.hidden{display:none}
button{background:transparent;color:var(--accent);border:1px solid rgba(255,255,255,0.08);padding:6px 10px;border-radius:8px;cursor:pointer}
input{padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:transparent;color:var(--accent);margin:6px 0}
select{
  padding:8px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,0.06) !important;
  background:rgba(8,16,33,0.55) !important;
  color:var(--accent) !important;
}
select:focus{outline:none;box-shadow:0 0 0 2px rgba(255,255,255,0.10)}
select option{background:#081021;color:var(--accent)}
.list-actions, .group-actions{display:flex;gap:6px}
/* Make list card actions compact and positioned on the right */
.list{position:relative}
.list-actions{position:absolute;right:8px;top:8px;transform:none;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:6px;pointer-events:none}
.list-actions > button{flex:0 0 auto}
.list-actions > button{pointer-events:auto}

.list-actions button, .group-actions button{
  width:28px;
  height:28px;
  padding:0;
  font-size:12px;
  border-radius:6px;
  min-width:0;
  opacity:0;
  visibility:hidden;
  transition:opacity 160ms ease, transform 160ms ease;
  transform:translateY(-4px);
  display:inline-flex;align-items:center;justify-content:center;
}
.list:hover .list-actions button,
.group:hover .group-actions button,
.group-header:hover .group-actions button{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

/* Also show actions when focused inside the list (keyboard users) */
.list:focus-within .list-actions button,
.group:focus-within .group-actions button{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

/* Also apply hidden-until-hover behavior for lists inside group bodies/modal */
.group-body .list .list-actions button,
.group-detail-modal .list .list-actions button{
  width:28px;
  height:28px;
  padding:0;
  font-size:12px;
  border-radius:6px;
  min-width:0;
  opacity:0;
  visibility:hidden;
  transition:opacity 160ms ease, transform 160ms ease;
  transform:translateY(-4px);
  display:inline-flex;align-items:center;justify-content:center;
}
.group-body .list .list-actions,
.group-detail-modal .list .list-actions{
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  align-items:center !important;
}
.group-body .list:hover .list-actions button,
.group-body .list:focus-within .list-actions button,
.group-detail-modal .list:hover .list-actions button,
.group-detail-modal .list:focus-within .list-actions button{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.list.dragging{opacity:0.6}
.group.over{outline:2px dashed rgba(255,255,255,0.12)}
.group.dragging{opacity:0.6;transform:scale(0.995)}
.group.drag-over-top{box-shadow:inset 0 4px 0 0 rgba(255,255,255,0.12);}
.group.drag-over-bottom{box-shadow:inset 0 -4px 0 0 rgba(255,255,255,0.12);}
.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.7);display:flex;align-items:center;justify-content:center;z-index:1000}
.modal-content{background:var(--glass-bg);backdrop-filter:blur(8px) saturate(120%);border:1px solid var(--glass-border);border-radius:12px;padding:24px;min-width:320px;max-width:400px;box-shadow:0 8px 32px rgba(0,0,0,0.3)}
.modal-content h3{margin:0 0 12px 0;color:var(--accent)}
.modal-content input, .modal-content select{width:100%;padding:8px;margin:8px 0;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:transparent;color:var(--accent)}
.modal-content button{width:100%;padding:10px;margin:4px 0}
.modal.hidden{display:none}

/* Keep modal primary action buttons full width but keep icon buttons compact */
.modal-content .icon-btn{width:auto;padding:0;height:28px;min-width:28px}

/* Make group detail close button a square and align it to the right */
#groupDetailClose{width:36px;height:36px;padding:0;margin-left:auto;border-radius:6px}

/* Edit list modal specific layout */
.edit-list-modal{min-width:520px;max-width:1100px;padding:20px}
.edit-list-grid{display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.edit-list-textarea{flex:1;width:100%}
.edit-list-controls{width:100%}
.controls-row{display:flex;justify-content:space-between;align-items:center;gap:12px}
.controls-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex:1;min-width:220px}
.controls-left select{min-width:160px}
.controls-right{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.edit-list-modal .edit-list-grid{flex-direction:column}
.edit-list-modal .edit-list-controls{width:100%}
.edit-list-controls label{font-size:13px}
.edit-list-controls input[type="checkbox"]{transform:scale(1.05)}
.modal-content .small{width:120px;padding:8px;border-radius:8px}
.edit-list-textarea textarea{width:100%;min-height:160px}

/* Group detail modal */
.group-detail-modal{width:92vw;max-width:1200px;min-width:720px;padding:22px}
.group-detail-modal #groupDetailBody{display:flex;flex-direction:column;gap:12px}
.group-detail-modal .list{margin:6px 0;padding:12px;padding-right:160px}
.group-detail-modal .list-actions{flex-direction:row;top:8px;right:8px;transform:none}
.group-detail-modal .list-actions button{margin:0;width:28px;padding:0}

/* Ensure modals stack correctly: edit modal should be above group detail modal */
#groupDetailModal{z-index:1000}
#editListModal{z-index:1100}

@media (max-width:800px){.top-row{flex-direction:column}}
@media (max-width:800px){.group-detail-modal{min-width:calc(100vw - 24px);width:calc(100vw - 24px)}}

/* Icon styling: compact square icons aligned right on list cards */
.icon{width:14px;height:14px;display:inline-block;vertical-align:middle;color:rgba(255,255,255,0.92)}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(255,255,255,0.04);padding:0;width:28px;height:28px;border-radius:6px;color:rgba(255,255,255,0.9);transition:all 140ms ease}
.icon-btn:hover{color:var(--accent);background:rgba(255,255,255,0.03);border-color:rgba(255,255,255,0.12);transform:translateY(-2px)}
.group-chevron .icon{width:12px;height:12px}
.icon-btn:focus{outline:2px solid rgba(255,255,255,0.06);outline-offset:2px}

/* Color button: show selected color as background and keep contrast on icon */
.color-group{border-color:rgba(255,255,255,0.06);color:rgba(255,255,255,0.95)}
.color-group svg{opacity:0.95}

.local-runner-modal .runner-actions{display:flex;gap:12px;flex-wrap:wrap}
.local-runner-modal{max-width:560px;width:90%;max-height:80vh;overflow:auto}
.local-runner-modal .runner-col{flex:1;min-width:220px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);padding:10px;border-radius:8px}
.local-runner-modal .runner-label{font-weight:600;margin-bottom:8px}
.local-runner-modal .runner-step{font-size:12px;opacity:0.8;margin-top:8px}
.local-runner-modal .runner-code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;font-size:12px;white-space:pre-wrap;background:rgba(0,0,0,0.25);border:1px solid rgba(255,255,255,0.08);padding:8px;border-radius:6px;margin-top:6px}
.local-runner-modal .runner-download{margin-top:4px}
