﻿:root{
  --bg:#0E0F10;
  --surface-1:#161718;
  --surface-2:#131415;
  --line:rgba(255,255,255,0.08);
  --line-soft:rgba(255,255,255,0.05);
  --t-clear:#E7E8E9;
  --t-mid:#9A9D9F;
  --t-faint:#646769;
  --pos:#6FB39A;
  --neg:#C98B84;
  --radius:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--t-clear);font-family:'Manrope',system-ui,sans-serif;font-feature-settings:"tnum" 1;-webkit-font-smoothing:antialiased}
body{padding-bottom:80px}
.num{font-variant-numeric:tabular-nums}
.label{text-transform:uppercase;font-size:11px;letter-spacing:0.10em;color:var(--t-mid);font-weight:600}
.meta{font-size:11px;color:var(--t-faint);letter-spacing:0.04em}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;transition:background .15s,color .15s,border-color .15s}

/* Top bar */
.topbar{position:sticky;top:0;z-index:50;background:rgba(14,15,16,0.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.topbar-inner{max-width:1080px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;gap:10px}
.topbar-row2{max-width:1080px;margin:0 auto;padding:0 24px 12px;display:flex;align-items:center;gap:12px}
.brand{display:flex;flex-direction:column;gap:2px}
.brand .t{font-size:15px;font-weight:700;letter-spacing:-0.01em}
.brand .s{font-size:11px;color:var(--t-faint);letter-spacing:0.06em;text-transform:uppercase}
.topbar-spacer{flex:1}

/* Segmented view switcher */
.seg{display:flex;gap:2px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:3px}
.seg button{font-size:12px;font-weight:600;letter-spacing:0.02em;padding:7px 14px;border-radius:8px;color:var(--t-mid)}
.seg button:hover{color:var(--t-clear)}
.seg button.active{background:var(--surface-1);color:var(--t-clear)}

.top-stat{display:flex;flex-direction:column;gap:2px;text-align:right}
.top-stat .v{font-size:18px;font-weight:700;letter-spacing:-0.01em}
.top-actions{display:flex;gap:8px}
.btn{font-size:12px;font-weight:600;letter-spacing:0.02em;padding:8px 14px;border-radius:10px;color:var(--t-mid);border:1px solid var(--line)}
.btn:hover{background:var(--surface-1);color:var(--t-clear)}
.btn-pos{color:var(--pos);border-color:rgba(111,179,154,0.3)}
.btn-pos:hover{background:rgba(111,179,154,0.08);color:var(--pos)}
.btn-sm{padding:6px 11px;font-size:11px}

.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.view{margin-top:26px}

/* ---------- Overview (project cards) ---------- */
.client-block{margin-bottom:14px}
.client-head{display:flex;align-items:baseline;gap:12px;padding:18px 4px 14px;border-bottom:1px solid var(--line)}
.client-head .name{font-size:13px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase}
.client-head .cnt{font-size:11px;color:var(--t-faint);letter-spacing:0.04em}
.pcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));column-gap:32px;row-gap:18px}
.pcard{padding:22px 10px;border-bottom:1px solid var(--line);cursor:pointer;display:flex;flex-direction:column;gap:12px}
.pcard:hover{background:var(--surface-2)}
.pcard .pc-ref{font-size:10px;color:var(--t-faint);letter-spacing:0.06em;text-transform:uppercase}
.pc-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px}
.pc-head .pc-name{flex:1;min-width:0;font-size:16px;font-weight:600;letter-spacing:-0.01em;line-height:1.25}
.pcard .pc-sub{font-size:12px;color:var(--t-faint);line-height:1.4}
.pc-prog{display:flex;align-items:center;gap:10px}
.bar{height:4px;border-radius:2px;background:var(--line);overflow:hidden;flex:1}
.bar > i{display:block;height:100%;background:var(--pos);border-radius:2px;transition:width .3s}
.pc-prog .pct{font-size:13px;color:var(--t-clear);font-weight:700;min-width:38px;text-align:right}
.pc-dur{flex-shrink:0;font-size:13px;color:var(--t-mid);font-weight:600;letter-spacing:0.06em;text-transform:uppercase;text-align:right;white-space:nowrap}

