* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body { font-family: var(--font); color: var(--text); background: var(--bg-soft); font-size: 14px; }
h1, h2, h3 { margin: 0; }
button { font-family: inherit; }
.muted { color: var(--grey-500); font-size: 12px; }
.hint { color: var(--grey-500); font-size: 12.5px; }
code { background: var(--grey-100); padding: 1px 6px; border-radius: 5px; }

/* ============ SHELL ============ */
.shell { display: grid; grid-template-columns: 232px 1fr; min-height: 100vh; }

/* ---- Sidebar (tema claro: hace lucir el logo verde+azul) ---- */
.sidebar { background: #fff; color: var(--text); display: flex; flex-direction: column; padding: 18px 14px; gap: 12px; position: sticky; top: 0; height: 100vh; border-right: 1px solid var(--grey-200); }
.sidebar .brand { display: flex; align-items: center; padding: 4px 6px 16px; border-bottom: 1px solid var(--grey-100); margin-bottom: 4px; }
.sidebar .brand img { height: 40px; width: auto; max-width: 100%; }
.brand-fallback { display: flex; align-items: center; gap: 8px; font-weight: 800; color: var(--marino); font-size: 16px; }
.brand-fallback .dot { width: 14px; height: 14px; border-radius: 4px; background: var(--lima); }
.side-nav { display: flex; flex-direction: column; gap: 3px; }
.side-nav button { display: flex; align-items: center; gap: 11px; background: transparent; border: 0; color: #4a5269;
  padding: 11px 12px; border-radius: 10px; cursor: pointer; font-size: 14px; text-align: left; width: 100%; font-weight: 600; }
.side-nav button .ic { width: 18px; text-align: center; color: var(--grey-500); }
.side-nav button:hover { background: var(--bg-soft); color: var(--marino); }
.side-nav button.active { background: var(--lima-soft); color: var(--marino); box-shadow: inset 3px 0 0 var(--lima); }
.side-nav button.active .ic { color: var(--lima-dark); }
.side-foot { margin-top: auto; }
.legend-mini { display: flex; flex-direction: column; gap: 6px; padding: 10px 8px; border-top: 1px solid var(--grey-100); }
.legend-mini .it { display: flex; align-items: center; gap: 8px; font-size: 12px; color: #4a5269; }
.legend-mini .sw { width: 10px; height: 10px; border-radius: 3px; flex: 0 0 auto; }
.side-user { display: flex; align-items: center; gap: 10px; border-top: 1px solid var(--grey-200); padding-top: 14px; }
.side-user .avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--lima); color: var(--marino); font-weight: 800; display: flex; align-items: center; justify-content: center; }
.side-user select { background: var(--bg-soft); color: var(--marino); border: 1px solid var(--grey-200); border-radius: 7px; padding: 5px 7px; font-size: 13px; font-weight: 600; }
.side-user .muted { color: var(--grey-500); }
.side-user-btns { display: flex; flex-direction: column; gap: 2px; flex-shrink: 0; }
.side-user-btns .iconbtn { width: 28px; height: 28px; font-size: 13px; }

/* ---- Workspace ---- */
.workspace { padding: 18px 22px 40px; min-width: 0; }
.view { display: none; }
.view.active { display: block; }

