:root{
  --border: rgba(255,255,255,.12);
  --danger: rgba(255,90,90,.95);
  --ok: rgba(120,255,180,.95);
}
.wrap{max-width:1180px;margin:0 auto;padding:24px}
.top{display:flex;gap:16px;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.top h1{margin:0;font-size:22px}
.topActions{display:flex;gap:10px;align-items:center}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin:14px 0}
.cardHead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.cardHead h2{margin:0;font-size:18px}
.grid2{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width: 980px){.grid2{grid-template-columns:1fr 1fr}}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);color:var(--text);
  text-decoration:none;cursor:pointer;user-select:none;
}
.btn:hover{background:rgba(255,255,255,.09)}
.btn.primary{background:rgba(122,160,255,.20);border-color:rgba(122,160,255,.55)}
.btn.danger{background:rgba(255,90,90,.12);border-color:rgba(255,90,90,.40)}
.btn.small{padding:7px 10px;border-radius:12px;font-size:12px}
.muted{color:var(--muted)}
.small{font-size:12px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}
.form{border-top:1px solid var(--border);padding-top:12px;margin-top:12px}
.form.hidden{display:none}
.row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:10px}
label{display:flex;flex-direction:column;gap:6px;flex:1;min-width:210px}
input,select,textarea{
  padding:10px 12px;border-radius:14px;border:1px solid var(--border);
  background:rgba(0,0,0,.25);color:var(--text);outline:none;
}
textarea{resize:vertical}
.check{flex-direction:row;align-items:center;gap:10px;min-width:auto}
.check input{width:18px;height:18px;margin:0}
.tableWrap{overflow:auto;border-radius:14px;border:1px solid var(--border)}
.table{width:100%;border-collapse:collapse;min-width:640px}
.table th,.table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left;vertical-align:top}
.table th{font-size:12px;color:var(--muted);font-weight:600}
.table tr:last-child td{border-bottom:none}
.actionsRow{display:flex;gap:10px;flex-wrap:wrap}
.filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:10px 0}
.filters input{flex:1;min-width:220px}
.badge{display:inline-flex;align-items:center;gap:8px}
.swatch{width:12px;height:12px;border-radius:4px;border:1px solid rgba(255,255,255,.25);display:inline-block}
/* Layout: allow full-page scrolling so panels never get cut off in fullscreen */
html, body{margin:0;height:auto}
body{min-height:100vh;overflow:auto}

/* Keep cards as normal blocks (no forced 100vh layout). */
@media (min-width: 980px){
  .grid2{grid-template-columns:1fr 1fr;align-items:start}
}

/* Tables can scroll inside their own panel if they get tall */
.tableWrap{overflow:auto}

/* Optional: cap table height on larger screens so the Save/Cancel buttons remain reachable */
@media (min-width: 980px){
  .tableWrap{max-height:70vh}
}
