:root { --border:#ddd; --bg:#fff; --muted:#666; }
* { box-sizing: border-box; }
body { margin: 16px; background: var(--bg); color:#111; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }
.top { display:flex; align-items:flex-start; justify-content:space-between; gap: 12px; margin-bottom: 12px; }
.title { font-size: 20px; font-weight: 800; }
.sub { font-size: 13px; color: var(--muted); margin-top: 4px; }
.actions { display:flex; gap: 10px; flex-wrap: wrap; }

.grid {
  display:grid;
  grid-template-columns: minmax(260px, 360px) minmax(360px, 460px) minmax(260px, 360px);
  gap: 16px;
  align-items: start;
  justify-content: center;
}
.panel {
  border:1px solid var(--border);
  border-radius: 14px;
  padding: 12px;
  max-width: 100%;
}
.stage {
  border:1px solid var(--border);
  border-radius: 14px;
  padding: 12px;
  max-width: 460px;
  width: 100%;
}

.block { border:1px solid var(--border); border-radius: 12px; padding: 10px; margin-bottom: 10px; }
.row { display:flex; gap: 10px; align-items: end; flex-wrap: wrap; }
.col { flex: 1; min-width: 140px; }
label { display:block; font-size: 12px; color: var(--muted); margin-bottom: 6px; }
input, select, textarea { width:100%; padding: 8px; border-radius: 10px; border: 1px solid #ccc; }
textarea { resize: vertical; }
button { padding: 10px 12px; border-radius: 12px; border: 1px solid #111; background: #111; color: #fff; cursor:pointer; }
button.secondary { background: #fff; color:#111; }
button.small { padding: 8px 10px; }
button:disabled { opacity:.6; cursor:not-allowed; }

.hint { font-size: 12px; color: var(--muted); margin-top: 6px; }
canvas {
  /* холст логически 794×1302, но на экране показываем поменьше */
  width: 100%;
  height: auto;
  border-radius: 12px;
  border:1px solid var(--border);
  background: #f7f7f7;
  display:block;
  margin: 0 auto;
}

details summary { cursor: pointer; user-select:none; }
progress { width:100%; height: 14px; }

/* Тёмная тема */
body.dark-mode {
  --border: #444;
  --bg: #1a1a1a;
  --muted: #999;
  background: var(--bg);
  color: #eee;
}
body.dark-mode input,
body.dark-mode select,
body.dark-mode textarea {
  background: #2a2a2a;
  border-color: #555;
  color: #eee;
}
body.dark-mode button.secondary {
  background: #2a2a2a;
  color: #eee;
  border-color: #555;
}
body.dark-mode canvas {
  background: #2a2a2a;
}

/* Адаптив: на узких экранах настройки и холст в колонку,
   чтобы панель не вылезала за край */
@media (max-width: 1100px) {
  body { margin: 8px; }
  .top { flex-direction: column; align-items: flex-start; }
  .grid { grid-template-columns: 1fr; }
}
