:root {
  --primario: #123456;
  --acento: #e0a53b;
  --fondo: #f0eee8;
  --texto: #2d3440;
  --suave: #788291;
  --linea: #dcd9cf;
  --blanco: #fff;
  --error: #c0392b;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "Segoe UI", system-ui, -apple-system, Arial, sans-serif;
  background: var(--fondo);
  color: var(--texto);
}
.top {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--primario); color: #fff;
  padding: 14px 22px; border-bottom: 4px solid var(--acento);
}
.brand-mark { font-weight: 700; font-size: 20px; letter-spacing: .5px; }
.brand-sub { margin-left: 12px; opacity: .8; font-size: 14px; }
.logout { color: #fff; text-decoration: none; opacity: .85; font-size: 14px; }
.logout:hover { opacity: 1; text-decoration: underline; }
.wrap { max-width: 1080px; margin: 0 auto; padding: 24px 20px 60px; }

h1 { font-size: 24px; margin: 0 0 4px; }
h2 { font-size: 18px; margin: 28px 0 12px; color: var(--primario); }
.muted { color: var(--suave); }
.error { color: var(--error); font-weight: 600; }

.btn {
  display: inline-block; border: none; border-radius: 8px; cursor: pointer;
  font-size: 15px; font-weight: 600; padding: 11px 18px; text-decoration: none;
}
.btn-primary { background: var(--primario); color: #fff; }
.btn-acento { background: var(--acento); color: #1b1b1b; }
.btn-ghost { background: transparent; color: var(--primario); border: 1.5px solid var(--primario); }
.btn:disabled { opacity: .5; cursor: not-allowed; }
.btn + .btn { margin-left: 8px; }

/* login */
.login-card {
  max-width: 360px; margin: 8vh auto; background: #fff; padding: 28px;
  border-radius: 14px; box-shadow: 0 8px 30px rgba(0,0,0,.08);
}
.login-card form { display: flex; flex-direction: column; gap: 14px; margin-top: 16px; }
label { display: flex; flex-direction: column; gap: 5px; font-size: 14px; font-weight: 600; }
input, select, textarea {
  font: inherit; padding: 9px 11px; border: 1.5px solid var(--linea);
  border-radius: 8px; background: #fff; color: var(--texto);
}
textarea { resize: vertical; min-height: 64px; }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--acento); border-color: var(--acento); }

/* proyectos */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 14px; }
.card {
  background: #fff; border: 1px solid var(--linea); border-radius: 12px; padding: 16px;
  cursor: pointer; transition: box-shadow .15s;
}
.card:hover { box-shadow: 0 6px 18px rgba(0,0,0,.08); }
.card h3 { margin: 0 0 6px; font-size: 16px; color: var(--primario); }
.badge { display: inline-block; background: var(--acento); color: #1b1b1b; font-size: 11px;
  font-weight: 700; padding: 2px 8px; border-radius: 10px; }

.panel { background: #fff; border: 1px solid var(--linea); border-radius: 14px; padding: 22px; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; font-size: 14px; font-weight: 600; }
.field small { font-weight: 400; color: var(--suave); }
.row { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.hidden { display: none !important; }

/* imágenes / piezas */
.piezas { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: 14px; margin-top: 12px; }
.pieza { border: 1px solid var(--linea); border-radius: 10px; padding: 10px; background: #fafafa; }
.pieza img { width: 100%; height: 140px; object-fit: cover; border-radius: 6px; background: #eee; }
.pieza input, .pieza select { width: 100%; margin-top: 6px; font-size: 13px; }

/* log */
.log {
  background: #0e1726; color: #d6e0ee; font-family: ui-monospace, Consolas, monospace;
  font-size: 13px; line-height: 1.5; padding: 14px; border-radius: 10px;
  height: 280px; overflow-y: auto; white-space: pre-wrap; margin-top: 12px;
}
.log .ok { color: #6fcf97; }
.log .err { color: #eb5757; }

/* galería resultados */
.galeria { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 14px; }
.galeria img, .galeria video { width: 100%; border-radius: 10px; border: 1px solid var(--linea); background:#fff; }
.cap-box { background: #fff; border: 1px solid var(--linea); border-radius: 12px; padding: 16px; white-space: pre-wrap; }
