/* ═══════════════════════════════════════════════════════════
   DESIGN SYSTEM — vocabulario reutilizable (clases ds-*)
   Usar estas clases en vez de estilos inline para mantener
   consistencia. Definidas sobre los tokens de tokens.css.
   ═══════════════════════════════════════════════════════════ */

/* Controles de formulario (input / select / textarea) */
.ds-input,.ds-select,.ds-textarea,
.login-field input,.login-field select{
  width:100%;border:1.5px solid var(--border);border-radius:10px;padding:10px 14px;
  font-family:"DM Sans",sans-serif;font-size:14px;color:var(--ink);
  outline:none;background:var(--surface);transition:border-color .2s;
}
.ds-input:focus,.ds-select:focus,.ds-textarea:focus,
.login-field input:focus,.login-field select:focus{border-color:var(--brand);background:#fff;}
.ds-select,.login-field select{
  appearance:none;cursor:pointer;padding-right:34px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237a7771' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}

/* Badge / pill */
.ds-badge{display:inline-block;padding:4px 10px;font-size:11px;font-weight:600;border-radius:999px;background:var(--surface);color:var(--muted);}

/* Título de tarjeta */
.ds-card-title{font-family:"Inter",sans-serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px;}

/* Utilidades de texto */
.ds-muted{color:var(--muted);}
.ds-text-sm{font-size:12px;}
.ds-text-xs{font-size:11px;}

/* Utilidades de layout */
.ds-row{display:flex;align-items:center;}
.ds-noshrink{flex-shrink:0;}
.ds-col-full{grid-column:1/-1;}

/* SECTION TITLE */
.section-title{font-family:"Inter",sans-serif;font-size:14px;font-weight:700;margin:20px 0 12px;display:flex;align-items:center;gap:8px;color:var(--ink);}
.section-title::after{content:"";flex:1;height:1px;background:var(--border);}
.section-count{font-size:11px;font-weight:400;color:var(--muted);}

/* DOC GRID */
.doc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:8px;}
.doc-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;text-decoration:none;display:flex;flex-direction:column;color:inherit;height:170px;overflow:hidden;box-sizing:border-box;}
.doc-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08);border-color:#bfbab3;}
.doc-card-icon{font-size:18px;margin-bottom:5px;display:block;flex-shrink:0;line-height:1;}
.doc-card-title{font-family:"Inter",sans-serif;font-size:11.5px;font-weight:700;margin-bottom:3px;color:var(--ink);line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex-shrink:0;word-break:break-word;}
.doc-card-meta{font-size:10px;color:var(--muted);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;display:none;}
.doc-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:7px;border-top:1px solid var(--border);margin-top:auto;flex-shrink:0;}
.doc-tag{font-size:9px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;}
.tag-Planillas{background:#efecff;color:var(--accent2);}
.tag-Políticas{background:#fff0ed;color:var(--accent);}
.tag-Procedimientos{background:#f0f0f0;color:#555;}
.tag-Capacitación{background:#e8f8f0;color:#1a7a4a;}
.tag-Manual{background:#fffbec;color:var(--gold);}
.open-btn{font-size:11px;color:var(--accent2);font-weight:500;}

/* TODOS LIST */
.todos-list{display:flex;flex-direction:column;gap:6px;margin-bottom:24px;}
.todos-item{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:13px 16px;transition:transform .15s,border-color .15s,box-shadow .15s;text-decoration:none;color:inherit;}
.todos-item:hover{transform:translateX(4px);border-color:#bfbab3;box-shadow:0 4px 14px rgba(0,0,0,.06);}
.todos-icon{font-size:20px;flex-shrink:0;width:28px;text-align:center;}
.todos-info{flex:1;min-width:0;}
.todos-title{font-family:"Inter",sans-serif;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.todos-meta{font-size:11px;color:var(--muted);}
.todos-arrow{font-size:13px;color:var(--border);flex-shrink:0;transition:color .15s;}
.todos-item:hover .todos-arrow{color:var(--ink);}

/* SEARCH */
.search-results{display:none;}
.search-results.active{display:block;}

/* EMPTY */
.empty-state{text-align:center;padding:50px 20px;color:var(--muted);grid-column:1/-1;}
.empty-state .ei{font-size:40px;margin-bottom:12px;}
.empty-state .et{font-family:"Inter",sans-serif;font-size:16px;font-weight:700;color:var(--ink);margin-bottom:6px;}

/* MOBILE NAV — Material 3 pill */
.mob-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--border);z-index:150;padding:4px 4px 0;padding-bottom:calc(6px + env(safe-area-inset-bottom));padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);}
.mob-nav-inner{display:flex;align-items:center;}
.mob-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;padding:2px 4px;color:var(--muted);font-size:9px;font-family:"DM Sans",sans-serif;text-align:center;transition:color .2s;user-select:none;position:relative;}
.mob-nav-item.active{color:var(--accent2);}
.mob-nav-item .mn-icon{display:flex;align-items:center;justify-content:center;width:44px;height:26px;border-radius:50px;transition:color .2s;color:var(--muted);}
.mob-nav-item.active .mn-icon{color:var(--accent2);}
.mob-nav-item:hover .mn-icon{color:var(--ink);}
.mob-nav-item .mn-lbl{font-size:10px;line-height:1;font-weight:500;letter-spacing:.2px;transition:color .2s;color:var(--muted);}
.mob-nav-item.active .mn-lbl{color:var(--accent2);font-weight:700;}
.mob-nav-item:hover .mn-lbl{color:var(--ink);}
/* ── MÁS submenú ── */
.mob-more-panel{display:none;position:fixed;bottom:calc(60px + env(safe-area-inset-bottom));left:0;right:0;background:var(--card);border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(0,0,0,.12);z-index:149;padding:12px 8px;padding-bottom:8px;max-height:calc(100dvh - 80px - env(safe-area-inset-bottom));overflow-y:auto;}
.mob-more-panel.open{display:block;}
.mob-more-section-lbl{font-family:'Inter',sans-serif;font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);padding:4px 12px 6px;display:block;}
.mob-more-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;cursor:pointer;font-size:13px;color:var(--ink);font-family:'DM Sans',sans-serif;transition:background .15s;}
.mob-more-item:hover,.mob-more-item:active{background:var(--surface);}
.mob-more-item .mmi-icon{width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.mob-more-sub{padding-left:20px;}
.mob-more-item.danger{color:var(--accent);}
.mob-more-version{font-size:10px;color:var(--muted);text-align:center;padding:8px 0 4px;}
.mob-more-overlay{display:none;position:fixed;inset:0;z-index:148;}
.mob-more-overlay.open{display:block;}
@media screen and (min-width:861px){
  .mob-nav,.mob-more-panel,.mob-more-overlay{display:none!important;}
}


/* DASHBOARD METRICS */
.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(195px,1fr));gap:14px;margin-bottom:24px;}
.dash-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px 22px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s,border-color .18s;overflow:hidden;}
.dash-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.dash-card-head .dash-card-label{flex:1;min-width:0;overflow-wrap:break-word;}
.dash-card-ic{flex-shrink:0;width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:var(--brand-soft);color:var(--brand-deep);}
.dash-card.accent .dash-card-ic,.dash-card.accent2 .dash-card-ic{background:rgba(255,255,255,.2);color:#fff;}
.dash-card.clickable{cursor:pointer;}
.dash-card.clickable:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent;}
.dash-card.clickable:active{transform:translateY(-1px);}
.dash-card.accent.clickable:hover{box-shadow:0 16px 38px rgba(155,59,191,.4);}
.dash-card.accent2.clickable:hover{box-shadow:0 14px 34px rgba(108,92,255,.32);}
.topbar-notif-badge{position:absolute;top:3px;right:3px;min-width:16px;height:16px;border-radius:8px;background:var(--accent);color:#fff;font-family:'Inter',sans-serif;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1.5px solid #fff;line-height:1;}
.dash-card-label{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.8px;text-transform:uppercase;}
.dash-card-value{font-family:'Inter',sans-serif;font-size:28px;font-weight:800;color:var(--ink);line-height:1;}
.dash-card-sub{font-size:11px;color:var(--muted);}
.dash-card.accent{background:var(--grad);border-color:transparent;box-shadow:0 10px 26px rgba(155,59,191,.28);}
.dash-card.accent .dash-card-label,.dash-card.accent .dash-card-value,.dash-card.accent .dash-card-sub{color:#fff;}
.dash-card.accent .dash-card-label{color:rgba(255,255,255,.85);}
.dash-card.accent2{background:var(--accent2);border-color:transparent;box-shadow:0 10px 26px rgba(108,92,255,.28);}
.dash-card.accent2 .dash-card-label,.dash-card.accent2 .dash-card-value,.dash-card.accent2 .dash-card-sub{color:#fff;}
.dash-chart-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px;}
.dash-chart-box{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:22px 24px;box-shadow:var(--shadow-sm);}
.dash-chart-title{font-family:'Inter',sans-serif;font-size:13px;font-weight:700;margin-bottom:16px;color:var(--ink);}
.dash-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.dash-bar-label{font-size:11px;color:var(--muted);width:90px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dash-bar-track{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden;}
.dash-bar-fill{height:100%;border-radius:4px;background:var(--accent2);transition:width .5s ease;}
.dash-bar-val{font-size:11px;font-weight:600;color:var(--ink);width:24px;text-align:right;flex-shrink:0;}
/* CONTACT CARDS */
.contact-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:24px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column;gap:8px;}
.contact-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08);border-color:#bfbab3;}
.contact-card-icon{font-size:28px;}
.contact-card-title{font-family:"Inter",sans-serif;font-size:15px;font-weight:700;color:var(--ink);}
.contact-card-desc{font-size:13px;color:var(--muted);line-height:1.5;}
.contact-card-arrow{font-size:13px;color:var(--accent2);font-weight:500;margin-top:4px;}


/* FILTER BAR */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;}
.filter-btn{padding:6px 16px;border-radius:20px;border:1.5px solid var(--border);background:var(--card);color:var(--muted);font-family:"DM Sans",sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;}
.filter-btn:hover{border-color:var(--ink);color:var(--ink);}
.filter-btn.active{background:var(--ink);color:#fff;border-color:var(--ink);}

/* CONTROL DE CAMBIOS */
.doc-card{display:flex;flex-direction:column;}
.rev-bar{display:flex;align-items:center;gap:5px;margin:4px 0 6px;padding:4px 8px;background:var(--surface);border-radius:6px;border:1px solid var(--border);overflow:hidden;flex-shrink:0;min-width:0;}
.rev-badge{font-size:9px;font-weight:700;background:var(--ink);color:#fff;padding:2px 6px;border-radius:8px;font-family:"Inter",sans-serif;flex-shrink:0;white-space:nowrap;}
.rev-fecha{font-size:9px;color:var(--muted);flex-shrink:0;white-space:nowrap;}
.rev-sep{font-size:10px;color:var(--border);flex-shrink:0;}
.rev-detalle{font-size:9px;color:var(--muted);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;}




/* DOC VIEWER PAGE */
#page-visor{display:none;height:calc(100dvh - 54px - env(safe-area-inset-top));flex-direction:column;padding:0!important;overflow:hidden;}
#page-visor.active{display:flex!important;}
.visor-handle{display:none;}
.visor-header{padding:12px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0;background:#fff;}
.visor-back{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);cursor:pointer;padding:6px 10px;border-radius:8px;transition:background .15s,color .15s;flex-shrink:0;}
.visor-back:hover{background:var(--surface);color:var(--ink);}
.visor-title{font-family:'Inter',sans-serif;font-size:13px;font-weight:700;color:var(--ink);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.visor-actions{display:flex;gap:6px;flex-shrink:0;}
.visor-body{flex:1;overflow:auto;position:relative;-webkit-overflow-scrolling:touch;}
.visor-footer{padding:10px 16px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:7px;flex-shrink:0;align-items:center;background:#fff;}
/* Desktop: sin padding en main cuando visor activo */
@media(min-width:861px){
  body.visor-active .main{padding:0!important;}
  body.visor-active #page-visor{height:calc(100dvh - 54px - env(safe-area-inset-top));}
}
/* Mobile: bottom sheet */
@media(max-width:860px){
  #page-visor{
    position:fixed!important;inset:0;height:100dvh!important;
    z-index:200;border-radius:14px 14px 0 0;background:#fff;
    box-shadow:0 -6px 40px rgba(0,0,0,.22);
    transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);
    display:flex!important;pointer-events:none;
  }
  #page-visor.active{transform:translateY(0);pointer-events:auto;}
  .visor-handle{display:flex;justify-content:center;padding:10px 0 2px;flex-shrink:0;cursor:grab;touch-action:none;}
  .visor-handle::after{content:'';width:40px;height:4px;border-radius:2px;background:#d0d0d5;}
  .visor-back{display:none;}
  .visor-header{padding:8px 16px 8px;}
  .visor-title{font-size:14px;}
  .visor-actions button,.visor-actions a{padding:5px 10px!important;font-size:11px!important;}
}

#splashScreen{position:fixed;top:0;left:0;right:0;bottom:0;height:100%;min-height:100vh;min-height:100dvh;width:100%;background:#0d0d0f;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:99999;transition:opacity .5s ease, visibility .5s ease;padding-bottom:env(safe-area-inset-bottom);box-sizing:border-box;}
#splashScreen.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.splash-logo-circle{width:auto;height:auto;background:transparent;display:flex;align-items:center;justify-content:center;padding:0 24px;}
.splash-logo-circle .endos-logo{width:min(340px,76vw);height:auto;}
@keyframes splashIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.splash-logo-circle{animation:splashIn .7s ease both;}

/* ── RESPONSIVE MOBILE ─────────────────────── */
@media screen and (max-width:860px){
  .sidebar{display:none;}
  .main{padding:52px 12px calc(90px + env(safe-area-inset-bottom)) !important;width:100% !important;max-width:100% !important;box-sizing:border-box !important;overflow-x:hidden !important;}
  .layout{width:100% !important;max-width:100% !important;overflow-x:hidden !important;}
  .dash-grid{grid-template-columns:1fr 1fr !important;gap:10px !important;}
  .dash-card{padding:16px !important;}
  .dash-card-label{font-size:10px !important;letter-spacing:.3px !important;}
  .dash-card-ic{width:32px !important;height:32px !important;}
  .dash-card-ic svg{width:16px !important;height:16px !important;}
  .dash-card-value{font-size:24px !important;}
  .dash-chart-row{grid-template-columns:1fr !important;}
  .doc-grid{grid-template-columns:1fr !important;width:100% !important;max-width:100% !important;overflow-x:hidden !important;}
  .doc-card{width:100% !important;max-width:100% !important;box-sizing:border-box !important;height:auto !important;min-height:130px;overflow:hidden !important;}
  .doc-card-title{white-space:normal;word-break:break-word;}
  .doc-card-meta{display:none !important;}
  .welcome-banner{flex-direction:column !important;align-items:flex-start !important;gap:0 !important;padding:16px !important;max-width:100% !important;overflow:hidden !important;box-sizing:border-box !important;margin-bottom:16px !important;}
  .welcome-banner h2{font-size:16px !important;}
  .welcome-icon{display:none !important;}
  .topbar{padding-left:10px !important;padding-right:10px !important;padding-top:env(safe-area-inset-top) !important;height:calc(54px + env(safe-area-inset-top)) !important;gap:8px !important;overflow:hidden !important;}
  .topbar-search{max-width:none !important;flex:1 !important;}
  .topbar-user span{display:none !important;}
  #topName{display:none !important;}
  .logout-btn{display:none !important;}
  .topbar-divider{display:none !important;}
  .page-title{font-size:20px !important;}
  .login-box{padding:24px 16px !important;border-radius:16px !important;margin:10px !important;width:calc(100% - 20px) !important;max-width:calc(100% - 20px) !important;box-sizing:border-box !important;}
  .mob-nav{display:block !important;}
  .todos-title{white-space:normal !important;}
  .section-title{max-width:100% !important;overflow:hidden !important;}
  .todos-list{max-width:100% !important;overflow:hidden !important;}
  .todos-item{max-width:100% !important;box-sizing:border-box !important;overflow:hidden !important;}
  .filter-bar{flex-wrap:wrap !important;}
  #contactCards{grid-template-columns:1fr !important;}
  .page{overflow-x:hidden !important;max-width:100% !important;}
  #welcomeContent{overflow-x:hidden !important;max-width:100% !important;}
}


/* ════════════════════════════════════════════════════
   DASHBOARD EDITABLE + KPI BUILDER (dashboard.js)
   ════════════════════════════════════════════════════ */
.dash-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px;}
.dash-head-title{font-family:'Inter',sans-serif;font-size:18px;font-weight:700;color:var(--ink);}
.dash-edit-toggle{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:9px;background:#fff;border:1px solid var(--border);font-size:12.5px;font-weight:600;cursor:pointer;color:var(--ink);font-family:inherit;}
.dash-edit-toggle:hover{border-color:var(--accent2);color:var(--accent2);}
.dash-edit-toggle.active{background:var(--accent2);color:#fff;border-color:var(--accent2);}

.dash-edit-banner{background:linear-gradient(110deg,#efecff,#fceef0);border:1px solid #d6d2ff;border-radius:12px;padding:10px 14px;font-size:12.5px;margin-bottom:14px;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.dash-edit-banner b{font-weight:700;}
.dash-edit-banner .actions{display:flex;gap:6px;}
.dash-edit-banner button{padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;border:1px solid transparent;}
.dash-edit-banner .save{background:var(--ink);color:#fff;}
.dash-edit-banner .cancel{background:#fff;color:var(--ink);border-color:var(--border);}

.dash-card-hide{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;border:none;font-size:13px;cursor:pointer;display:none;align-items:center;justify-content:center;line-height:1;z-index:2;font-family:inherit;}
.dash-editing .dash-card-hide{display:flex;}
.dash-editing .dash-card{cursor:grab;outline:2px dashed transparent;transition:outline-color .15s;}
.dash-editing .dash-card:hover{outline-color:var(--accent2);transform:none;box-shadow:var(--shadow-sm);}
.dash-editing .dash-card::before{content:"⋮⋮";position:absolute;top:8px;left:10px;font-size:14px;color:var(--muted);letter-spacing:-2px;font-weight:700;z-index:2;}
.dash-editing .dash-card.accent::before,.dash-editing .dash-card.accent2::before{color:rgba(255,255,255,.85);}

.dash-add-tile{display:none;border:2px dashed var(--border);border-radius:16px;padding:20px;align-items:center;justify-content:center;flex-direction:column;gap:6px;color:var(--muted);font-size:12.5px;font-weight:600;cursor:pointer;background:transparent;min-height:120px;font-family:inherit;}
.dash-add-tile:hover{border-color:var(--accent2);color:var(--accent2);}
.dash-add-tile .plus{font-size:24px;line-height:1;}
.dash-editing .dash-add-tile{display:flex;}

.dash-custom-kpi{background:linear-gradient(135deg,#fff,#fceef0);border-color:#f0d8ec;}
.dash-kpi-badge{position:absolute;top:8px;right:34px;font-size:9.5px;font-weight:700;color:var(--accent2);background:#fff;padding:2px 7px;border-radius:99px;border:1px solid #e4dcff;letter-spacing:.5px;}
.dash-editing .dash-custom-kpi .dash-kpi-badge{display:none;}

/* Modal genérico (dashboard) */
.dash-modal{display:none;position:fixed;inset:0;background:rgba(15,15,30,.45);z-index:200;align-items:center;justify-content:center;padding:20px;}
.dash-modal.open{display:flex;}
.dash-modal-box{background:#fff;border-radius:16px;max-width:620px;width:100%;max-height:88vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);}
.dash-modal-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.dash-modal-head h3{font-family:'Inter',sans-serif;font-size:15px;font-weight:700;color:var(--ink);margin:0;}
.dash-modal-head .x{cursor:pointer;font-size:22px;color:var(--muted);background:none;border:none;line-height:1;font-family:inherit;}
.dash-modal-body{padding:14px 22px;overflow-y:auto;flex:1;}
.dash-modal-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:space-between;gap:8px;align-items:center;}
.dash-modal-foot .right{display:flex;gap:8px;}
.dash-modal-foot button{padding:8px 16px;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;border:1px solid transparent;}
.dash-modal-foot .primary{background:var(--ink);color:#fff;}
.dash-modal-foot .secondary{background:#fff;color:var(--ink);border-color:var(--border);}
.dash-modal-foot .danger{background:#fff;color:var(--accent);border-color:#f3c4bb;}

/* Repositorio */
.dash-repo-group{font-family:'Inter',sans-serif;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin:14px 0 6px;}
.dash-repo-group:first-child{margin-top:4px;}
.dash-repo-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:10px;border:1px solid var(--border);margin-bottom:8px;cursor:pointer;background:#fff;}
.dash-repo-item:hover{background:var(--surface);}
.dash-repo-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent2);}
.dash-repo-item .ic{width:36px;height:36px;border-radius:10px;background:var(--brand-soft);color:var(--brand-deep);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;}
.dash-repo-item .meta{flex:1;min-width:0;}
.dash-repo-item .meta .t{font-size:13px;font-weight:600;color:var(--ink);}
.dash-repo-item .meta .s{font-size:11.5px;color:var(--muted);margin-top:2px;}
.dash-repo-custom .ic{background:linear-gradient(135deg,#fceef0,#efecff);color:var(--accent2);}
.dash-kpi-tag{font-size:10px;color:var(--accent2);font-weight:700;background:#efecff;padding:1px 6px;border-radius:99px;margin-left:4px;}
.dash-repo-cta{border:2px dashed var(--accent2);background:linear-gradient(135deg,#fceef0,#efecff);margin-top:8px;}
.dash-repo-cta .ic{background:var(--accent2);color:#fff;}
.dash-repo-cta .meta .t{color:var(--accent2);}

/* KPI builder */
.dash-kpi-section{margin-bottom:18px;}
.dash-kpi-section h4{font-family:'Inter',sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:8px;}
.dash-kpi-meta{display:grid;grid-template-columns:1fr 110px 110px;gap:8px;margin-bottom:14px;}
.dash-kpi-meta input,.dash-kpi-meta select{padding:8px 11px;border:1.5px solid var(--border);border-radius:9px;font-size:13px;font-family:inherit;background:#fff;color:var(--ink);outline:none;}
.dash-kpi-meta input:focus,.dash-kpi-meta select:focus{border-color:var(--accent2);}

.dash-chip-pool{display:flex;flex-direction:column;gap:10px;}
.dash-chip-group-title{font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:5px;}
.dash-chip-row{display:flex;flex-wrap:wrap;gap:6px;}
.dash-chip{display:inline-flex;align-items:center;gap:5px;padding:6px 11px;border-radius:99px;font-size:12px;font-weight:600;cursor:grab;border:1px solid transparent;user-select:none;font-family:inherit;line-height:1.2;}
.dash-chip.data{background:#e3f2fd;color:#1565c0;border-color:#bbdefb;}
.dash-chip.op  {background:#fff3e0;color:#bf6a00;border-color:#ffe0b2;}
.dash-chip.num {background:#f1f8e9;color:#4a7c1d;border-color:#d4e9b8;}
.dash-chip:hover{filter:brightness(.96);}
.dash-chip.in-formula{cursor:pointer;padding-right:6px;}
.dash-chip.in-formula:hover{outline:2px solid var(--accent);outline-offset:1px;}
.dash-chip-x{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:rgba(0,0,0,.18);color:#fff;font-size:11px;font-weight:700;line-height:1;}
.dash-chip.in-formula:hover .dash-chip-x{background:var(--accent);}

.dash-formula-bar{min-height:54px;border:2px dashed var(--border);border-radius:12px;padding:10px;display:flex;flex-wrap:wrap;gap:6px;align-items:center;background:var(--surface);transition:border-color .15s,background .15s;}
.dash-formula-bar.drag-over{border-color:var(--accent2);background:#efecff;}
.dash-formula-bar:empty::before{content:"Arrastrá o tocá chips de abajo para armar la fórmula";color:var(--muted);font-size:12.5px;font-style:italic;}

.dash-kpi-preview{margin-top:12px;background:linear-gradient(135deg,#fceef0,#efecff);border-radius:14px;padding:14px 18px;border:1px solid #e4dcff;}
.dash-kpi-preview .lbl{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.7px;text-transform:uppercase;}
.dash-kpi-preview .val{font-family:'Inter',sans-serif;font-size:26px;font-weight:800;color:var(--ink);margin-top:4px;line-height:1;}
.dash-kpi-preview .sub{font-size:11.5px;color:var(--muted);margin-top:4px;}
.dash-kpi-preview .formula-txt{font-family:ui-monospace,monospace;font-size:11px;color:var(--accent2);margin-top:6px;background:rgba(255,255,255,.6);padding:4px 8px;border-radius:6px;display:inline-block;}

@media screen and (max-width:860px){
  .dash-kpi-meta{grid-template-columns:1fr;}
  .dash-modal-box{max-height:92vh;}
}
