:root{
  --purple-label:#CCC2DC;
  --purple-dark:#5C4380;
  --purple-light:#B6A4CC;
  --green:#D6E4BC;
  --border:#7F7F7F;
  --bg:#e9ebee;
}
*{box-sizing:border-box;}
body{
  font-family: Arial, Helvetica, sans-serif;
  background:var(--bg);
  margin:0;
  padding:20px;
  color:#1a1a1a;
}
.wrap{ max-width:1200px; margin:0 auto; }

.topbar{
  background:#fff;
  border-radius:10px;
  padding:14px 18px;
  box-shadow:0 1px 4px rgba(0,0,0,.15);
  display:flex;
  gap:10px;
  align-items:center;
  margin-bottom:16px;
}
.topbar h1{ margin:0; font-size:18px; color:var(--purple-dark); flex:1 1 auto; }
.topbar .user{ font-size:13px; color:#555; margin-right:8px; }

button{
  border:none;
  border-radius:6px;
  padding:9px 16px;
  font-size:13px;
  font-weight:bold;
  cursor:pointer;
  transition:opacity .15s;
}
button:hover{ opacity:.85; }
button:disabled{ opacity:.5; cursor:not-allowed; }
.btn-primary{ background:var(--purple-dark); color:#fff; }
.btn-secondary{ background:#e0e0e0; color:#333; }
.btn-danger{ background:#c0392b; color:#fff; }
.btn-green{ background:#4c7a2a; color:#fff; }
.btn-blue{ background:#2E5FA3; color:#fff; }
.btn-sm{ padding:5px 10px; font-size:11.5px; }

.card{
  background:#fff;
  border-radius:10px;
  box-shadow:0 1px 6px rgba(0,0,0,.15);
  padding:18px 22px;
  margin-bottom:18px;
}

.error{ color:#c0392b; font-size:13px; margin-top:8px; }

/* ---- Login ---- */
.login-box{
  max-width:380px;
  margin:80px auto;
  background:#fff;
  border-radius:12px;
  padding:32px;
  box-shadow:0 2px 12px rgba(0,0,0,.2);
  text-align:center;
}
.login-box h1{ color:var(--purple-dark); font-size:20px; margin-bottom:4px; }
.login-box p{ color:#777; font-size:13px; margin-top:0; margin-bottom:20px; }
.login-box input{
  width:100%; padding:10px 12px; margin-bottom:12px;
  border:1px solid #ccc; border-radius:6px; font-size:14px;
}
.login-box button{ width:100%; padding:11px; font-size:14px; }

/* ---- Inicio: plantillas ---- */
.plantillas-grid{ display:flex; gap:16px; flex-wrap:wrap; }
.plantilla-btn{
  display:flex; flex-direction:column; align-items:flex-start; gap:6px;
  width:220px; padding:18px; text-align:left;
  background:#fff; border:2px solid var(--purple-light); border-radius:10px;
  color:#333; font-weight:normal;
}
.plantilla-btn:hover{ opacity:1; border-color:var(--purple-dark); box-shadow:0 2px 8px rgba(0,0,0,.12); }
.plantilla-btn .plantilla-nombre{ font-weight:bold; color:var(--purple-dark); font-size:14px; }
.plantilla-btn .plantilla-desc{ font-size:12px; color:#777; }
.plantilla-btn.disabled{ opacity:.5; cursor:not-allowed; border-style:dashed; }

/* ---- Lista de partes ---- */
table.lista{ width:100%; border-collapse:collapse; }
table.lista th, table.lista td{ border:1px solid #ddd; padding:8px 10px; font-size:13px; text-align:left; }
table.lista th{ background:var(--green); }
table.lista tr:hover{ background:#fafafa; }
.lista-actions{ display:flex; gap:6px; flex-wrap:wrap; }

/* ---- Editor: reutiliza el look del prototipo original ---- */
.sheet{ background:#fff; padding:18px 24px 26px 24px; box-shadow:0 1px 6px rgba(0,0,0,.2); position:relative; }

.logos{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.logos img.madrid{ height:46px; }
.logos .center-logos{ display:flex; align-items:center; gap:14px; }
.logos img.gob{ height:52px; }
.logos img.sepe{ height:52px; }
.logos img.ue{ height:46px; }

.banner-row{ display:flex; align-items:center; gap:14px; margin-bottom:10px; }
.banner{
  flex: 0 0 70%; margin-left: 9%;
  background: linear-gradient(180deg, var(--purple-light) 0%, var(--purple-dark) 60%, #46315f 100%);
  border-radius: 50% / 100%; color:#fff; text-align:center; font-weight:bold; font-size:17px; padding:9px 60px;
}
.banner input{ width:100%; background:transparent; border:none; outline:none; color:#fff; text-align:center; font-weight:bold; font-size:17px; font-family:inherit; }
.hoja-num{ font-weight:bold; font-size:18px; white-space:nowrap; }
.hoja-num input{ width:40px; font-size:18px; font-weight:bold; color:#2E5FA3; border:none; border-bottom:1px solid #888; background:transparent; padding:2px 4px; text-align:center; }

table.info{ width:100%; border-collapse:collapse; margin-bottom:10px; }
table.info td{ border:1px solid var(--border); padding:4px 6px; vertical-align:middle; }
table.info td.lbl{ background:var(--purple-label); font-weight:bold; text-align:center; font-size:12px;}
table.info input{ width:100%; border:none; background:transparent; color:#2E5FA3; font-family:inherit; font-size:13px; text-align:center; padding:2px; }
table.info input.left{ text-align:left; }

table.main{ width:100%; border-collapse:collapse; }
table.main th, table.main td{ border:1px solid var(--border); padding:3px 6px; font-size:13px; }
table.main th{ background:var(--green); font-weight:bold; }
table.main td.idx{ text-align:center; width:28px; background:#fafafa; }
table.main td.mark{ width:130px; text-align:center; }
table.main td:nth-child(2){ width:auto; }
table.main input{ width:100%; border:none; font-family:inherit; font-size:13px; padding:3px 2px; }
table.main input.center{ text-align:center; }
table.main tr:hover{ background:#fff8e1; }
.rm-btn{ background:#c0392b;color:#fff;border:none;border-radius:3px; width:18px;height:18px;line-height:18px;font-size:12px;cursor:pointer;padding:0; }
td.rm-cell{ width:22px; text-align:center; padding:0; border:none; }

.add-row{ text-align:left; margin:6px 0 18px 0; display:flex; gap:8px; flex-wrap:wrap; }
.add-row button{ font-size:12px; padding:6px 12px; }

.editor-actions{ display:flex; gap:10px; margin-top:16px; flex-wrap:wrap; }

/* ---- Modal ---- */
.modal-overlay{ display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:1000; align-items:center; justify-content:center; }
.modal-overlay.open{ display:flex; }
.modal-box{ background:#fff; border-radius:10px; padding:20px 24px; width:420px; max-width:92vw; box-shadow:0 4px 20px rgba(0,0,0,.3); }
.modal-box h3{ margin:0 0 8px 0; font-size:16px; color:#333; }
.modal-box p{ font-size:12.5px; color:#555; margin:0 0 10px 0; line-height:1.5; }
.modal-box .modal-row{ display:flex; gap:12px; margin-bottom:10px; }
.modal-box .modal-row > div{ flex:1; }
.modal-box .modal-row label{ font-size:12.5px; color:#333; display:block; margin-bottom:4px; font-weight:bold; }
.modal-box .modal-row input{ width:100%; font-size:14px; padding:7px 8px; border:1px solid #ccc; border-radius:6px; }
.modal-actions{ display:flex; justify-content:flex-end; gap:8px; margin-top:14px; }

.pegar-lista{ margin:-6px 0 16px 0; background:#fff8e1; border:1px solid #e0c97a; border-radius:8px; padding:10px 14px; }
.pegar-lista textarea{ width:100%; font-family:inherit; font-size:13px; border:1px solid #ccc; border-radius:6px; padding:8px; resize:vertical; }

/* ---- Tachado Sábado/Domingo ---- */
.tachado-toolbar{ display:flex; align-items:center; gap:8px; margin-bottom:8px; font-size:12.5px; color:#444; flex-wrap:wrap; }
.tachado-hint{ color:#888; font-size:11.5px; }
.btn-toggle{ background:#e0e0e0; color:#333; padding:6px 12px; font-size:12px; }
.btn-toggle.active{ background:#c0392b; color:#fff; }
.tabla-wrap{ position:relative; }
.linea-tachado{ position:absolute; pointer-events:none; z-index:5; }
