/* ==== Layout & theme ==== */
:root {
  --bg:#001D39;
  --panel:#0A4174;
  --muted:#6EA2B3;
  --text:#BDD8E9;
  --btn:#49769F;
  --danger:#ef4444;
  --border:rgba(189,216,233,.18);
  --card:#001D39;
}
* { box-sizing:border-box }
html,body { height:100% }
body.bg {
  margin:0;
  background:linear-gradient(180deg,#001D39,#001D39 40%,#0A4174);
  color:var(--text);
  font-family:Inter,system-ui,Segoe UI,Roboto,Arial;
}
a { color:#7BBDE8; text-decoration:none }

/* ==== Containers ==== */
.container { max-width:1100px; margin:1rem auto; padding:0 1rem }
.container.narrow { max-width:520px }
.topbar {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:.5rem 1rem;
  border-bottom:1px solid var(--border);
  background:#0A4174;
  position:sticky;
  top:0;
  z-index:5;
}
.topbar .left { display:flex; gap:.6rem; align-items:center }
.topbar .right { display:flex; gap:.5rem; align-items:center; flex-wrap:wrap }

/* ==== Generic toolbar ==== */
.toolbar { display:flex; gap:.5rem; align-items:center; flex-wrap:wrap }
.toolbar input,.toolbar select,.toolbar .btn { margin:0 }
.toolbar input,.toolbar select { width:auto; min-width:180px }
.toolbar label { margin:0 }

/* ==== Cards & grids ==== */
.grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1rem }
.board-card {
  background:var(--panel);
  border:1px solid var(--border);
  padding:1rem;
  border-radius:12px;
  display:flex;
  flex-direction:column;
  gap:.75rem;
}
/* Título arriba y botones abajo en línea */
.board-card .title{
  margin-bottom:.25rem;
  line-height:1.2;
}
.board-card .actions{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  justify-content:flex-start; /* botones alineados a la izquierda */
}

/* ==== Buttons ==== */
.btn {
  background:var(--btn);
  border:none;
  padding:.5rem .8rem;
  border-radius:10px;
  color:white;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:.35rem;
}
.btn:hover { filter:brightness(1.05) }
.btn.small { padding:.25rem .6rem; font-size:.9rem }
.btn.outline { background:transparent; border:1px solid var(--border); color:var(--text) }
.btn.danger { background:var(--danger) }
.logo { width:28px; height:28px; border-radius:6px }

/* ==== Form controls ==== */
.card {
  background:var(--panel);
  border:1px solid var(--border);
  padding:1rem;
  border-radius:12px;
  display:flex;
  flex-direction:column;
  gap:.5rem;
}
input,textarea,select {
  background:#BDD8E9;/*coloranterior: #0b1220*/
  border:1px solid var(--border);
  color:#001D39;
  border-radius:8px;
  padding:.55rem;
  width:100%;
}
label { display:block; margin:.35rem 0 .25rem; color:#6EA2B3 }
h1,h2,h3 { margin:.5rem 0 1rem }
.muted { color:var(--muted) }

/* Topbar tidy en pantallas medianas */
@media (max-width:960px){
  .topbar{align-items:flex-start}
  .topbar .right{width:100%}
}

/* ==== Rows ==== */
.row { display:flex; gap:.5rem; align-items:center }
.row.sb { justify-content:space-between }

/* ==== Lists/Board page ==== */
.lists-wrapper {
  display:flex;
  gap:1rem;
  align-items:flex-start;
  overflow-x:auto;
  padding:1rem;
}
.list {
  min-width:280px;
  max-width:320px;
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:12px;
  padding:.75rem;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}
.list header {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:.5rem;
  flex-wrap:wrap;
}
.list header .row { gap:.5rem; flex-wrap:wrap }
.list .cards { display:flex; flex-direction:column; gap:.5rem; min-height:10px }
.card-item {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:10px;
  padding:.6rem;
  display:flex;
  flex-direction:column;
  gap:.5rem;
  cursor:grab;
}

/* ==== Badges & labels ==== */
.badge {
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  background:#001D39;
  border:1px solid var(--border);
  padding:.1rem .45rem;
  border-radius:999px;
  font-size:.8rem;
}
.badge[class*="label-"]{width:.75rem;height:.75rem;border-radius:999px;padding:0;border:none}
.label-green{background:#22c55e}
.label-yellow{background:#eab308}
.label-red{background:#ef4444}
.label-blue{background:#3b82f6}
.label-purple{background:#a855f7}
.cards .meta{display:flex;flex-wrap:wrap;gap:.35rem}
.list .add-card{display:flex;gap:.4rem}

/* ==== Modal ==== */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center}
.modal.hidden{display:none}
.modal-content{
  width:min(940px,92vw);
  max-height:88vh;
  overflow:auto;
  background:#001D39;
  border:1px solid var(--border);
  border-radius:14px;
  padding:0 0 1rem;
}
.modal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1rem;
  border-bottom:1px solid var(--border);
}
.modal-body{padding:1rem;display:flex;flex-direction:column;gap:.75rem}
.grid-two{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
hr{border-color:var(--border)}
.plain-list{list-style:none;margin:0;padding:0}
.plain-list li{margin:.3rem 0}
.chips{display:flex;gap:.35rem;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .5rem;border-radius:999px;background:#0A4174;color:#BDD8E9;font-size:.85rem}

/* ==== CHECKLIST ITEMS - Estilos específicos ==== */
#checklistContainer li {
  margin: .5rem 0;
  padding: 0;
}

#checklistContainer li label.row {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 5px !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

#checklistContainer li label.row input[type="checkbox"] {
  flex: 0 0 auto !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  margin-right: 5px !important;
}

#checklistContainer li label.row .chk-text {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  text-align: left !important;
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
  margin: 0 !important;
  padding: 0 !important;
  color: var(--text) !important;
}

#checklistContainer li label.row button {
  flex: 0 0 auto !important;
  margin: 0 !important;
  margin-left: 5px !important;
  white-space: nowrap !important;
}

/* ==== Page-specific tweaks ==== */
.board-header-controls{padding:.5rem 0}
.board-header-controls .toolbar{gap:.5rem}

/* ==== Fondo para la zona de listas del tablero ==== */
.lists-wrapper.tablero-bg {
  background:url('../IMG/img_tablero.jpg') no-repeat center center fixed;
  background-size:cover;
  flex:1;
  min-height:calc(100vh - 60px); /* resta la altura aprox del header */
  padding:1rem;
  border-radius:0;
}

/* ==== Fondo para la página de Dashboard ==== */
body.dashboard-bg {
  background:url('../IMG/img_tablero.jpg') no-repeat center center fixed;
  background-size:cover;
}

/* =======================
   Responsive (móvil)
   ======================= */
@media (max-width:768px){

  /* Listas en columna con scroll vertical */
  .lists-wrapper{
    flex-direction:column !important;
    align-items:stretch !important;
    overflow-x:hidden !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch;
    gap:.75rem;
    padding:.75rem;
    min-height:calc(100vh - 60px);
  }

  /* Cada lista ocupa todo el ancho */
  .list{
    min-width:auto !important;
    max-width:none !important;
    width:100% !important;
  }

  .lists-wrapper .cards{min-height:0 !important}

  /* Header de lista con botones en varias filas */
  .list header{flex-wrap:wrap;gap:.5rem}
  .list header .row{flex-wrap:wrap;gap:.5rem}

  /* Toolbar superior adaptable */
  .topbar .right.toolbar{
    width:100%;
    padding-top:.5rem;
    gap:.5rem;
  }
  .topbar .right.toolbar input,
  .topbar .right.toolbar select{
    width:100% !important;
    min-width:0 !important;
    flex:1 1 100%;
  }

  /* Modal en 1 columna */
  .grid-two{grid-template-columns:1fr}
}



/* Solo móvil: separa la ficha 25px del menú superior y céntrala en horizontal */
@media (max-width: 640px) {
  .modal {
    align-items: flex-start;    /* empezamos arriba, no centrado vertical */
    justify-content: center;    /* centrado horizontal intacto */
    padding-top: 25px;          /* margen superior respecto al header */
  }
  .modal .modal-content {
    margin: 0;                  /* por si quedó algún margin-top previo */
    max-width: 92vw;            /* evita que se salga por la derecha */
    width: min(940px, 92vw);    /* mantiene tu ancho pero responsivo */
  }
}


/* MOBILE modal-content height fix */
@media (max-width: 640px){
  .modal .modal-content{
    max-height: calc(100dvh - 25px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* === Efecto visual para todos los elementos arrastrables === */
.dragging {
  opacity: 0.7;
  box-shadow: 0 8px 20px rgba(0,0,0,0.25);
  cursor: grabbing !important;
  transition: all 0.15s ease;
}





/* ==== Dashboard2 (list rows occupy container width) ==== */
.list{ display:flex; flex-direction:column; gap:.5rem; width:100%; }
.board-row{
  width:100%;
  display:grid;
  grid-template-columns: 28px 1fr auto;
  align-items:center;
  gap:.75rem;
  background: var(--panel);
  border:1px solid var(--border);
  border-radius:10px;
  padding:.5rem .75rem;
}
.board-row .color{ width:20px; height:20px; border-radius:6px; border:1px solid var(--border); }
.board-row .title{ font-weight:600; color:var(--text); cursor:pointer; }
.board-row .meta{ display:none; } /* oculto por simplicidad; podemos reactivar */
.board-row .actions{ display:flex; gap:.4rem; justify-content:flex-end }
.btn.xs{ padding:.3rem .55rem; border-radius:8px; font-size:.85rem }
.btn.danger{ background:var(--danger); color:#fff }
@media (max-width: 700px){
  .board-row{ grid-template-columns: 20px 1fr auto; }
}


/* ==== Calendar ==== */
.calendar-page { min-height:100vh; }
.calendar-title{
  min-width:220px;
  font-weight:700;
  text-align:center;
}
.calendar-layout{
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
  gap:1rem;
  padding:1rem;
}
.calendar-sidebar{
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.calendar-mini-card,
.calendar-shell{
  background:rgba(10,65,116,.92);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
}
.calendar-mini-card{
  padding:1rem;
}
.calendar-mini-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.5rem;
  margin-bottom:.75rem;
}
.mini-calendar-grid{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:.35rem;
}
.mini-calendar-head{
  margin-bottom:.4rem;
  color:#9ec6d6;
  font-size:.85rem;
  text-align:center;
}
.mini-day{
  min-height:38px;
  border-radius:10px;
  border:1px solid var(--border);
  background:#0c3357;
  color:var(--text);
  cursor:pointer;
  position:relative;
}
.mini-day.is-out{ opacity:.45; }
.mini-day.is-selected{
  outline:2px solid #bdd8e9;
  background:#155285;
}
.mini-day.has-cards::after{
  content:'';
  position:absolute;
  right:6px;
  bottom:5px;
  width:6px;
  height:6px;
  border-radius:999px;
  background:#facc15;
}
.calendar-summary{
  display:flex;
  flex-direction:column;
  gap:.5rem;
}
.calendar-main{
  min-width:0;
}
.calendar-view{
  min-width:0;
}
.month-shell{ padding:1rem; }
.month-weekdays,
.month-grid{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
}
.month-weekdays{
  gap:.5rem;
  margin-bottom:.5rem;
}
.month-weekdays > div{
  padding:.5rem .6rem;
  color:#9ec6d6;
  font-weight:600;
}
.month-grid{
  gap:.5rem;
}
.month-cell{
  min-height:160px;
  background:rgba(0,29,57,.85);
  border:1px solid rgba(189,216,233,.14);
  border-radius:14px;
  padding:.65rem;
  display:flex;
  flex-direction:column;
  gap:.5rem;
}
.month-cell.is-out{ opacity:.5; }
.month-cell.is-today{
  box-shadow:inset 0 0 0 2px rgba(189,216,233,.45);
}
.month-cell header{
  display:flex;
  justify-content:flex-end;
}
.month-day-link,
.day-head-link{
  border:none;
  background:transparent;
  color:var(--text);
  cursor:pointer;
}
.month-day-link{
  font-weight:700;
  font-size:1rem;
}
.month-events{
  display:flex;
  flex-direction:column;
  gap:.4rem;
  min-height:0;
}
.month-empty,
.all-day-empty{
  min-height:10px;
}
.calendar-event{
  width:100%;
  text-align:left;
  border:none;
  border-left:4px solid #7bbde8;
  background:#bdd8e9;
  color:#001d39;
  border-radius:10px;
  padding:.45rem .55rem;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  gap:.15rem;
  box-shadow:0 4px 10px rgba(0,0,0,.08);
}
.calendar-event.label-green{ border-left-color:#22c55e; }
.calendar-event.label-yellow{ border-left-color:#eab308; }
.calendar-event.label-red{ border-left-color:#ef4444; }
.calendar-event.label-blue{ border-left-color:#3b82f6; }
.calendar-event.label-purple{ border-left-color:#a855f7; }
.calendar-event-title{
  font-weight:700;
  line-height:1.2;
}
.calendar-event-meta{
  font-size:.8rem;
  opacity:.8;
}
.week-shell,
.day-shell{
  padding:0;
  overflow:hidden;
}
.time-grid{
  display:grid;
  background:rgba(255,255,255,.02);
}
.week-grid{
  grid-template-columns:90px repeat(7,minmax(0,1fr));
}
.day-grid{
  grid-template-columns:90px minmax(0,1fr);
}
.head-spacer{
  background:#f3f4f6;
  border-bottom:1px solid #d7dde6;
}
.day-head{
  background:#ffffff;
  color:#001d39;
  border-left:1px solid #d7dde6;
  border-bottom:1px solid #d7dde6;
  min-height:64px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.day-head.is-today{
  background:#0f6fcb;
  color:#fff;
}
.day-head-link{
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.25rem;
  padding:.5rem;
}
.day-head-link strong{ font-size:1.5rem; }
.all-day-label,
.time-label{
  background:#ffffff;
  color:#4b5563;
  border-right:1px solid #d7dde6;
  border-bottom:1px solid #d7dde6;
  padding:.65rem .5rem;
  text-align:right;
  font-size:.9rem;
}
.all-day-cell,
.time-slot{
  background:#ffffff;
  border-bottom:1px solid #e5e7eb;
  border-left:1px solid #e5e7eb;
  min-height:52px;
  padding:.35rem;
}
.all-day-cell{
  min-height:84px;
  display:flex;
  flex-direction:column;
  gap:.35rem;
}
.time-slot.is-today,
.all-day-cell.is-today{
  background:#fafcff;
}
.day-single-header{
  display:grid;
  grid-template-columns:90px minmax(0,1fr);
}
.day-single-header .day-head{
  grid-column:2;
  border-left:none;
}
.modal-content-narrow{
  width:min(760px,92vw);
}
.calendar-meta{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}
@media (max-width: 1100px){
  .calendar-layout{
    grid-template-columns:1fr;
  }
}
@media (max-width: 900px){
  .calendar-title{ min-width:auto; }
  .month-shell{ padding:.75rem; }
  .month-grid{ gap:.35rem; }
  .month-cell{ min-height:130px; }
}
@media (max-width: 720px){
  .calendar-layout{ padding:.75rem; }
  .month-weekdays > div{ font-size:.8rem; padding:.35rem; }
  .week-grid{ grid-template-columns:70px repeat(7,minmax(140px,1fr)); overflow:auto; }
  .day-grid{ grid-template-columns:70px minmax(220px,1fr); }
  .calendar-shell{ overflow:auto; }
}