/* ---------- Project detail ---------- */
.backbar{display:flex;align-items:center;gap:12px;padding:4px 4px 0}
.back{font-size:12px;color:var(--t-mid);font-weight:600;letter-spacing:0.02em;padding:6px 0}
.back:hover{color:var(--t-clear)}
.panel{padding:14px 4px 0}
.p-title{font-size:26px;font-weight:700;letter-spacing:-0.02em;line-height:1.15}
.p-sub{font-size:14px;color:var(--t-mid);margin-top:6px;letter-spacing:-0.005em}
.p-metarow{display:flex;flex-wrap:wrap;gap:24px;margin-top:18px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.metacell{display:flex;flex-direction:column;gap:4px}
.metacell .v{font-size:16px;font-weight:600;letter-spacing:-0.01em}
.metacell .v.pos{color:var(--pos)}
.metacell input.startin{background:none;border:none;color:var(--t-clear);font-family:inherit;font-size:15px;font-weight:600;padding:0;cursor:pointer;width:130px}
.metacell input.startin:focus{outline:none}
.metacell input.startin::placeholder{color:var(--t-faint)}
.metacell input.startin::-webkit-calendar-picker-indicator{filter:invert(.6)}

.section{padding:24px 0 4px}
.section-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:10px}
.section-h .label{font-size:11px}

/* Roadmap */
.phase{border-bottom:1px solid var(--line)}
.phase-head{display:flex;align-items:center;gap:14px;padding:16px 6px;cursor:pointer}
.phase-head:hover{background:var(--surface-2)}
.phase-dot{width:9px;height:9px;border-radius:50%;background:var(--t-faint);flex-shrink:0}
.phase-dot.done{background:var(--pos)}
.phase-dot.active{background:var(--pos);box-shadow:0 0 0 3px rgba(111,179,154,0.18)}
.phase-info{flex:1;min-width:0}
.phase-name{font-size:14px;font-weight:600;letter-spacing:-0.005em}
.phase-focus{font-size:12px;color:var(--t-faint);margin-top:3px;line-height:1.45}
.phase-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.phase-count{font-size:12px;color:var(--t-mid);font-weight:600}
.phasein{background:none;border:1px solid transparent;color:var(--t-clear);font-family:inherit;font-size:14px;font-weight:600;letter-spacing:-0.005em;padding:3px 6px;margin-left:-6px;border-radius:6px;width:100%;max-width:440px}
.phasein:hover{background:var(--surface-1)}
.phasein:focus{outline:none;background:var(--surface-1);border-color:var(--line)}
.delphase{color:var(--t-faint);font-size:16px;line-height:1;padding:2px 8px;border-radius:6px;opacity:0}
.phase-head:hover .delphase{opacity:1}
.delphase:hover{color:var(--neg);background:rgba(201,139,132,0.08)}
.chev{color:var(--t-faint);font-size:12px;transition:transform .15s}
.phase.open .chev{transform:rotate(90deg)}
.tasks{display:none;padding:2px 6px 14px 33px}
.phase.open .tasks{display:block}
.milestone{font-size:11px;color:var(--t-faint);letter-spacing:0.03em;padding:6px 6px 12px 33px;display:flex;gap:8px;align-items:flex-start}
.milestone b{color:var(--t-mid);font-weight:600}

/* Task row (detail) */
.task{display:flex;align-items:center;gap:14px;padding:9px 0;border-bottom:1px solid var(--line-soft)}
.task:last-child{border-bottom:none}
.task .tt{flex:1;font-size:13px;letter-spacing:-0.005em;line-height:1.4}
.task.s-hecho .tt{color:var(--t-faint);text-decoration:line-through}
.ttin{flex:1;min-width:0;background:none;border:1px solid transparent;color:var(--t-clear);font-family:inherit;font-size:13px;letter-spacing:-0.005em;line-height:1.4;padding:4px 6px;border-radius:6px}
.ttin:hover{background:var(--surface-2)}
.ttin:focus{outline:none;background:var(--surface-2);border-color:var(--line)}
.s-hecho .ttin{color:var(--t-faint);text-decoration:line-through}
.fbody .ttin{display:block;width:100%;padding:2px 4px;margin-left:-4px}
.duein{background:none;border:none;color:var(--t-faint);font-family:inherit;font-size:11px;width:auto;text-align:right}
.duein:hover,.duein:focus{color:var(--t-mid);outline:none}
.duein::-webkit-calendar-picker-indicator{filter:invert(.45);opacity:.5}
.hrcell{display:flex;align-items:center;justify-content:flex-end;gap:1px;flex-shrink:0;width:50px}
.hrin{background:none;border:none;color:var(--t-mid);font-family:inherit;font-size:11px;width:34px;text-align:right;font-variant-numeric:tabular-nums;-moz-appearance:textfield}
.hrin::-webkit-outer-spin-button,.hrin::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.hrin:focus{outline:none;color:var(--t-clear)}
.hrin::placeholder{color:var(--t-faint)}
.hru{font-size:10px;color:var(--t-faint)}
.phase-hrs{font-size:12px;color:var(--t-faint);font-variant-numeric:tabular-nums}
.ftag .fhrs{color:var(--t-faint)}
.stbtn{font-size:10px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:4px 10px;border-radius:20px;border:1px solid var(--line);color:var(--t-mid);white-space:nowrap;min-width:104px;text-align:center;flex-shrink:0}
.stbtn:hover{border-color:var(--t-mid)}
.stbtn.s-pendiente{color:var(--t-faint)}
.stbtn.s-en-proceso{color:var(--t-clear);border-color:rgba(231,232,233,0.25)}
.stbtn.s-hecho{color:var(--pos);border-color:rgba(111,179,154,0.3);background:rgba(111,179,154,0.06)}
.stbtn.s-bloqueada{color:var(--neg);border-color:rgba(201,139,132,0.3);background:rgba(201,139,132,0.06)}
.delx{color:var(--t-faint);font-size:15px;line-height:1;padding:2px 6px;border-radius:6px;opacity:0;flex-shrink:0}
.task:hover .delx,.ftask:hover .delx{opacity:1}
.delx:hover{color:var(--neg);background:rgba(201,139,132,0.08)}
.addtask{display:flex;gap:8px;margin-top:10px}
.addtask input{flex:1;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;color:var(--t-clear);font-family:inherit;font-size:13px;padding:8px 12px}
.addtask input::placeholder{color:var(--t-faint)}
.addtask input:focus{outline:none;border-color:rgba(255,255,255,0.18)}
.miniadd{font-size:11px;color:var(--t-mid);padding:8px 12px;border:1px solid var(--line);border-radius:8px;font-weight:600}
.miniadd:hover{background:var(--surface-1);color:var(--t-clear)}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:0}
.kpi{padding:16px 6px;border-bottom:1px solid var(--line)}
.kpi .k-name{font-size:12px;color:var(--t-mid);font-weight:600;letter-spacing:0.01em}
.kpi .k-def{font-size:11px;color:var(--t-faint);margin-top:4px;line-height:1.4}
.kpi .k-foot{display:flex;justify-content:space-between;margin-top:10px}
.kpi .k-meta{font-size:18px;font-weight:700;letter-spacing:-0.01em}
.kpi .k-freq{font-size:10px;color:var(--t-faint);text-transform:uppercase;letter-spacing:0.06em;align-self:flex-end}

