/* Respond OT Tool Skin — consistent, light-first */

.grid-2{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap:16px;
}
@media (max-width: 980px){
  .grid-2{ grid-template-columns: 1fr; }
}

.sticky{
  position: sticky;
  top: 88px; /* below sticky site header */
  align-self: start;
}

.form-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
@media (max-width: 920px){
  .form-grid{ grid-template-columns: 1fr; }
}

.field label{
  display:block;
  font-size: .82rem;
  font-weight: 800;
  color: var(--muted);
  margin-bottom: 6px;
}

.tool-input,
.tool-select,
.tool-textarea{
  width:100%;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.96);
  color: var(--ink);
  outline: none;
}

.tool-textarea{ resize:vertical; min-height:72px; }

.tool-input:focus,
.tool-select:focus,
.tool-textarea:focus{
  box-shadow: 0 0 0 4px rgba(40,120,255,.15);
  border-color: rgba(40,120,255,.55);
}

.divider{
  height:1px;
  background: var(--line);
  margin: 18px 0;
  opacity: .9;
}

.row-add{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:10px;
}
.row-add .tool-input{
  flex: 1 1 260px;
}

.table-wrap{
  overflow:auto;
  border:1px solid var(--line);
  border-radius:14px;
  background: rgba(255,255,255,.86);
}

.tool-table{
  width:100%;
  border-collapse: collapse;
  min-width: 860px;
}

.tool-table th,
.tool-table td{
  padding:10px 12px;
  border-bottom:1px solid var(--line);
  vertical-align: top;
}

.tool-table th{
  text-align:left;
  font-weight:800;
  font-size:.9rem;
  color: var(--ink);
  background: rgba(20, 70, 180, .06);
}

.role-ta{
  min-height:64px;
}

.tool-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}

.summary{
  white-space: pre-wrap;
  padding:12px;
  border-radius:14px;
  border:1px dashed var(--line);
  background: rgba(255,255,255,.85);
  color: var(--ink);
  min-height: 280px;
}

/* Print */
@media print{
  .bg-grid, #header-slot, #footer-slot,
  #demoBtn, #exportXlsxBtn, #printBtn, #resetBtn, #copySummaryBtn,
  #addRoleBtn {
    display:none !important;
  }
  body{ background:#fff !important; }
  .panel{ box-shadow:none !important; border:1px solid #ddd !important; }
  .table-wrap{ border:1px solid #ddd !important; }
  .sticky{ position:static !important; }
}
