button { background: linear-gradient(135deg, #22c55e, #7dd3fc); color: #041012; border: none; padding: 10px 16px; border-radius: 10px; cursor: pointer; font-weight: 600; box-shadow: var(--shadow); } button.ghost { background: transparent; color: var(--text); border: 1px solid var(--border); box-shadow: none; } button.icon-btn { width: 40px; height: 40px; padding: 0; display: grid; place-items: center; font-size: 1.1rem; box-shadow: none; } :root[data-theme="light"] button.icon-btn { box-shadow: inset 0 0 0 1px var(--border); border-radius: 10px; } button:active { transform: translateY(1px); } button.danger-btn { background: linear-gradient(135deg, #f87171, #ef4444); color: #0f1117; } .menu-btn { font-size: 1rem; width: 32px; height: 32px; padding: 0; display: grid; place-items: center; border-radius: 8px; } .service-menu { position: absolute; top: 8px; right: 8px; display: flex; flex-direction: column-reverse; align-items: flex-end; gap: 6px; } .service-menu .ghost { border: 1px solid color-mix(in srgb, var(--border) 60%, var(--text) 20%); width: 32px; height: 32px; padding: 0; display: grid; place-items: center; border-radius: 8px; } label.toggle { position: relative; display: inline-block; width: 46px; height: 24px; } label.toggle input { display: none; } label.toggle .slider { position: absolute; cursor: pointer; inset: 0; background: var(--toggle-track); border-radius: 24px; transition: 0.2s; } label.toggle .slider:before { position: absolute; content: ""; height: 18px; width: 18px; left: 3px; bottom: 3px; background: white; border-radius: 50%; transition: 0.2s; } label.toggle input:checked + .slider { background: linear-gradient(135deg, #22c55e, #7dd3fc); } label.toggle input:checked + .slider:before { transform: translateX(22px); } .controls { display: flex; flex-direction: column; gap: 10px; } .accordion { border: 1px solid var(--border); border-radius: 12px; overflow: hidden; background: var(--panel-overlay); } .accordion + .accordion { margin-top: 8px; } .accordion-toggle { width: 100%; text-align: left; background: transparent; color: var(--text); border: none; padding: 12px 14px; font-weight: 700; cursor: pointer; } .accordion-toggle.danger-btn { color: #0f1117; } .accordion-body { padding: 0 14px 0; max-height: 0; overflow: hidden; opacity: 0; transition: max-height 0.24s ease, opacity 0.18s ease, padding-bottom 0.18s ease, padding-top 0.18s ease; } .accordion.open .accordion-body { max-height: 1200px; opacity: 1; padding: 8px 12px 6px; } .accordion-body p { margin: 0 0 6px; } .control-card { border: 1px solid var(--border); border-radius: 12px; padding: 12px; display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; } .control-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; } .control-actions.split-row { justify-content: flex-start; gap: 10px; align-items: center; margin-top: 4px; flex-wrap: wrap; } .control-actions.column.tight { gap: 6px; align-items: flex-start; } .control-actions.column { flex-direction: column; align-items: stretch; } .control-actions.column > .checkbox-row.inline { margin-top: 6px; } select, input { background: var(--input-bg); color: var(--text); border: 1px solid var(--input-border); padding: 8px 10px; border-radius: 10px; } .checkbox-row { display: flex; align-items: center; gap: 8px; color: var(--muted); font-size: 0.95rem; } .checkbox-row.inline { display: inline-flex; gap: 10px; align-items: center; } .checkbox-row.inline.tight { margin-top: 6px; } .checkbox-row.inline.nowrap span { white-space: nowrap; } .control-row.split { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; } .control-row.split > * { margin: 0; } .dual-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; align-items: center; } .dual-row .dual-col:last-child { text-align: right; } .dual-row .checkbox-row.inline { justify-content: flex-start; width: fit-content; } .form-grid { display: grid; gap: 6px; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); } .field { display: flex; flex-direction: column; gap: 4px; color: var(--muted); font-size: 0.95rem; } .field input, .field select { width: 100%; } .checkbox-field .checkbox-row { color: var(--text); } .status-msg { margin-top: 4px; } .status-msg.error { color: #f87171; } .note-warn { color: #f87171; font-weight: 600; } .is-disabled { opacity: 0.45; } .is-disabled input, .is-disabled select, .is-disabled textarea { filter: grayscale(0.5); background: var(--input-disabled-bg); color: var(--input-disabled-text); border-color: var(--input-disabled-border); box-shadow: none; } .is-disabled label { color: var(--disabled-text); } .is-disabled .slider { filter: grayscale(0.7); } .hidden { display: none !important; } button:disabled { opacity: 0.55; cursor: not-allowed; box-shadow: none; background: #2f3844; border: 1px solid #3b4756; color: #c9d2dc; pointer-events: none; }