/* ---------- Day / Week flow ---------- */
.dwnav{display:flex;align-items:center;justify-content:space-between;padding:4px 4px 18px;border-bottom:1px solid var(--line)}
.dwnav .dw-title{font-size:22px;font-weight:700;letter-spacing:-0.02em}
.dwnav .dw-sub{font-size:12px;color:var(--t-faint);margin-top:3px;letter-spacing:0.02em}
.dwnav .nav-btns{display:flex;gap:6px;align-items:center}
.navarrow{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);color:var(--t-mid);font-size:14px;display:flex;align-items:center;justify-content:center}
.navarrow:hover{background:var(--surface-1);color:var(--t-clear)}

.daygroup{border-bottom:1px solid var(--line)}
.daygroup-h{display:flex;align-items:baseline;gap:12px;padding:16px 6px 10px}
.daygroup-h .dg-day{font-size:13px;font-weight:700;letter-spacing:0.03em;text-transform:uppercase}
.daygroup-h .dg-day.today{color:var(--pos)}
.daygroup-h .dg-date{font-size:11px;color:var(--t-faint);letter-spacing:0.04em}
.daygroup-h .dg-cnt{font-size:11px;color:var(--t-faint);margin-left:auto}
.daygroup.over .dg-day{color:var(--neg)}

.ftask{display:flex;align-items:center;gap:14px;padding:11px 6px;border-top:1px solid var(--line-soft)}
.ftask:hover{background:var(--surface-2)}
.ftask .fdot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--t-faint)}
.ftask .fdot.s-en-proceso{background:var(--t-clear)}
.ftask .fdot.s-hecho{background:var(--pos)}
.ftask .fdot.s-bloqueada{background:var(--neg)}
.ftask .fbody{flex:1;min-width:0}
.ftask .ftt{font-size:13px;letter-spacing:-0.005em;line-height:1.35}
.ftask.s-hecho .ftt{color:var(--t-faint);text-decoration:line-through}
.ftask .ftag{font-size:11px;color:var(--t-mid);margin-top:3px;letter-spacing:0.01em;cursor:pointer}
.ftask .ftag:hover{color:var(--t-clear)}
.ftask .ftag b{color:var(--t-faint);font-weight:600}
.empty{padding:54px 6px;text-align:center;color:var(--t-faint);font-size:13px;line-height:1.6}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);z-index:100;display:none;align-items:center;justify-content:center;padding:24px}
.modal-bg.show{display:flex}
.modal{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius);width:100%;max-width:420px;padding:24px}
.modal h3{font-size:15px;font-weight:700;letter-spacing:-0.01em;margin-bottom:18px}
.field{margin-bottom:14px}
.field label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--t-mid);font-weight:600;margin-bottom:6px}
.field input,.field select{width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;color:var(--t-clear);font-family:inherit;font-size:13px;padding:9px 12px}
.field input:focus,.field select:focus{outline:none;border-color:rgba(255,255,255,0.18)}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}