/* ============ TOPBAR ============ */
.topbar { display: flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap;
  background: #fff; border-radius: 14px; box-shadow: var(--shadow); padding: 14px 18px; margin-bottom: 16px; }
.weeknav { display: flex; align-items: center; gap: 10px; }
.ic-btn { width: 36px; height: 36px; border-radius: 9px; border: 1px solid var(--grey-200); background: #fff; cursor: pointer; font-size: 20px; color: var(--marino); line-height: 1; }
.ic-btn:hover { background: var(--bg-soft); }
.weektitle h1 { font-size: 20px; color: var(--marino); }
.wt-row { display: flex; align-items: center; gap: 10px; position: relative; }
.wt-sub { color: var(--grey-500); font-size: 13px; margin-top: 2px; }
.pill { font-size: 12px; font-weight: 700; padding: 3px 11px; border-radius: 20px; cursor: pointer; user-select: none; }
.pill.Abierta { background: #e6f7e0; color: #4e7d10; }
.pill.Enviada { background: #fff3d6; color: #8a6400; }
.pill.Validada { background: #dcecff; color: #11519e; }
.pill.Facturada { background: #e8e4ff; color: #4b32b5; }
.menu { position: absolute; top: 30px; left: 70px; background: #fff; border: 1px solid var(--grey-200); border-radius: 10px; box-shadow: var(--shadow); z-index: 50; display: none; overflow: hidden; }
.menu.open { display: block; }
.menu button { display: block; width: 170px; text-align: left; padding: 9px 14px; border: 0; background: #fff; cursor: pointer; font-size: 13px; }
.menu button:hover { background: var(--bg-soft); }

.topbar-right { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.totalbox { text-align: right; }
.tb-num { font-size: 24px; font-weight: 800; color: var(--marino); }
.tb-sub { color: var(--grey-500); font-size: 12px; }
.ring { width: 56px; height: 56px; }
.actions-row { display: flex; gap: 8px; flex-wrap: wrap; }

/* ---- Botones ---- */
.btn { border: 0; border-radius: 9px; padding: 10px 15px; cursor: pointer; font-size: 14px; font-weight: 600; background: var(--grey-100); color: var(--marino); }
.btn:hover { filter: brightness(.97); }
.btn.sm { padding: 8px 12px; font-size: 13px; }
.btn.primary { background: var(--marino); color: #fff; }
.btn.lima { background: var(--lima); color: var(--marino); }
.btn.ghost { background: #fff; border: 1px solid var(--grey-200); }
.chk { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; color: var(--marino); cursor: pointer; }

/* ============ SEMANA LAYOUT ============ */
.semana-grid { display: grid; grid-template-columns: 1fr 300px; gap: 16px; align-items: start; }
@media (max-width: 1200px) { .semana-grid { grid-template-columns: 1fr; } }
.semana-main { min-width: 0; }

/* ---- KPIs ---- */
.kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 16px; }
@media (max-width: 1000px) { .kpis { grid-template-columns: 1fr; } }
.kcard { background: #fff; border-radius: 13px; box-shadow: var(--shadow); padding: 15px; min-height: 160px; }
.kcard h3 { font-size: 12px; text-transform: uppercase; letter-spacing: .4px; color: var(--grey-500); margin-bottom: 12px; }
.kcard .big { font-size: 34px; font-weight: 800; color: var(--marino); line-height: 1; }
.completion .progress { background: var(--grey-100); border-radius: 20px; height: 9px; margin: 12px 0 8px; overflow: hidden; }
.completion .bar { height: 100%; background: linear-gradient(90deg, var(--lima), var(--lima-dark)); border-radius: 20px; transition: width .4s; }

.daybars { display: flex; align-items: flex-end; gap: 6px; height: 80px; }
.daybars .d { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 4px; height: 100%; justify-content: flex-end; }
.daybars .d .bk { width: 100%; max-width: 22px; background: var(--grey-100); border-radius: 5px 5px 0 0; display: flex; flex-direction: column-reverse; overflow: hidden; min-height: 2px; }
.daybars .d .seg { width: 100%; }
.daybars .d .dl { font-size: 9.5px; color: var(--grey-500); }
.daybars .d.today .dl { color: var(--lima-dark); font-weight: 700; }

.klist { display: flex; flex-direction: column; gap: 8px; }
.klist.sm { gap: 5px; }
.klist .r { display: grid; grid-template-columns: 10px 1fr auto auto; align-items: center; gap: 8px; font-size: 13px; }
.klist .r .sw { width: 10px; height: 10px; border-radius: 3px; }
.klist .r .nm { color: var(--marino); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.klist .r .hh { font-weight: 700; color: var(--marino); }
.klist .r .pc { color: var(--grey-500); font-size: 11.5px; width: 32px; text-align: right; }
.donut-wrap { display: flex; gap: 12px; align-items: center; }
.donut-wrap svg { flex: 0 0 auto; }

/* ---- Toolbar / filtros ---- */
.toolbar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; background: #fff; border-radius: 11px; box-shadow: var(--shadow); padding: 10px 12px; margin-bottom: 12px; }
.toolbar select, .toolbar input[type=search], .toolbar input[type=text] { border: 1px solid var(--grey-200); border-radius: 8px; padding: 8px 10px; font: inherit; background: #fff; }
.toolbar input[type=search], .toolbar input[type=text] { min-width: 200px; flex: 1; }
.toolbar .sp { flex: 1; }
.overlap { color: var(--danger); font-size: 13px; font-weight: 600; }

/* ---- Grid ---- */
.grid-wrap { background: #fff; border-radius: 13px; box-shadow: var(--shadow); overflow: hidden; }
table.grid { width: 100%; border-collapse: collapse; }
table.grid thead th { background: #fbfcfe; color: var(--grey-500); text-align: left; padding: 11px 8px; font-size: 11.5px; text-transform: uppercase; letter-spacing: .3px; border-bottom: 1px solid var(--grey-200); position: sticky; top: 0; z-index: 5; }
table.grid tbody td { padding: 4px 6px; border-bottom: 1px solid var(--grey-100); }
table.grid tbody tr.entry:hover { background: #fbfdf6; }
table.grid input, table.grid select { width: 100%; border: 1px solid transparent; background: transparent; padding: 7px 6px; border-radius: 7px; font: inherit; color: var(--text); }
table.grid input:focus, table.grid select:focus { outline: none; border-color: var(--lima); background: #fff; box-shadow: 0 0 0 3px rgba(144,192,32,.18); }
td.tot { font-weight: 700; color: var(--marino); text-align: center; }
td.tot .ro { background: var(--grey-100); border-radius: 7px; padding: 6px 4px; display: inline-block; min-width: 50px; }
tr.daygroup { cursor: pointer; user-select: none; }
tr.daygroup:hover td { background: #e8eef8; }
tr.daygroup td { background: #f3f6fb; color: var(--marino); font-weight: 700; padding: 7px 12px; font-size: 12.5px; }
tr.daygroup .dt { color: var(--lima-dark); font-weight: 800; }
.day-toggle { font-size: 10px; color: var(--grey-500); margin-right: 7px; display: inline-block; width: 10px; }
tr.taskgroup td { background: #f8faf0; color: var(--marino); font-weight: 700; padding: 6px 12px; font-size: 12.5px; }
td.act { white-space: nowrap; text-align: right; }
.c-date { width: 116px; } .c-cli { width: 184px; } .c-proj { width: 140px; } .c-time { width: 78px; } .c-tot { width: 66px; } .c-act { width: 86px; }
.iconbtn { background: transparent; border: 0; cursor: pointer; color: var(--grey-500); padding: 5px; border-radius: 6px; font-size: 14px; }
.iconbtn:hover { background: var(--grey-100); color: var(--marino); }
.iconbtn.del:hover { background: #f9e0db; color: var(--danger); }
tr.warn td { box-shadow: inset 3px 0 0 var(--danger); }
.addrow { width: 100%; border: 0; border-top: 1px dashed var(--grey-200); background: #fbfdf6; color: var(--lima-dark); font-weight: 700; padding: 12px; cursor: pointer; }
.addrow:hover { background: #f3f9e6; }
.footnote { color: var(--grey-500); font-size: 12px; margin-top: 12px; }
.footnote b { color: var(--marino); }

/* ---- Select estilizado (combobox bonito) ---- */
.select-pretty {
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' fill='none' stroke='%23001868' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; background-size: 12px;
  border: 1px solid var(--grey-200); border-radius: 9px;
  padding: 9px 34px 9px 13px; min-width: 230px; font-size: 13px; font-weight: 600;
  color: var(--marino); cursor: pointer; line-height: 1.2;
  transition: border-color .15s, box-shadow .15s;
}
.select-pretty:hover { border-color: var(--grey-300); }
.select-pretty:focus { outline: none; border-color: var(--lima); box-shadow: 0 0 0 3px var(--lima-soft); }
[data-theme="dark"] .select-pretty {
  background-color: var(--bg-card); color: var(--text); border-color: var(--border);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' fill='none' stroke='%236b9ef4' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* ---- Facturación ---- */
.bill-controls { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 16px; margin: 14px 0 6px; }
.bill-right { display: flex; align-items: flex-end; gap: 10px; }
.bill-right .field label { display: block; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--grey-500); margin-bottom: 5px; }
#billTable tr.bill-section td { background: var(--bg-soft); color: var(--grey-500); font-weight: 700; text-transform: uppercase; font-size: 11px; letter-spacing: .04em; padding: 8px 10px; }
.tag-int { background: var(--grey-200); color: var(--grey-500); font-size: 10px; padding: 1px 6px; border-radius: 6px; font-weight: 600; vertical-align: middle; }

/* ---- Notificaciones ---- */
.notif-btn { position: relative; }
.notif-badge { position: absolute; top: -4px; right: -4px; background: var(--danger); color: #fff; border-radius: 10px; font-size: 10px; min-width: 16px; height: 16px; line-height: 16px; text-align: center; padding: 0 3px; font-weight: 700; }
.notif-panel { position: fixed; left: 14px; bottom: 74px; width: 320px; max-height: 62vh; overflow-y: auto; background: #fff; border: 1px solid var(--grey-200); border-radius: 12px; box-shadow: var(--shadow); display: none; z-index: 200; }
.notif-panel.open { display: block; }
.notif-hd { display: flex; justify-content: space-between; align-items: center; padding: 11px 14px; border-bottom: 1px solid var(--grey-200); position: sticky; top: 0; background: #fff; border-radius: 12px 12px 0 0; }
.notif-hd h3 { margin: 0; font-size: 14px; color: var(--marino); }
.notif-hd-actions { display: flex; gap: 6px; }
.notif-item { padding: 10px 14px; border-bottom: 1px solid var(--grey-100); }
.notif-item.unread { background: var(--lima-soft); }
.notif-msg { font-size: 13px; color: var(--marino); line-height: 1.35; }
.notif-time { font-size: 11px; color: var(--grey-500); margin-top: 3px; }
.notif-empty { padding: 20px; text-align: center; color: var(--grey-500); font-size: 13px; }
[data-theme="dark"] .notif-panel { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .notif-hd { background: var(--bg-card); border-color: var(--border); }

/* ---- Calendario ----
   Usa todo el ancho disponible (el resto de paneles siguen a 1000px), una altura por hora
   generosa (64px, antes 44) para que los tramos de 15-30 min sean legibles, y rellena la
   altura visible de la ventana (en vez de un 72vh fijo que dejaba hueco libre debajo):
   topbar a su alto natural, el panel se reparte el resto. */
#calendario.view.active { display: flex; flex-direction: column; height: calc(100vh - 58px); }
#calendario .topbar { flex: 0 0 auto; }
#calendario .panel { max-width: 1700px; flex: 1 1 auto; display: flex; flex-direction: column; min-height: 0; }
#calendario .panel #calWrap { flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column; }
/* Cabecera y cuerpo comparten un único scroll (cal-scroll); la cabecera es sticky dentro
   de él. Si tuvieran cada una su propio scroll (o una scrollbar y la otra no), sus columnas
   se calculan sobre anchos distintos y se desalinean — por eso NO van en grids separados. */
.cal-scroll { flex: 1 1 auto; min-height: 0; overflow-y: auto; }
.cal-head { display: grid; grid-template-columns: 64px repeat(7, 1fr); border-bottom: 1px solid var(--grey-200); background: #fff; position: sticky; top: 0; z-index: 6; }
.cal-gutter-h { border-right: 1px solid var(--grey-200); }
.cal-dh { padding: 13px 6px; text-align: center; font-size: 13px; font-weight: 700; color: var(--marino); border-left: 1px solid var(--grey-100); }
.cal-dh.today { background: var(--lima-soft); border-bottom: 2px solid var(--lima); }
/* padding-top: dale aire a la primera hora (06:00) — su etiqueta se centra con un
   translateY negativo (ver .cal-hr) y sin este margen queda tapada por la cabecera sticky.
   padding-bottom: que el último tramo del día no quede pegado al borde inferior. */
.cal-body { display: grid; grid-template-columns: 64px repeat(7, 1fr); padding: 12px 0 16px; }
.cal-gutter { position: relative; border-right: 1px solid var(--grey-200); }
.cal-hr { position: absolute; right: 8px; font-size: 11px; font-weight: 600; color: var(--grey-500); font-variant-numeric: tabular-nums; transform: translateY(-7px); }
.cal-col { position: relative; border-left: 1px solid var(--grey-100); cursor: crosshair;
  /* línea fina cada media hora + línea más marcada cada hora, alineadas a _calHourPx=64 */
  background-image:
    repeating-linear-gradient(to bottom, transparent 0, transparent 31px, rgba(0,24,104,.035) 31px, rgba(0,24,104,.035) 32px),
    repeating-linear-gradient(to bottom, transparent 0, transparent 63px, var(--grey-100) 63px, var(--grey-100) 64px); }
.cal-block { position: absolute; border-radius: 9px; padding: 5px 9px; color: #fff; overflow: hidden; font-size: 12px; box-shadow: 0 2px 6px rgba(0,24,104,.18); cursor: pointer; transition: box-shadow .12s ease, transform .12s ease; }
.cal-block:hover { box-shadow: 0 5px 14px rgba(0,24,104,.3); transform: translateY(-1px); z-index: 2; }
.cal-block.compact { padding: 3px 9px; display: flex; align-items: center; }
.cal-block.compact .cb-t { flex: 1 1 auto; min-width: 0; }
.cb-t { font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 1.35; }
.cb-s { opacity: .88; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 11px; line-height: 1.3; margin-top: 1px; }
.cal-preview { position: absolute; left: 2px; right: 2px; background: rgba(144,192,32,.32); border: 1px dashed var(--lima-dark); border-radius: 9px; pointer-events: none; }
[data-theme="dark"] .cal-head { background: var(--bg-card); }
[data-theme="dark"] .cal-dh { color: var(--text); }
[data-theme="dark"] .cal-col { background-image:
    repeating-linear-gradient(to bottom, transparent 0, transparent 31px, rgba(255,255,255,.025) 31px, rgba(255,255,255,.025) 32px),
    repeating-linear-gradient(to bottom, transparent 0, transparent 63px, var(--grey-100) 63px, var(--grey-100) 64px); }
.bill-total { background: var(--lima-soft); color: var(--marino); border-radius: 10px; padding: 10px 14px; font-size: 14px; margin: 8px 0 14px; }
.bill-total b { color: var(--marino); font-size: 15px; }
#billTable tr.bill-sub td { border-top: 1px solid var(--grey-200); color: var(--marino); }
#billTable td { padding: 7px 10px; }

/* ---- Combobox cliente (buscador) ----
   position:fixed (en vez de absolute) a propósito: así el desplegable escapa de
   cualquier ancestro con overflow:hidden (la cuadrícula .grid-wrap, el modal con
   scroll propio…) que si no lo recortaba y lo dejaba minúsculo/ilegible. La
   posición (left/top/width) la calcula App._positionAcList() en JS a partir del
   input real, así que aquí solo van tamaño y estilo. */
.combo { position: relative; }
.combo .ac-list { position: fixed; z-index: 350; background: #fff; border: 1px solid var(--grey-200); border-radius: 12px; box-shadow: 0 14px 34px rgba(0,24,104,.16); max-height: 360px; overflow-y: auto; overscroll-behavior: contain; display: none; min-width: 300px; padding: 6px; }
.combo .ac-list.open { display: block; }
.combo .ac-list div { padding: 10px 12px; cursor: pointer; font-size: 14px; display: flex; justify-content: space-between; align-items: center; gap: 12px; border-radius: 8px; line-height: 1.3; }
.combo .ac-list div .ac-name { font-weight: 600; color: var(--marino); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.combo .ac-list div .ac-code { flex: 0 0 auto; font-family: ui-monospace, "Cascadia Mono", Consolas, monospace; font-size: 11px; font-weight: 700; letter-spacing: .3px; color: var(--grey-500); background: var(--grey-100); padding: 3px 8px; border-radius: 6px; }
.combo .ac-list div:hover, .combo .ac-list div.sel { background: var(--lima-soft); }
.combo .ac-list div:hover .ac-code, .combo .ac-list div.sel .ac-code { background: #fff; color: var(--marino); }
.combo .ac-list .none { color: var(--grey-500); cursor: default; padding: 14px 12px; text-align: center; font-size: 13px; }

/* Scroll estilizado siguiendo la marca (verde lima sobre track gris claro) */
.combo .ac-list { scrollbar-width: thin; scrollbar-color: var(--grey-300) transparent; }
.combo .ac-list::-webkit-scrollbar { width: 9px; }
.combo .ac-list::-webkit-scrollbar-track { background: transparent; margin: 4px 0; }
.combo .ac-list::-webkit-scrollbar-thumb { background: var(--grey-300); border-radius: 9px; border: 2px solid #fff; }
.combo .ac-list::-webkit-scrollbar-thumb:hover { background: var(--lima); }

/* ---- Autocomplete ---- */
.ac-wrap { position: relative; }
.ac-list { position: absolute; z-index: 30; left: 0; right: 0; background: #fff; border: 1px solid var(--grey-200); border-radius: 9px; box-shadow: var(--shadow); max-height: 200px; overflow: auto; display: none; }
.ac-list div { padding: 8px 11px; cursor: pointer; font-size: 13px; }
.ac-list div:hover, .ac-list div.sel { background: var(--bg-soft); }

/* ============ RAIL ============ */
.rail { display: flex; flex-direction: column; gap: 14px; }
.rcard { background: #fff; border-radius: 13px; box-shadow: var(--shadow); padding: 14px; }
.rhead { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.rhead h3 { font-size: 12px; text-transform: uppercase; letter-spacing: .4px; color: var(--grey-500); }
.wk { display: flex; align-items: center; justify-content: space-between; padding: 9px 10px; border-radius: 9px; cursor: pointer; }
.wk:hover { background: var(--bg-soft); }
.wk.current { background: #f3f9e6; outline: 1px solid var(--lima); }
.wk .wl { font-weight: 700; color: var(--marino); font-size: 13px; }
.wk .wd { color: var(--grey-500); font-size: 11.5px; }
.wk .wr { text-align: right; }
.wk .wh { font-weight: 800; color: var(--marino); font-size: 13px; }
.badge { font-size: 10.5px; font-weight: 700; padding: 2px 8px; border-radius: 12px; }
.badge.Abierta { background: #e6f7e0; color: #4e7d10; }
.badge.Enviada { background: #fff3d6; color: #8a6400; }
.badge.Validada { background: #dcecff; color: #11519e; }
.badge.Facturada { background: #e8e4ff; color: #4b32b5; }
.quick { display: block; width: 100%; text-align: left; background: var(--bg-soft); border: 0; border-radius: 9px; padding: 10px 12px; margin-bottom: 7px; cursor: pointer; color: var(--marino); font-size: 13px; font-weight: 600; }
.quick:hover { background: var(--grey-100); }
.cmp { display: flex; justify-content: space-between; padding: 6px 0; font-size: 13px; }
.cmp b { color: var(--marino); }
.cmp.delta { font-weight: 800; justify-content: flex-end; }
.cmp.delta.up { color: var(--lima-dark); }
.cmp.delta.down { color: var(--danger); }

/* ============ Paneles genéricos ============ */
.panel { background: #fff; border-radius: 13px; box-shadow: var(--shadow); padding: 22px; margin-bottom: 16px; max-width: 1000px; }
.panel.narrow { max-width: 560px; margin: 40px auto; }
.panel h2 { color: var(--marino); font-size: 18px; margin-bottom: 16px; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field { margin-bottom: 6px; }
.field label { display: block; font-weight: 600; margin-bottom: 5px; color: var(--marino); font-size: 13px; }
.field input { width: 100%; padding: 9px 11px; border: 1px solid var(--grey-300); border-radius: 8px; font: inherit; }
.panel .btn { margin-top: 14px; }
table.maptable { width: 100%; border-collapse: collapse; margin-top: 12px; }
table.maptable th { text-align: left; padding: 9px; color: var(--marino); border-bottom: 2px solid var(--lima); font-size: 12.5px; }
table.maptable td { padding: 7px 9px; border-bottom: 1px solid var(--grey-100); }
table.maptable input[type=text] { width: 100%; padding: 7px; border: 1px solid var(--grey-300); border-radius: 7px; }
.tag { background: var(--grey-100); color: var(--marino); border-radius: 16px; padding: 2px 9px; font-size: 11.5px; margin: 2px; display: inline-block; }

/* ====== Clientes y Proyectos — maestro/detalle plano ====== */
/* Esta vista aprovecha todo el ancho disponible (el resto de paneles siguen a 1000px). */
#clientes .panel { max-width: 1600px; }
.cli-counter { font-size: 12px; font-weight: 700; color: var(--grey-500); background: var(--grey-100); padding: 4px 11px; border-radius: 20px; white-space: nowrap; }
/* Dos columnas separadas solo por una hairline; nada de cajas dentro de cajas. */
.cli-layout { display: grid; grid-template-columns: 320px minmax(0, 1fr); gap: 0; align-items: stretch; margin-top: 18px; min-height: 64vh; }

/* --- panel izquierdo: lista buscable (estilo sidebar) --- */
.cli-list-pane { display: flex; flex-direction: column; gap: 10px; min-width: 0; padding-right: 20px; border-right: 1px solid var(--grey-100); }
.cli-search { position: relative; }
.cli-search-ic { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); font-size: 12px; opacity: .5; pointer-events: none; }
.cli-search input { width: 100%; padding: 10px 12px 10px 34px; border: 1px solid var(--grey-200); border-radius: 10px; font: inherit; background: var(--grey-100); transition: background .12s, border-color .12s; }
.cli-search input:focus { outline: none; border-color: var(--lima); background: #fff; }
.cli-showhidden { font-size: 11.5px; color: var(--grey-500); padding-left: 2px; }
.cli-list { display: flex; flex-direction: column; gap: 1px; max-height: 62vh; overflow-y: auto; margin: 0 -6px; padding: 0 6px; }
.cli-row { display: flex; align-items: center; gap: 9px; width: 100%; text-align: left; background: transparent; border: none; border-left: 3px solid transparent; border-radius: 8px; padding: 9px 10px; cursor: pointer; font: inherit; transition: background .12s; }
.cli-row:hover { background: var(--grey-100); }
.cli-row.selected { background: var(--lima-soft); border-left-color: var(--lima); }
.cli-row.hidden-cli { opacity: .45; }
.cli-row.hidden-cli .cli-row-name { text-decoration: line-through; }
.cli-row-code { font-family: ui-monospace, "Cascadia Mono", Consolas, monospace; font-size: 10px; font-weight: 700; letter-spacing: .4px; color: var(--grey-500); background: var(--grey-100); padding: 3px 6px; border-radius: 5px; flex: 0 0 auto; }
.cli-row.selected .cli-row-code { background: #fff; color: var(--marino); }
.cli-row-name { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--marino); font-weight: 600; font-size: 13px; }
.cli-row-meta { display: flex; align-items: center; gap: 8px; flex: 0 0 auto; }
.dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; flex: 0 0 auto; }
.dot.lima { background: var(--lima); }
.dot.grey { background: var(--grey-300); }
.cli-count { min-width: 22px; height: 19px; padding: 0 6px; border-radius: 10px; background: var(--grey-100); color: var(--grey-500); font-size: 11px; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; }
.cli-row.selected .cli-count { background: #fff; color: var(--marino); }
.cli-newrow { display: flex; gap: 6px; padding-top: 10px; border-top: 1px solid var(--grey-100); }
.cli-newrow input { flex: 1 1 auto; min-width: 0; padding: 9px 11px; border: 1px solid var(--grey-200); border-radius: 9px; font: inherit; }
.cli-newrow input:focus { outline: none; border-color: var(--lima); }

/* --- panel derecho: detalle del cliente (plano, sobre el propio panel) --- */
.cli-detail { background: transparent; border: none; padding: 0 4px 8px 26px; max-height: 72vh; overflow-y: auto; }
.cli-empty { color: var(--grey-500); font-size: 13px; padding: 60px 12px; text-align: center; }
.cli-empty.sm { padding: 16px 4px; text-align: left; }
.cli-detail-hd { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.cli-code-chip { font-family: ui-monospace, "Cascadia Mono", Consolas, monospace; font-size: 11px; font-weight: 700; color: var(--grey-500); background: var(--grey-100); padding: 5px 10px; border-radius: 7px; letter-spacing: .5px; flex: 0 0 auto; }
.cli-name-input { flex: 1 1 auto; min-width: 0; font-size: 22px; font-weight: 800; color: var(--marino); border: none; background: transparent; padding: 4px 6px; border-radius: 8px; letter-spacing: -.2px; }
.cli-name-input:hover { background: var(--grey-100); }
.cli-name-input:focus { outline: none; box-shadow: inset 0 0 0 1.5px var(--lima); background: #fff; }

/* --- interruptores (switch) --- */
.cli-detail-toggles { display: flex; align-items: center; gap: 22px; padding-bottom: 18px; margin-bottom: 6px; border-bottom: 1px solid var(--grey-100); }
.switch { display: inline-flex; align-items: center; gap: 9px; cursor: pointer; user-select: none; position: relative; }
.switch input { position: absolute; opacity: 0; width: 0; height: 0; }
.switch .track { width: 36px; height: 21px; border-radius: 21px; background: var(--grey-300); transition: background .18s; flex: 0 0 auto; position: relative; }
.switch .track::after { content: ''; position: absolute; top: 2px; left: 2px; width: 17px; height: 17px; border-radius: 50%; background: #fff; box-shadow: 0 1px 3px rgba(0,24,104,.25); transition: transform .18s; }
.switch input:checked + .track { background: var(--lima); }
.switch input:checked + .track::after { transform: translateX(15px); }
.switch input:focus-visible + .track { box-shadow: 0 0 0 3px var(--lima-soft); }
.switch-lbl { font-size: 13px; font-weight: 600; color: var(--marino); }
.switch.sm .track { width: 30px; height: 18px; }
.switch.sm .track::after { width: 14px; height: 14px; }
.switch.sm input:checked + .track::after { transform: translateX(12px); }

/* --- lista de proyectos (filas planas con hairline) --- */
.cli-proj-hd { display: flex; align-items: center; gap: 8px; margin: 20px 0 6px; }
.cli-proj-hd h3 { margin: 0; font-size: 11px; color: var(--grey-500); text-transform: uppercase; letter-spacing: .9px; font-weight: 700; }
/* Rejilla responsiva: las tecnologías fluyen en varias columnas y aprovechan el ancho. */
.cli-proj-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(440px, 1fr)); column-gap: 34px; align-items: start; }
.proj-item { border-bottom: 1px solid var(--grey-100); }
.proj-item.inactive .proj-name { color: var(--grey-500); }
.proj-item.inactive { opacity: .7; }
.proj-row { display: flex; align-items: center; gap: 8px; padding: 5px 0; }
.chev { display: inline-flex; align-items: center; gap: 4px; border: none; background: transparent; cursor: pointer; color: var(--grey-500); font: inherit; padding: 4px 6px; border-radius: 7px; flex: 0 0 auto; transition: background .12s; }
.chev:hover { background: var(--grey-100); }
.chev-ic { font-size: 15px; line-height: 1; transition: transform .15s; display: inline-block; }
.proj-item.expanded .chev-ic { transform: rotate(90deg); }
.chev-n { font-size: 11px; font-weight: 700; min-width: 13px; text-align: center; }
.chev.empty .chev-n { opacity: .35; }
.proj-name { flex: 1 1 auto; min-width: 0; border: none; background: transparent; font: inherit; font-weight: 600; font-size: 14px; color: var(--marino); padding: 7px 9px; border-radius: 8px; transition: background .12s; }
.proj-name:hover { background: var(--grey-100); }
.proj-name:focus { outline: none; background: #fff; box-shadow: inset 0 0 0 1.5px var(--lima); }

/* --- subproyectos (indentados, con línea de acento, planos) --- */
.sub-wrap { display: flex; flex-direction: column; gap: 1px; margin: 0 0 8px 16px; padding-left: 16px; border-left: 2px solid var(--grey-200); }
.sub-wrap[hidden] { display: none; }  /* el atributo hidden manda sobre display:flex */
.sub-item { display: flex; align-items: center; gap: 8px; }
.sub-name { flex: 1 1 auto; min-width: 0; border: none; background: transparent; font: inherit; font-size: 13px; color: var(--marino); padding: 6px 9px; border-radius: 7px; transition: background .12s; }
.sub-name:hover { background: var(--grey-100); }
.sub-name:focus { outline: none; background: #fff; box-shadow: inset 0 0 0 1.5px var(--lima); }
.sub-add { display: flex; align-items: center; gap: 6px; margin-top: 2px; }
.sub-add input { flex: 1 1 auto; min-width: 0; border: none; border-bottom: 1px dashed var(--grey-300); background: transparent; font: inherit; font-size: 12.5px; padding: 5px 9px; color: var(--marino); }
.sub-add input:focus { outline: none; border-bottom-color: var(--lima); }

/* --- añadir proyecto (pie del detalle) --- */
.proj-add { display: flex; align-items: center; gap: 10px; margin-top: 14px; padding-top: 14px; border-top: 1px dashed var(--grey-200); }
.proj-add-ic { color: var(--lima); font-weight: 700; font-size: 16px; flex: 0 0 auto; }
.proj-add input { flex: 1 1 auto; min-width: 0; border: none; background: transparent; font: inherit; padding: 6px 0; color: var(--marino); }
.proj-add input:focus { outline: none; }

@media (max-width: 880px) {
  .cli-layout { grid-template-columns: 1fr; min-height: 0; }
  .cli-list-pane { border-right: none; padding-right: 0; border-bottom: 1px solid var(--grey-100); padding-bottom: 14px; }
  .cli-list { max-height: 34vh; }
  .cli-detail { padding: 16px 4px 8px; max-height: none; }
  .cli-proj-list { grid-template-columns: 1fr; }
}
/* Detalle ancho: si no hay sitio para 2 columnas cómodas, una sola. */
@media (max-width: 1180px) {
  .cli-proj-list { grid-template-columns: 1fr; }
}

/* ===== Modal plan B correo ===== */
.modal-back { position: fixed; inset: 0; background: rgba(0,24,104,.35); z-index: 300; display: none; align-items: center; justify-content: center; }
.modal-back.open { display: flex; }
.modal-box { background: #fff; border-radius: 16px; box-shadow: 0 12px 40px rgba(0,24,104,.18); padding: 28px; max-width: 580px; width: 94%; max-height: 90vh; overflow-y: auto; }
.modal-hd { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.modal-hd h2 { color: var(--marino); font-size: 18px; }
.modal-ft { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; border-top: 1px solid var(--grey-100); padding-top: 16px; }

/* Modal de tramo (calendario) */
.em-body { display: flex; flex-direction: column; gap: 12px; }
.em-body select { width: 100%; padding: 9px 11px; border: 1px solid var(--grey-300); border-radius: 8px; font: inherit; background: #fff; }
.em-total { font-weight: 700; color: var(--marino); background: var(--lima-soft); cursor: default; }
.em-ft { justify-content: flex-start; flex-wrap: wrap; }
.em-spacer { flex: 1; }
.em-del { color: #dc2626; }
[data-theme="dark"] .em-body select { background: var(--grey-100); color: var(--text); border-color: var(--border); }
[data-theme="dark"] .em-total { color: var(--text); background: var(--grey-100); }
.mp-row { display: grid; grid-template-columns: 80px 1fr; gap: 10px; align-items: start; margin-bottom: 12px; }
.mp-row label { font-weight: 700; color: var(--marino); font-size: 13px; padding-top: 6px; }
.mp-val { background: var(--bg-soft); border-radius: 8px; padding: 8px 11px; font-size: 13px; word-break: break-all; }
.mp-val-copy { display: flex; align-items: flex-start; gap: 8px; background: var(--bg-soft); border-radius: 8px; padding: 8px 11px; }
.mp-val-copy.col { flex-direction: column; }
.mp-val-copy span, .mp-val-copy pre { flex: 1; font-size: 13px; margin: 0; white-space: pre-wrap; font-family: inherit; }
.mp-file { font-size: 12px; color: var(--marino); background: var(--lima-soft); border-radius: 7px; padding: 5px 10px; margin-bottom: 4px; font-weight: 600; word-break: break-all; }

/* ---- Toast ---- */
.toast { position: fixed; bottom: 22px; right: 22px; background: var(--marino); color: #fff; padding: 12px 18px; border-radius: 11px; box-shadow: var(--shadow); opacity: 0; transform: translateY(10px); transition: .25s; z-index: 200; }
.toast.show { opacity: 1; transform: translateY(0); }
.toast.err { background: var(--danger); }
.toast.ok { background: var(--lima); color: var(--marino); font-weight: 700; }

/* ---- Modo lectura (Gerente) ---- */
body.readonly [data-hide-readonly] { display: none !important; }
body.readonly .addrow { display: none !important; }
body.readonly tr.daygroup .iconbtn { display: none !important; }
body.readonly tr.entry .act { display: none !important; }
body.readonly tr.entry input,
body.readonly tr.entry select { pointer-events: none; background: transparent !important; border-color: transparent !important; color: var(--text); }
body.readonly tr.entry { cursor: default; }

/* ---- Panel header con botón ---- */
.panel-hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.panel-hd h2 { margin: 0; }

/* ---- Tabla de usuarios (admin) ---- */
.usertable { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.usertable th { text-align: left; color: var(--grey-500); font-weight: 600; font-size: 12px; padding: 6px 10px; border-bottom: 2px solid var(--grey-200); }
.usertable td { padding: 10px 10px; border-bottom: 1px solid var(--grey-100); vertical-align: middle; }
.usertable tr:last-child td { border-bottom: 0; }
.usertable tr.row-inactive td { opacity: .5; }
.role-tag { display: inline-block; padding: 2px 9px; border-radius: 20px; font-size: 11.5px; font-weight: 700; }
.role-tag.rt-admin   { background: #e8eaf6; color: #001868; }
.role-tag.rt-gerente { background: #fff8e1; color: #78350f; }
.role-tag.rt-senior  { background: #e3f2fd; color: #1e40af; }
.role-tag.rt-junior  { background: #e8f5e9; color: #14532d; }
.dot-on  { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: #22c55e; }
.dot-off { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: var(--grey-300); }

/* ---- Organigrama ---- */
.org-wrap { position: relative; display: flex; flex-direction: column; align-items: center; padding: 16px 24px 24px; overflow: visible; }
.org-level { display: flex; gap: 16px; justify-content: center; padding: 18px 0; position: relative; z-index: 1; }
.org-card { padding: 10px 22px; border-radius: 10px; text-align: center; min-width: 110px; border: 2px solid; font-size: 13px; }
.org-card .oc-name { font-weight: 700; }
.org-card .oc-role { font-size: 11px; opacity: .6; margin-top: 3px; }
.org-svg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; pointer-events: none; z-index: 0; overflow: visible; }

/* ================================================================
   DARK MODE — sistema completo (una sola fuente de verdad)
   Nota: --marino se sobreescribe en tokens.css a #6b9ef4,
   lo que arregla automáticamente todos los var(--marino) de texto.
================================================================ */

/* Estructura principal */
[data-theme="dark"] body       { background: var(--bg-soft); color: var(--text); }
[data-theme="dark"] .sidebar   { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .workspace { background: var(--bg-soft); }

/* Topbar */
[data-theme="dark"] .topbar    { background: var(--bg-card); box-shadow: var(--shadow); }
[data-theme="dark"] .ic-btn    { background: var(--grey-100); border-color: var(--border); color: var(--text); }
[data-theme="dark"] .ic-btn:hover { background: var(--grey-200); }
[data-theme="dark"] .menu      { background: var(--bg-card); border-color: var(--border); box-shadow: var(--shadow); }
[data-theme="dark"] .menu button     { background: transparent; color: var(--text); }
[data-theme="dark"] .menu button:hover { background: var(--grey-100); }

/* Navegación lateral */
[data-theme="dark"] .side-nav button      { color: var(--grey-500); }
[data-theme="dark"] .side-nav button:hover { background: var(--grey-100); color: var(--text); }
[data-theme="dark"] .side-nav button.active { background: rgba(163,212,59,.1); color: var(--lima); box-shadow: inset 3px 0 0 var(--lima); }
[data-theme="dark"] .side-nav button.active .ic { color: var(--lima); }
[data-theme="dark"] .legend-mini .it      { color: var(--grey-500); }
[data-theme="dark"] .side-user select     { background: var(--grey-100); color: var(--text); border-color: var(--border); }

/* KPI cards */
[data-theme="dark"] .kcard               { background: var(--bg-card); box-shadow: var(--shadow); }
[data-theme="dark"] .daybars .d .bk      { background: var(--grey-200); }

/* Toolbar + filtros */
[data-theme="dark"] .toolbar             { background: var(--bg-card); box-shadow: var(--shadow); }
[data-theme="dark"] .toolbar select,
[data-theme="dark"] .toolbar input[type=search],
[data-theme="dark"] .toolbar input[type=text] { background: var(--grey-100); color: var(--text); border-color: var(--border); }

/* Grid de horas */
[data-theme="dark"] .grid-wrap                      { background: var(--bg-card); }
[data-theme="dark"] table.grid thead th             { background: var(--bg-soft); color: var(--grey-500); border-color: var(--border); }
[data-theme="dark"] table.grid tbody td             { border-color: var(--grey-100); }
[data-theme="dark"] table.grid tbody tr.entry:hover { background: var(--grey-100); }
[data-theme="dark"] table.grid input,
[data-theme="dark"] table.grid select               { color: var(--text); }
[data-theme="dark"] tr.daygroup td                  { background: var(--grey-100); color: var(--text); }
[data-theme="dark"] tr.daygroup .dt                 { color: var(--lima); }
[data-theme="dark"] tr.daygroup:hover td            { background: var(--grey-200); }
[data-theme="dark"] tr.taskgroup td                 { background: var(--grey-100); }
[data-theme="dark"] .addrow                         { background: var(--bg-soft); border-color: var(--border); color: var(--lima); }
[data-theme="dark"] .addrow:hover                   { background: var(--grey-100); }
[data-theme="dark"] td.tot .ro                      { background: var(--grey-100); }

/* Autocomplete y combos */
[data-theme="dark"] .ac-list,
[data-theme="dark"] .combo .ac-list    { background: var(--bg-card); border-color: var(--border); box-shadow: var(--shadow); }
[data-theme="dark"] .combo .ac-list div .ac-name { color: var(--text); }
[data-theme="dark"] .combo .ac-list div .ac-code { background: var(--grey-200); color: var(--text); }
[data-theme="dark"] .combo .ac-list div:hover,
[data-theme="dark"] .combo .ac-list div.sel { background: var(--grey-100); }
[data-theme="dark"] .combo .ac-list div:hover .ac-code,
[data-theme="dark"] .combo .ac-list div.sel .ac-code { background: var(--bg-card); }
[data-theme="dark"] .ac-list div:hover,
[data-theme="dark"] .ac-list div.sel   { background: var(--grey-100); }
[data-theme="dark"] .combo .ac-list { scrollbar-color: var(--grey-300) transparent; }
[data-theme="dark"] .combo .ac-list::-webkit-scrollbar-thumb { background: var(--grey-300); border-color: var(--bg-card); }
[data-theme="dark"] .combo .ac-list::-webkit-scrollbar-thumb:hover { background: var(--lima); }

/* Rail derecho */
[data-theme="dark"] .rcard             { background: var(--bg-card); border: 1px solid var(--border); box-shadow: var(--shadow); }
[data-theme="dark"] .wk:hover          { background: var(--grey-100); }
[data-theme="dark"] .wk.current        { background: rgba(163,212,59,.08); outline-color: var(--lima); }
[data-theme="dark"] .quick             { background: var(--grey-100); color: var(--text); }
[data-theme="dark"] .quick:hover       { background: var(--grey-200); }

/* Paneles genéricos */
[data-theme="dark"] .panel             { background: var(--bg-card); border: 1px solid var(--border); }
[data-theme="dark"] .field label       { color: var(--text); }
[data-theme="dark"] .field input       { background: var(--grey-100); color: var(--text); border-color: var(--border); }
[data-theme="dark"] .tag               { background: var(--grey-200); color: var(--text); }
[data-theme="dark"] .mp-val,
[data-theme="dark"] .mp-val-copy       { background: var(--grey-100); }

/* Clientes y Proyectos (maestro/detalle plano) — dark */
[data-theme="dark"] .cli-counter       { background: var(--grey-200); color: var(--text); }
[data-theme="dark"] .cli-list-pane     { border-right-color: var(--border); }
[data-theme="dark"] .cli-search input,
[data-theme="dark"] .cli-newrow input  { background: var(--grey-100); color: var(--text); border-color: var(--border); }
[data-theme="dark"] .cli-search input:focus,
[data-theme="dark"] .cli-newrow input:focus { background: var(--grey-200); border-color: var(--lima); }
[data-theme="dark"] .cli-row:hover     { background: var(--grey-100); }
[data-theme="dark"] .cli-row.selected  { background: rgba(144,192,32,.14); border-left-color: var(--lima); }
[data-theme="dark"] .cli-row-name,
[data-theme="dark"] .cli-name-input    { color: var(--text); }
[data-theme="dark"] .cli-row-code,
[data-theme="dark"] .cli-code-chip,
[data-theme="dark"] .cli-count         { background: var(--grey-200); color: var(--text); }
[data-theme="dark"] .cli-row.selected .cli-row-code,
[data-theme="dark"] .cli-row.selected .cli-count { background: var(--grey-100); }
[data-theme="dark"] .proj-item,
[data-theme="dark"] .proj-item:last-child { border-bottom-color: var(--border); }
[data-theme="dark"] .proj-name,
[data-theme="dark"] .sub-name          { color: var(--text); }
[data-theme="dark"] .proj-name:hover,
[data-theme="dark"] .sub-name:hover,
[data-theme="dark"] .chev:hover        { background: var(--grey-100); }
[data-theme="dark"] .proj-name:focus,
[data-theme="dark"] .sub-name:focus    { background: var(--grey-200); }
[data-theme="dark"] .switch .track     { background: var(--grey-300); }
[data-theme="dark"] .sub-wrap          { border-left-color: var(--border); }
[data-theme="dark"] .cli-detail-toggles,
[data-theme="dark"] .cli-proj-hd + .cli-proj-list,
[data-theme="dark"] .proj-add          { border-color: var(--border); }

/* Tabla de usuarios (admin) */
[data-theme="dark"] .usertable th,
[data-theme="dark"] .usertable td      { border-color: var(--border); }

/* Modales base */
[data-theme="dark"] .modal-back        { background: rgba(0,0,0,.65); }
[data-theme="dark"] .modal-box         { background: var(--bg-card); border: 1px solid var(--border); }
[data-theme="dark"] .modal-hd h2       { color: var(--text); }
[data-theme="dark"] .modal-ft          { border-color: var(--border); }

/* Botones globales */
[data-theme="dark"] .btn               { background: var(--grey-100); color: var(--text); border-color: var(--border); }
[data-theme="dark"] .btn.primary       { background: var(--marino-2); color: #fff; border-color: transparent; }
[data-theme="dark"] .btn.lima          { background: var(--lima); color: #1a2000; }
[data-theme="dark"] .btn.ghost         { background: var(--grey-100); border-color: var(--border); }
[data-theme="dark"] .chk               { color: var(--text); }

/* Inputs globales */
[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="password"],
[data-theme="dark"] input[type="time"],
[data-theme="dark"] input[type="date"],
[data-theme="dark"] select,
[data-theme="dark"] textarea           { background: var(--grey-100); color: var(--text); border-color: var(--border); }
[data-theme="dark"] select option      { background: var(--bg-card); color: var(--text); }

/* Modal de perfil */
[data-theme="dark"] .pm-shell          { background: var(--bg-card); border: 1px solid var(--border); }
[data-theme="dark"] .pm-hero           { background: linear-gradient(135deg,#0d1830 0%,#1a2755 100%); }
[data-theme="dark"] .pm-tabs           { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .pm-tab            { color: var(--grey-500); }
[data-theme="dark"] .pm-tab:hover      { color: var(--text); }
[data-theme="dark"] .pm-tab.active     { color: var(--lima); border-bottom-color: var(--lima); }
[data-theme="dark"] .pm-dropzone       { background: var(--grey-100); border-color: var(--border); }
[data-theme="dark"] .pm-fields .field label { color: var(--grey-500); }
[data-theme="dark"] .pm-fields input,
[data-theme="dark"] .pm-fields select  { background: var(--grey-100); color: var(--text); border-color: var(--border); }
[data-theme="dark"] .pm-footer         { border-top-color: var(--border); }
[data-theme="dark"] .pref-title        { color: var(--text); }
[data-theme="dark"] .theme-opt         { background: var(--grey-100); color: var(--grey-500); border-color: var(--border); }
[data-theme="dark"] .theme-opt.active  { color: var(--lima); background: rgba(163,212,59,.12); border-color: var(--lima); }
[data-theme="dark"] .session-info      { background: var(--grey-100); }
[data-theme="dark"] .session-lbl       { color: var(--grey-500); }
[data-theme="dark"] .session-val       { color: var(--text); }
[data-theme="dark"] .session-row       { border-bottom-color: var(--border); }

/* Org chart v2 */
[data-theme="dark"] .org2-container    { background: var(--bg-soft); }
[data-theme="dark"] .org2-toolbar      { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .org2-zbtn         { background: var(--grey-100); border-color: var(--border); color: var(--text); }
[data-theme="dark"] .org2-zbtn:hover   { background: var(--grey-200); }
[data-theme="dark"] .org2-search-wrap  { background: var(--grey-100); border-color: var(--border); }
[data-theme="dark"] .org2-search-wrap input { color: var(--text); }
[data-theme="dark"] .org2-card         { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .org2-card:hover   { border-color: var(--grey-300); }
[data-theme="dark"] .org2-drawer       { background: var(--bg-card); border-left-color: var(--border); }
[data-theme="dark"] .od-hero           { background: linear-gradient(135deg,#0d1830 0%,#1a2755 100%); }
[data-theme="dark"] .od-section-title  { color: var(--grey-500); border-bottom-color: var(--border); }
[data-theme="dark"] .od-row-lbl        { color: var(--grey-500); }
[data-theme="dark"] .od-row-val        { color: var(--text); }
[data-theme="dark"] .od-row            { border-bottom-color: var(--border); }

/* ================================================================
   MODAL DE PERFIL — diseño premium tipo Linear/Notion
================================================================ */
.pm-shell {
  background: var(--bg-card);
  border-radius: 20px;
  width: 560px;
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: var(--shadow-md);
  animation: pmSlideIn .22s cubic-bezier(.34,1.36,.64,1);
}
@keyframes pmSlideIn { from { opacity:0; transform:scale(.94) translateY(12px); } to { opacity:1; transform:none; } }

/* Hero / cabecera con gradiente corporativo */
.pm-hero {
  background: linear-gradient(135deg, var(--marino) 0%, #16306f 60%, #1a4090 100%);
  padding: 28px 24px 20px;
  display: flex;
  align-items: center;
  gap: 18px;
  position: relative;
}
.pm-avatar-ring {
  width: 80px; height: 80px;
  border-radius: 50%;
  border: 3px solid rgba(255,255,255,.35);
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  overflow: hidden;
  background: rgba(255,255,255,.15);
  display: flex; align-items: center; justify-content: center;
  transition: border-color .2s;
}
.pm-avatar-ring:hover { border-color: rgba(255,255,255,.8); }
.pm-avatar-ring img { position:absolute;inset:0;width:100%;height:100%;object-fit:cover; }
.pm-avatar-ring span { color:#fff;font-size:28px;font-weight:700;z-index:1; }
.pm-avatar-hover {
  position:absolute;inset:0;background:rgba(0,0,0,.55);border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:#fff;font-size:18px;opacity:0;transition:opacity .18s;z-index:2;
}
.pm-avatar-ring:hover .pm-avatar-hover { opacity:1; }
.pm-hero-info { flex:1;min-width:0; }
.pm-hero-name { color:#fff;font-size:19px;font-weight:700;line-height:1.2; }
.pm-hero-email { color:rgba(255,255,255,.7);font-size:12.5px;margin-top:5px; }
.pm-x { position:absolute;top:14px;right:14px;background:rgba(255,255,255,.12);border:0;color:#fff;width:28px;height:28px;border-radius:8px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .15s; }
.pm-x:hover { background:rgba(255,255,255,.25); }

/* Tabs */
.pm-tabs { display:flex;padding:0 20px;border-bottom:1px solid var(--border);background:var(--bg-card); }
.pm-tab { background:none;border:0;padding:13px 14px;font:inherit;font-size:13.5px;font-weight:600;color:var(--grey-500);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s; }
.pm-tab:hover { color:var(--text); }
.pm-tab.active { color:var(--marino);border-bottom-color:var(--lima); }


/* Cuerpo scrollable */
.pm-body { flex:1;overflow-y:auto;padding:0; }
.pm-panel { display:none;padding:22px 24px 8px; }
.pm-panel.active { display:block; }
.pm-footer { display:flex;justify-content:flex-end;padding:12px 0 4px; }

/* Dropzone de foto */
.pm-dropzone {
  border:2px dashed var(--border);border-radius:14px;padding:20px;text-align:center;
  background:var(--bg-soft);margin-bottom:20px;transition:border-color .2s,background .2s;
}
.pm-dropzone.drag-over { border-color:var(--lima);background:var(--lima-soft); }
.pmd-icon { font-size:28px;margin-bottom:6px;opacity:.5; }
.pmd-title { font-weight:600;font-size:14px;margin-bottom:4px; }
.pmd-sub { color:var(--grey-500);font-size:12px;margin-bottom:12px; }
.pmd-canvas-wrap { display:flex;justify-content:center;margin-bottom:12px; }
.pmd-canvas-wrap canvas { border-radius:50%;border:3px solid var(--grey-200);display:block; }
.pmd-preview-btns { display:flex;align-items:center;justify-content:center;gap:12px; }
.danger-btn:hover { background:#fee2e2!important;color:#dc2626!important; }

/* Campos del perfil */
.pm-fields { display:grid;grid-template-columns:1fr 1fr;gap:12px 16px;margin-bottom:4px; }
.pm-fields .field { display:flex;flex-direction:column;gap:5px; }
.pm-fields label { font-size:12px;font-weight:600;color:var(--grey-500);text-transform:uppercase;letter-spacing:.04em; }
.pm-fields input, .pm-fields select { border:1.5px solid var(--border);border-radius:9px;padding:9px 12px;font:inherit;font-size:13.5px;background:var(--bg-soft);color:var(--text);transition:border-color .15s,box-shadow .15s; }
.pm-fields input:focus, .pm-fields select:focus { outline:none;border-color:var(--lima);box-shadow:0 0 0 3px rgba(144,192,32,.18);background:var(--bg-card); }

/* Bloques de preferencias */
.pref-block { margin-bottom:24px; }
.pref-title { font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--grey-500);margin-bottom:12px; }

/* Theme selector */
.theme-row { display:flex;gap:10px; }
.theme-opt {
  flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px;
  border:2px solid var(--border);border-radius:12px;background:var(--bg-soft);cursor:pointer;
  font:inherit;font-size:13px;font-weight:600;color:var(--text);transition:.15s;
}
.theme-opt:hover { border-color:var(--grey-300); }
.theme-opt.active { border-color:var(--lima);background:var(--lima-soft);color:var(--marino); }

.theme-icon { font-size:22px; }

/* Sesión info */
.session-info { background:var(--bg-soft);border-radius:12px;overflow:hidden; }
.session-row { display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-bottom:1px solid var(--border); }
.session-row:last-child { border-bottom:0; }
.session-lbl { font-size:12.5px;font-weight:600;color:var(--grey-500); }
.session-val { font-size:13px;color:var(--text); }

/* ================================================================
   ORGANIGRAMA PREMIUM v2
================================================================ */
.org2-container {
  display:flex;flex-direction:column;height:100%;
  background:var(--bg-soft);
  position:relative;overflow:hidden;
}
.org2-toolbar {
  display:flex;align-items:center;gap:12px;padding:12px 16px;
  background:var(--bg-card);border-bottom:1px solid var(--border);
  flex-shrink:0;z-index:10;
}
.org2-search-wrap { display:flex;align-items:center;flex:1;max-width:320px;gap:8px;background:var(--bg-soft);border:1.5px solid var(--border);border-radius:10px;padding:0 12px; }
.org2-search-wrap input { flex:1;border:0;background:none;padding:9px 0;font:inherit;font-size:13.5px;color:var(--text); }
.org2-search-wrap input:focus { outline:none; }
.org2-search-ic { color:var(--grey-500);font-size:14px; }
.org2-zoom-btns { display:flex;gap:4px;margin-left:auto; }
.org2-zbtn { width:32px;height:32px;border:1.5px solid var(--border);border-radius:8px;background:var(--bg-card);cursor:pointer;font-size:16px;font-weight:700;color:var(--text);display:flex;align-items:center;justify-content:center;transition:.15s; }
.org2-zbtn:hover { background:var(--grey-100);border-color:var(--grey-300); }

/* Viewport con overflow hidden + canvas transformable */
.org2-viewport {
  flex:1;overflow:hidden;position:relative;cursor:grab;
  user-select:none;-webkit-user-select:none;
}
.org2-viewport.dragging { cursor:grabbing; }
.org2-canvas {
  position:absolute;top:0;left:0;
  transform-origin:0 0;
  transition:none;
  padding:60px 80px 80px;
  display:flex;flex-direction:column;align-items:center;gap:0;
}
.org2-svg {
  position:absolute;top:0;left:0;
  pointer-events:none;z-index:0;
  overflow:visible;
}

/* Niveles del organigrama */
.org2-level { display:flex;gap:20px;justify-content:center;padding:28px 0;position:relative;z-index:1; }

/* Tarjeta premium de empleado */
.org2-card {
  width:190px;background:var(--bg-card);border-radius:14px;
  border:1.5px solid var(--border);
  box-shadow:0 1px 3px rgba(0,0,0,.06),0 4px 14px rgba(0,24,104,.07);
  padding:16px 14px 12px;
  display:flex;flex-direction:column;align-items:center;gap:0;
  cursor:pointer;transition:box-shadow .2s,border-color .2s,transform .18s;
  position:relative;overflow:hidden;
}
.org2-card:hover { box-shadow:0 4px 12px rgba(0,0,0,.1),0 12px 32px rgba(0,24,104,.12);transform:translateY(-2px);border-color:var(--grey-300); }
.org2-card.highlighted { border-color:var(--lima);box-shadow:0 0 0 3px rgba(144,192,32,.25); }
.org2-card.dimmed { opacity:.35;pointer-events:none; }

/* Accent bar por rol */
.org2-card::before { content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0; }
.org2-card[data-role="Admin"]::before   { background:var(--marino); }
.org2-card[data-role="Gerente"]::before { background:#ca8a04; }
.org2-card[data-role="Senior"]::before  { background:#2563eb; }
.org2-card[data-role="Junior"]::before  { background:#16a34a; }

/* Foto circular en la tarjeta */
.oc2-photo {
  width:56px;height:56px;border-radius:50%;
  margin-bottom:10px;position:relative;
  background:var(--grey-100);
  border:2.5px solid var(--border);
  overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.oc2-photo img { width:100%;height:100%;object-fit:cover;position:absolute;inset:0; }
.oc2-photo .oc2-init { font-size:20px;font-weight:700;color:var(--grey-500);z-index:1; }
.oc2-photo .oc2-dot {
  position:absolute;bottom:2px;right:2px;width:12px;height:12px;border-radius:50%;
  border:2px solid var(--bg-card);
}
.oc2-dot.Activo    { background:#22c55e; }
.oc2-dot.Remoto    { background:#3b82f6; }
.oc2-dot.Vacaciones{ background:#f59e0b; }
.oc2-dot.Baja      { background:#ef4444; }

.oc2-name     { font-size:13px;font-weight:700;color:var(--text);text-align:center;line-height:1.2;margin-bottom:2px; }
.oc2-role-lbl { font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--grey-500);text-align:center;margin-bottom:3px; }
.oc2-title    { font-size:11px;color:var(--grey-500);text-align:center;margin-bottom:5px;min-height:14px; }
.oc2-dept  { font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:20px;background:var(--grey-100);color:var(--grey-500);text-align:center; }

/* Drawer lateral de detalle */
.org2-drawer {
  position:absolute;top:0;right:0;bottom:0;width:300px;
  background:var(--bg-card);border-left:1px solid var(--border);
  box-shadow:-8px 0 32px rgba(0,0,0,.1);
  transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  z-index:20;overflow-y:auto;
}
.org2-drawer.open { transform:translateX(0); }
.od-close { position:absolute;top:12px;right:12px;width:28px;height:28px;background:var(--grey-100);border:0;border-radius:8px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--grey-500);transition:.15s; }
.od-close:hover { background:var(--grey-200);color:var(--text); }
.od-hero { background:linear-gradient(135deg,var(--marino),#16306f);padding:32px 20px 20px;display:flex;flex-direction:column;align-items:center;gap:10px; }

/* ===== WORKSPACE CONFIG ===== */
.ws-field-row { margin-bottom:4px; }
.ws-input-row { display:flex;gap:8px;align-items:center; }
.ws-input-row input { flex:1;min-width:0; }
.ws-status { font-size:12px;padding:6px 10px;border-radius:6px;margin:8px 0 4px; }
.ws-ok   { background:#f0fdf4;color:#166534;border:1px solid #bbf7d0; }
.ws-err  { background:#fef2f2;color:#991b1b;border:1px solid #fecaca; }
.ws-warn { background:#fffbeb;color:#92400e;border:1px solid #fde68a; }
.ws-global-root { font-family:monospace;font-size:12px;color:var(--grey-500);background:var(--grey-100);border-radius:4px;padding:4px 8px;margin-top:4px;word-break:break-all; }
.ws-hint-list { margin:8px 0 0 16px;padding:0;color:var(--grey-500);font-size:12.5px;line-height:1.7; }
.ws-hint-list li { margin-bottom:2px; }

/* Error state en picker de proyecto */
.pp-error { gap:8px; }
.pp-error code { display:block;font-size:11px;background:var(--grey-100);border-radius:4px;padding:2px 6px;margin:2px 0;word-break:break-all;color:var(--text); }

[data-theme="dark"] .ws-ok   { background:#052e16;color:#86efac;border-color:#166534; }
[data-theme="dark"] .ws-err  { background:#450a0a;color:#fca5a5;border-color:#991b1b; }
[data-theme="dark"] .ws-warn { background:#451a03;color:#fcd34d;border-color:#92400e; }
[data-theme="dark"] .ws-global-root { background:var(--grey-800);color:var(--grey-400); }
[data-theme="dark"] .pp-error code  { background:var(--grey-800); }
.od-photo { width:80px;height:80px;border-radius:50%;border:3px solid rgba(255,255,255,.35);background:rgba(255,255,255,.15);overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative; }
.od-photo img { position:absolute;inset:0;width:100%;height:100%;object-fit:cover; }
.od-photo span { color:#fff;font-size:28px;font-weight:700; }
.od-hero-name { color:#fff;font-size:17px;font-weight:700; }
.od-hero-role { color:rgba(255,255,255,.7);font-size:12px; }
.od-body { padding:16px; }
.od-section { margin-bottom:20px; }
.od-section-title { font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--grey-500);margin-bottom:10px; }
.od-row { display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px; }
.od-row:last-child { border-bottom:0; }
.od-row-lbl { width:90px;flex-shrink:0;color:var(--grey-500);font-size:12px; }
.od-row-val { flex:1;color:var(--text);font-weight:500; }

/* Vista Equipo como fullpage */
#equipo { padding:0;overflow:hidden; }
#equipo .org2-container { height:calc(100vh - 0px); }

/* ================================================================
   SELECTOR DE PROYECTO — exploración progresiva de carpetas
================================================================ */
/* Celda proyecto: input + botón explorar */
.proj-wrap { display:flex;align-items:center;gap:2px; }
.proj-wrap input { flex:1;min-width:0; }
.proj-pick-btn { flex-shrink:0;font-size:12px;padding:3px 5px; }

/* Modal picker */
.pp-modal { max-width:620px;width:94vw; }
.pp-breadcrumb {
  display:flex;align-items:center;flex-wrap:wrap;gap:2px 4px;
  padding:9px 12px;background:var(--bg-soft);border-radius:10px;
  margin-bottom:12px;font-size:13px;border:1px solid var(--border);
}
.pp-crumb { color:var(--marino);cursor:pointer;font-weight:600;padding:2px 5px;border-radius:5px;transition:.12s; }
.pp-crumb:hover { background:var(--grey-100); }
.pp-crumb.pp-crumb-active { color:var(--text);cursor:default; }
.pp-crumb.pp-crumb-active:hover { background:none; }
.pp-sep { color:var(--grey-300);font-size:11px;user-select:none; }
.pp-nav-row { display:flex;align-items:center;gap:10px;margin-bottom:14px; }
.pp-folder-list {
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:10px;max-height:320px;overflow-y:auto;padding:2px;
}
.pp-card {
  background:var(--bg-soft);border:1.5px solid var(--border);border-radius:12px;
  padding:14px 10px 12px;cursor:pointer;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  transition:border-color .15s,background .15s,transform .12s;
}
.pp-card:hover { border-color:var(--lima);background:var(--lima-soft);transform:translateY(-2px); }
.pp-card-icon { font-size:26px;line-height:1; }
.pp-card-name { font-size:12.5px;font-weight:700;color:var(--marino);word-break:break-word;line-height:1.3; }
.pp-card-sub  { font-size:11px;color:var(--grey-500); }
.pp-empty { text-align:center;padding:40px 20px;color:var(--grey-500);grid-column:1/-1; }
.pp-empty-icon { font-size:36px;display:block;margin-bottom:8px;opacity:.35; }
.pp-empty p { margin:4px 0; }

/* Dark mode picker */
[data-theme="dark"] .pp-breadcrumb { background:var(--grey-100);border-color:var(--border); }
[data-theme="dark"] .pp-card        { background:var(--grey-100);border-color:var(--border); }
[data-theme="dark"] .pp-card:hover  { background:rgba(163,212,59,.09);border-color:var(--lima); }
[data-theme="dark"] .pp-card-name   { color:var(--text); }
tr.entry {
    cursor: default;
}

    tr.entry:hover {
        background: #f8fafc;
    }
.week-total-pill {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid #e5e7eb;
    background: #f8fafc;
    color: #001868;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

    .week-total-pill span {
        color: #7a8294;
        font-weight: 600;
    }

    .week-total-pill b {
        font-size: 13px;
        font-weight: 800;
        color: #001868;
    }

[data-theme="dark"] .week-total-pill {
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.14);
    color: #fff;
}

    [data-theme="dark"] .week-total-pill span {
        color: rgba(255,255,255,.68);
    }

    [data-theme="dark"] .week-total-pill b {
        color: #fff;
    }