@media(max-width:680px){
  .topbar-inner{flex-wrap:wrap;gap:12px;padding:12px 16px}
  .wrap{padding:0 16px}
  .top-stat{display:none}
  .p-title{font-size:22px}
  .duein{font-size:11px}
}

/* flatpickr — ajuste a la paleta del proyecto */
.flatpickr-calendar{background:var(--surface-1);border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 36px rgba(0,0,0,.55);font-family:'Manrope',sans-serif}
.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowTop:after{border-bottom-color:var(--surface-1)}
.flatpickr-calendar.arrowBottom:before,.flatpickr-calendar.arrowBottom:after{border-top-color:var(--surface-1)}
.flatpickr-months,.flatpickr-weekdays,.flatpickr-weekdaycontainer{background:transparent}
.flatpickr-month,.flatpickr-current-month,.flatpickr-current-month input.cur-year,.flatpickr-monthDropdown-months{color:var(--t-clear);fill:var(--t-clear)}
.flatpickr-monthDropdown-months{background:var(--surface-1)}
.flatpickr-weekday{color:var(--t-faint);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.flatpickr-day{color:var(--t-mid);border-radius:8px;font-weight:500}
.flatpickr-day:hover,.flatpickr-day:focus{background:var(--surface-2);border-color:transparent;color:var(--t-clear)}
.flatpickr-day.today{border-color:var(--t-faint)}
.flatpickr-day.today:hover{background:var(--surface-2);color:var(--t-clear)}
.flatpickr-day.selected,.flatpickr-day.selected:hover,.flatpickr-day.selected:focus{background:var(--pos);border-color:var(--pos);color:#0E0F10;font-weight:700}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{color:var(--t-faint);opacity:.45}
.flatpickr-prev-month svg,.flatpickr-next-month svg{fill:var(--t-mid)}
.flatpickr-prev-month:hover svg,.flatpickr-next-month:hover svg{fill:var(--pos)}
.numInputWrapper:hover{background:var(--surface-2)}
.numInputWrapper span.arrowUp:after{border-bottom-color:var(--t-mid)}
.numInputWrapper span.arrowDown:after{border-top-color:var(--t-mid)}

/* Nube / login */
.cloudchip{font-size:11px;color:var(--t-faint);letter-spacing:0.02em;display:flex;align-items:center;gap:6px;padding:0 4px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cloudchip .dot{width:7px;height:7px;border-radius:50%;background:var(--t-faint);flex-shrink:0}
.cloudchip.ok .dot{background:var(--pos)}
.cloudchip.warn .dot{background:var(--neg)}
.cloudchip.sync .dot{background:var(--t-mid)}
.login-bg{position:fixed;inset:0;background:var(--bg);z-index:200;display:none;align-items:center;justify-content:center;padding:24px}
.login-bg.show{display:flex}
.login-card{width:100%;max-width:360px;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.login-title{font-size:18px;font-weight:700;letter-spacing:-0.01em}
.login-sub{font-size:12px;color:var(--t-faint);margin:6px 0 20px;line-height:1.5}
.login-err{font-size:12px;color:var(--neg);min-height:16px;margin-bottom:10px;line-height:1.4}
.login-foot{margin-top:14px;text-align:center}
.linkbtn{font-size:12px;color:var(--t-mid);text-decoration:underline;text-underline-offset:2px}
.linkbtn:hover{color:var(--t-clear)}

/* Selector de tablero */
.board-select{font-family:inherit;font-size:12px;font-weight:600;color:var(--t-clear);background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:7px 10px;cursor:pointer;max-width:200px;margin-left:auto}
.board-select:focus{outline:none;border-color:rgba(255,255,255,0.18)}
.board-select option{background:var(--surface-1);color:var(--t-clear)}

/* Banner solo lectura + bloqueo de edición */
.ro-banner{margin-top:18px;padding:10px 16px;border:1px solid rgba(201,139,132,0.3);background:rgba(201,139,132,0.07);border-radius:10px;display:flex;align-items:center;gap:12px;font-size:12px;color:var(--t-mid)}
.ro-banner .linkbtn{margin-left:auto;color:var(--neg)}
body.readonly .ttin,body.readonly .hrin,body.readonly .duein,body.readonly .startin,body.readonly .phasein,body.readonly .stbtn,body.readonly .fdot,body.readonly .ftag{pointer-events:none}
body.readonly .delx,body.readonly .delphase,body.readonly .addtask,body.readonly #btn-add-phase,body.readonly #btn-add-client,body.readonly #btn-add-project,body.readonly #btn-edit-project,body.readonly #btn-del-project{display:none !important}
