:root {
  --acp-primary: #e3001e;
  --acp-secondary: #171717;
  --acp-bg: #f6f6f6;
  --acp-card: #fff;
  --acp-border: #e5e5e5;
  --acp-muted: #666;
  --acp-radius: 16px;
}

.acp-access-test,
.acp-restricted-message,
.acp-portal-card,
.acp-login-card {
  box-sizing: border-box;
  border: 1px solid var(--acp-border);
  border-radius: var(--acp-radius);
  padding: 24px;
  background: var(--acp-card);
  box-shadow: 0 8px 28px rgba(0, 0, 0, .05);
}

.acp-access-test.is-allowed { border-left: 4px solid #18864b; }
.acp-access-test.is-denied,
.acp-restricted-message { border-left: 4px solid var(--acp-primary); }
.acp-access-test p { margin: 0 0 8px; }
.acp-access-test ul { margin: 12px 0 0 20px; }

.acp-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  border: 0;
  border-radius: 9px;
  padding: 10px 17px;
  text-decoration: none !important;
  font-weight: 700;
  cursor: pointer;
  line-height: 1.2;
}
.acp-button-primary { background: var(--acp-primary); color: #fff !important; }
.acp-button-primary:hover { background: #c9001a; }
.acp-button-secondary { background: var(--acp-secondary); color: #fff !important; }
.acp-button-ghost { background: #f0f0f0; color: #222 !important; }
.acp-eyebrow {
  display: block;
  margin-bottom: 7px;
  color: var(--acp-primary);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.acp-muted { color: var(--acp-muted); }

/* Login */
.acp-login-card { max-width: 520px; margin: 8vh auto; padding: 38px; }
.acp-login-card h1 { margin: 0 0 10px; font-size: 34px; }
.acp-login-card > p { color: var(--acp-muted); line-height: 1.6; }
.acp-login-form { margin-top: 24px; }
.acp-login-submit { width: 100%; margin-top: 14px; }
.acp-login-remember,
.acp-inline-check {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  margin: 2px 0 0;
  font-weight: 500 !important;
}
.acp-login-remember input,
.acp-inline-check input { width: auto !important; margin: 0; }
.acp-login-help { display: block; margin-top: 14px; text-align: center; }
.acp-password-field {
  position: relative;
  display: block;
  width: 100%;
  max-width: none;
}
.acp-password-field input {
  width: 100% !important;
  max-width: none !important;
  padding-right: 48px !important;
}
.acp-password-field input::-ms-reveal,
.acp-password-field input::-ms-clear { display: none; }
.acp-password-toggle {
  box-sizing: border-box;
  position: absolute !important;
  z-index: 2;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  display: grid !important;
  place-items: center;
  width: 44px !important;
  min-width: 44px !important;
  max-width: 44px !important;
  height: 100% !important;
  min-height: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 8px 8px 0 !important;
  padding: 0 !important;
  transform: none !important;
  background: transparent !important;
  color: #4d4d4d !important;
  line-height: 0;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}
.acp-password-toggle:hover { background: rgba(0, 0, 0, .055) !important; color: #111 !important; }
.acp-password-toggle:focus-visible {
  outline: 2px solid var(--acp-primary);
  outline-offset: -3px;
  background: rgba(227, 0, 30, .06) !important;
}
.acp-password-icon {
  display: block;
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  pointer-events: none;
}
.acp-password-icon-open { display: none; }
.acp-password-toggle[aria-pressed="true"] .acp-password-icon-closed { display: none; }
.acp-password-toggle[aria-pressed="true"] .acp-password-icon-open { display: block; }

/* Navegación */
.acp-portal-nav {
  position: relative;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  width: 100%;
  margin: 0 0 18px;
  padding: 14px 18px;
  border: 1px solid var(--acp-border);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 7px 24px rgba(0, 0, 0, .04);
}
.acp-nav-zone { min-width: 0; }
.acp-nav-zone-left { justify-self: start; }
.acp-nav-zone-center { justify-self: center; }
.acp-nav-zone-right { justify-self: end; display: flex; align-items: center; }
.acp-portal-brand {
  display: flex;
  align-items: center;
  gap: 9px;
  color: #111 !important;
  text-decoration: none !important;
  font-weight: 800;
  white-space: nowrap;
}
.acp-brand-mark {
  display: grid;
  place-items: center;
  width: 35px;
  height: 35px;
  border-radius: 9px;
  background: var(--acp-primary);
  color: #fff;
  font-size: 12px;
}
.acp-nav-links { display: flex; align-items: center; }
.acp-nav-link-list { display: flex; align-items: center; justify-content: center; gap: 5px; }
.acp-nav-links a {
  padding: 8px 10px;
  border-radius: 7px;
  color: #333 !important;
  text-decoration: none !important;
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
}
.acp-nav-links a:hover { background: #f2f2f2; }
.acp-nav-user { display: flex; align-items: center; gap: 9px; }
.acp-nav-user > a:first-child,
.acp-nav-mobile-user > a:first-child {
  display: flex;
  align-items: center;
  gap: 7px;
  color: #222 !important;
  text-decoration: none !important;
  font-size: 13px;
}
.acp-nav-user img,
.acp-nav-mobile-user img { border-radius: 50%; object-fit: cover; }
.acp-nav-logout { color: var(--acp-primary) !important; font-size: 12px; text-decoration: none !important; }
.acp-nav-toggle,
.acp-nav-close,
.acp-nav-overlay,
.acp-nav-mobile-user { display: none; }

/* Selector de ámbito */
.acp-scope-bar {
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: stretch;
  min-height: 92px;
  margin: 0 0 20px;
  padding: 16px 18px;
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.035), rgba(255,255,255,0)),
    rgba(10, 10, 12, .94);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 12px 30px rgba(0,0,0,.08);
  backdrop-filter: blur(12px);
}
.acp-scope-current {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  justify-content: center;
  min-width: 180px;
}
.acp-scope-current .acp-eyebrow { margin-bottom: 6px; color: #ff7184; font-size: 11px; }
.acp-scope-current strong { display: block; margin: 0; color: #fff; font-size: 16px; line-height: 1.3; }
.acp-scope-current small { display: block; margin-top: 5px; color: #aaa; font-size: 11px; }
.acp-scope-form { display: flex; align-items: end; gap: 10px; }
.acp-scope-form label { margin: 0; }
.acp-scope-form label span {
  display: block;
  margin-bottom: 5px;
  color: #aaa;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .04em;
}
.acp-scope-form select {
  box-sizing: border-box;
  width: 170px;
  height: 42px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  padding: 0 34px 0 12px;
  background: rgba(255,255,255,.07);
  color: #fff;
  font-size: 13px;
  line-height: 1;
  outline: none;
}
.acp-scope-form select:hover { border-color: rgba(255,255,255,.3); background: rgba(255,255,255,.1); }
.acp-scope-form select:focus { border-color: var(--acp-primary); box-shadow: 0 0 0 3px rgba(227,0,30,.18); }
.acp-scope-form select option { color: #111; background: #fff; }
.acp-scope-apply { height: 42px; min-width: 92px; padding-top: 0; padding-bottom: 0; }
.acp-scope-bar-admin { justify-content: flex-start; }

/* Contenido */
.acp-portal-hero {
  box-sizing: border-box;
  margin-bottom: 18px;
  padding: 34px;
  border: 1px solid var(--acp-border);
  border-radius: 20px;
  background: linear-gradient(135deg, #fff 0%, #f7f7f7 100%);
}
.acp-portal-hero h1 { margin: 0 0 10px; font-size: 38px; }
.acp-portal-hero p { max-width: 760px; margin: 0; color: #555; font-size: 17px; line-height: 1.6; }
.acp-portal-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; margin-bottom: 18px; }
.acp-portal-card strong { display: block; margin: 7px 0; font-size: 21px; }
.acp-portal-card p { color: var(--acp-muted); line-height: 1.55; }
.acp-card-label { color: #777; font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.acp-phase-card h2,
.acp-module-placeholder h1 { margin-top: 0; }

/* Formularios */
.acp-section-heading { display: flex; justify-content: space-between; align-items: center; gap: 20px; margin-bottom: 22px; }
.acp-section-heading h2 { margin: 0 0 6px; font-size: 30px; }
.acp-section-heading p { margin: 0; color: var(--acp-muted); }
.acp-profile-avatar img { border-radius: 50%; object-fit: cover; }
.acp-portal-form h3 { margin: 0 0 6px; }
.acp-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px 16px; }
.acp-form-field { min-width: 0; margin-bottom: 12px; }
.acp-form-field-wide { grid-column: 1 / -1; }
.acp-form-field > label { display: block; margin-bottom: 5px; font-weight: 700; }
.acp-form-field input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
.acp-form-field select,
.acp-portal-form textarea {
  box-sizing: border-box;
  width: 100%;
  min-height: 42px;
  border: 1px solid #ccc;
  border-radius: 8px;
  padding: 9px 11px;
  background: #fff;
}
.acp-form-field input[type="file"] { display: block; width: 100%; }
.acp-form-field input:focus,
.acp-form-field select:focus,
.acp-portal-form textarea:focus { border-color: var(--acp-primary); outline: none; box-shadow: 0 0 0 3px rgba(227,0,30,.1); }
.acp-form-field small { display: block; margin-top: 4px; color: #777; font-size: 12px; line-height: 1.45; }
.acp-divider { border: 0; border-top: 1px solid var(--acp-border); margin: 20px 0; }
.acp-portal-notice { margin: 0 0 16px; padding: 12px 15px; border-radius: 8px; font-weight: 600; }
.acp-portal-notice.is-success { background: #e8f7ed; color: #176b35; }
.acp-portal-notice.is-error { background: #fff0f0; color: #9d1b1b; }

/* Gestión de usuarios */
.acp-user-layout { display: grid; grid-template-columns: minmax(330px, 430px) minmax(0, 1fr); gap: 22px; }
.acp-user-form-panel,
.acp-user-list-panel { min-width: 0; }
.acp-user-form-panel { padding: 18px; border-radius: 12px; background: #f7f7f7; }
.acp-user-form-panel h3,
.acp-user-list-panel h3 { margin-top: 0; }
.acp-user-form-panel .acp-form-field { margin-bottom: 11px; }
.acp-choice-list { display: grid; gap: 7px; }
.acp-choice-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.acp-choice-item {
  box-sizing: border-box;
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  min-height: 42px;
  margin: 0 !important;
  border: 1px solid #ddd;
  border-radius: 8px;
  padding: 9px 10px !important;
  background: #fff;
  font-weight: 500 !important;
  line-height: 1.3;
  cursor: pointer;
}
.acp-choice-item:hover { border-color: #bbb; }
.acp-choice-item:has(input:checked) { border-color: var(--acp-primary); background: #fff6f7; box-shadow: 0 0 0 2px rgba(227,0,30,.07); }
.acp-choice-item input[type="checkbox"],
.acp-choice-item input[type="radio"] { flex: 0 0 auto; width: 16px !important; height: 16px !important; margin: 0 !important; accent-color: var(--acp-primary); }
.acp-choice-item span { min-width: 0; overflow-wrap: anywhere; }
.acp-choice-list-scroll { max-height: 210px; overflow: auto; padding-right: 3px; }
.acp-form-actions { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 4px; }
.acp-editing-user { display: flex; flex-direction: column; margin-bottom: 13px; padding: 11px; border-radius: 8px; background: #fff; }
.acp-editing-user span { color: #666; font-size: 13px; }
.acp-user-limit-note { padding: 7px 10px; border-radius: 999px; background: #f1f1f1; font-size: 12px; font-weight: 700; }
.acp-responsive-table { overflow-x: auto; }
.acp-front-table { width: 100%; border-collapse: collapse; }
.acp-front-table th,
.acp-front-table td { padding: 12px 10px; border-bottom: 1px solid var(--acp-border); text-align: left; vertical-align: top; }
.acp-front-table th { color: #666; font-size: 12px; letter-spacing: .04em; text-transform: uppercase; }
.acp-front-table td small { display: block; margin-top: 3px; color: #777; }
.acp-front-status { display: inline-block; padding: 4px 8px; border-radius: 999px; font-size: 11px; font-weight: 700; }
.acp-front-status.is-active { background: #e8f7ed; color: #176b35; }
.acp-front-status.is-inactive { background: #eee; color: #555; }
.acp-inline-front-form { display: inline; margin-left: 8px; }
.acp-inline-front-form button { border: 0; padding: 0; background: none; color: var(--acp-primary); cursor: pointer; text-decoration: underline; }
.acp-restricted-message { max-width: 680px; margin: 40px auto; text-align: center; }
.acp-restricted-message h2 { margin: 0 0 8px; }

@media (max-width: 1180px) {
  .acp-nav-links a { padding-right: 7px; padding-left: 7px; font-size: 13px; }
}

@media (max-width: 1000px) {
  body.acp-nav-open { overflow: hidden; }
  .acp-portal-nav { grid-template-columns: 1fr auto; gap: 12px; }
  .acp-nav-zone-left { grid-column: 1; }
  .acp-nav-zone-right { grid-column: 2; }
  .acp-nav-user { display: none; }
  .acp-nav-toggle {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
    width: 42px;
    height: 42px;
    border: 1px solid #ddd;
    border-radius: 9px;
    padding: 0 10px;
    background: #f5f5f5;
    cursor: pointer;
  }
  .acp-nav-toggle span { display: block; width: 100%; height: 2px; border-radius: 99px; background: #222; transition: transform .2s ease, opacity .2s ease; }
  .acp-nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  .acp-nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .acp-nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
  .acp-nav-links {
    position: fixed;
    z-index: 100002;
    top: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: min(88vw, 340px);
    padding: 72px 20px 24px;
    background: #fff;
    box-shadow: -18px 0 48px rgba(0,0,0,.18);
    transform: translateX(105%);
    transition: transform .24s ease;
  }
  .acp-nav-links.is-open { transform: translateX(0); }
  .acp-nav-link-list { display: flex; flex-direction: column; align-items: stretch; gap: 4px; }
  .acp-nav-links a { width: 100%; box-sizing: border-box; padding: 12px; font-size: 15px; }
  .acp-nav-close {
    position: absolute;
    top: 18px;
    right: 18px;
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 50%;
    background: #f1f1f1;
    font-size: 25px;
    cursor: pointer;
  }
  .acp-nav-mobile-user { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: auto; border-top: 1px solid #eee; padding-top: 18px; }
  .acp-nav-mobile-user > a:first-child { min-width: 0; }
  .acp-nav-mobile-user > a:first-child span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .acp-nav-overlay {
    position: fixed;
    z-index: 100001;
    inset: 0;
    display: block;
    border: 0;
    padding: 0;
    background: rgba(0,0,0,.42);
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
  }
  .acp-nav-overlay.is-open { opacity: 1; pointer-events: auto; }
  .acp-portal-grid { grid-template-columns: 1fr; }
  .acp-user-layout { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .acp-portal-nav { padding: 11px 13px; }
  .acp-portal-brand span:last-child { display: none; }
  .acp-scope-bar { flex-direction: column; min-height: 0; gap: 14px; padding: 15px; }
  .acp-scope-current { min-height: 58px; }
  .acp-scope-form { align-items: stretch; flex-direction: column; gap: 8px; }
  .acp-scope-form select,
  .acp-scope-apply { width: 100%; }
  .acp-form-grid { grid-template-columns: 1fr; gap: 0; }
  .acp-form-field-wide { grid-column: auto; }
  .acp-choice-grid { grid-template-columns: 1fr; }
  .acp-section-heading { align-items: flex-start; flex-direction: column; }
  .acp-portal-hero { padding: 24px; }
  .acp-portal-hero h1 { font-size: 31px; }
  .acp-login-card { margin: 20px 12px; padding: 25px; }
  .acp-portal-card { padding: 18px; }
}

/* Glosario de métricas */
.acp-metric-glossary{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:22px}.acp-section-heading h2{margin:4px 0 18px}.acp-table-scroll{overflow:auto}.acp-metric-glossary table{width:100%;border-collapse:collapse;min-width:680px}.acp-metric-glossary th,.acp-metric-glossary td{text-align:left;padding:13px 14px;border-bottom:1px solid rgba(0,0,0,.08);vertical-align:top}.acp-metric-glossary th{font-size:12px;text-transform:uppercase;letter-spacing:.06em}.acp-metric-glossary code{font-size:12px}.acp-empty-state{padding:18px;border:1px dashed rgba(0,0,0,.2);border-radius:12px}

/* Compras */
.acp-purchase-summary-front,.acp-purchase-table-front{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:22px}.acp-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.acp-kpi-card{border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:16px;background:#fafafa}.acp-kpi-card span{display:block;margin-bottom:7px;color:#666;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.acp-kpi-card strong{font-size:22px}.acp-purchase-table-front table{width:100%;min-width:720px;border-collapse:collapse}.acp-purchase-table-front th,.acp-purchase-table-front td{padding:12px 13px;border-bottom:1px solid rgba(0,0,0,.08);text-align:left}.acp-purchase-table-front th{font-size:12px;text-transform:uppercase;letter-spacing:.05em}.acp-purchase-table-front .is-negative{color:#b32d2e}

/* Fase 5: gráficos y filtros globales */
.acp-chart-widget{box-sizing:border-box;position:relative;min-width:0;margin:0 0 20px;padding:20px;border:1px solid var(--acp-border);border-radius:16px;background:#fff;box-shadow:0 8px 26px rgba(0,0,0,.045);overflow:hidden}.acp-chart-widget.is-loading{min-height:240px}.acp-chart-loading,.acp-chart-empty{display:grid;place-items:center;min-height:190px;color:#777;font-size:14px}.acp-chart-error{display:flex;flex-direction:column;gap:6px;min-height:150px;justify-content:center;align-items:center;border-radius:10px;background:#fff2f3;color:#9b1c1c;text-align:center;padding:20px}.acp-chart-header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:14px}.acp-chart-copy h3{margin:0 0 5px;font-size:20px;color:#111}.acp-chart-copy p{margin:0;color:#6b6b6b;font-size:13px;line-height:1.5}.acp-chart-export{display:flex;align-items:center;gap:5px;flex-wrap:wrap;justify-content:flex-end}.acp-chart-export-button{min-width:42px;height:30px;border:1px solid #ddd;border-radius:7px;padding:0 9px;background:#f7f7f7;color:#333;font-size:11px;font-weight:700;cursor:pointer}.acp-chart-export-button:hover{border-color:var(--acp-primary);color:var(--acp-primary);background:#fff}.acp-chart-canvas{width:100%;min-height:220px}.acp-chart-kpi-body{display:flex;flex-direction:column;justify-content:center;min-height:180px;padding:10px 4px}.acp-chart-kpi-body.is-counter{align-items:center;text-align:center}.acp-chart-kpi-value{display:block;color:#111;font-size:clamp(42px,6vw,72px);line-height:1;font-weight:800;letter-spacing:-.04em}.acp-chart-kpi-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.acp-chart-kpi-meta span{display:inline-flex;align-items:center;min-height:30px;border-radius:999px;padding:0 11px;background:#f2f2f2;color:#555;font-size:12px;font-weight:700}.acp-chart-kpi-meta .is-positive{background:#e8f7ed;color:#176b35}.acp-chart-kpi-meta .is-negative{background:#fff0f0;color:#9d1b1b}.acp-chart-table-wrap{overflow:auto;max-width:100%}.acp-chart-table{width:100%;border-collapse:collapse;font-size:13px}.acp-chart-table th,.acp-chart-table td{border-bottom:1px solid #e8e8e8;padding:10px 12px;text-align:right;white-space:nowrap}.acp-chart-table th:first-child,.acp-chart-table td:first-child{text-align:left}.acp-chart-table thead th{background:#f7f7f7;color:#555;font-size:11px;text-transform:uppercase;letter-spacing:.05em}.acp-global-filters{box-sizing:border-box;display:grid;grid-template-columns:minmax(150px,1fr) minmax(150px,1fr) minmax(150px,1fr) auto;gap:10px;align-items:end;margin:0 0 20px;padding:14px 16px;border:1px solid rgba(255,255,255,.1);border-radius:13px;background:rgba(14,14,16,.94);color:#fff;box-shadow:0 10px 26px rgba(0,0,0,.08)}.acp-global-filter-field label{display:block;margin-bottom:5px;color:#aaa;font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.acp-global-filter-field select,.acp-global-filter-field input{box-sizing:border-box;width:100%;height:40px;border:1px solid rgba(255,255,255,.17);border-radius:8px;padding:0 11px;background:rgba(255,255,255,.07);color:#fff;font-size:12px}.acp-global-filter-field input::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.72}.acp-global-filter-actions{display:flex;gap:7px}.acp-global-filter-actions button{height:40px;border-radius:8px;border:1px solid transparent;padding:0 14px;font-size:12px;font-weight:700;cursor:pointer}.acp-global-filter-apply{background:var(--acp-primary);color:#fff}.acp-global-filter-reset{border-color:rgba(255,255,255,.2)!important;background:transparent;color:#ddd}
@media(max-width:800px){.acp-chart-widget{padding:15px}.acp-chart-header{flex-direction:column}.acp-chart-export{justify-content:flex-start}.acp-global-filters{grid-template-columns:1fr 1fr}.acp-global-filter-actions{grid-column:1/-1}.acp-global-filter-actions button{flex:1}}
@media(max-width:520px){.acp-global-filters{grid-template-columns:1fr}.acp-global-filter-actions{grid-column:auto}.acp-chart-kpi-value{font-size:44px}}

/* v0.6.1 — filtros globales compactos y legibles */
.acp-global-filters{display:flex;align-items:flex-end;gap:10px;flex-wrap:nowrap}
.acp-global-filter-field{flex:0 0 170px;min-width:0}.acp-global-filter-field:first-child{flex-basis:150px}.acp-global-filter-date{flex-basis:180px}
.acp-global-filter-field select,.acp-global-filter-field input{width:100%;color-scheme:dark;cursor:pointer}
.acp-global-filter-field select option{background:#242428!important;color:#fff!important}
.acp-global-filter-field input[type="date"]{caret-color:transparent;user-select:none}
.acp-global-filter-actions{margin-left:auto;flex:0 0 auto;align-items:center}
.acp-empty-state{box-sizing:border-box;margin:0 0 18px;padding:18px;border:1px dashed rgba(0,0,0,.18);border-radius:12px;background:#fafafa;color:#666}
@media(max-width:900px){.acp-global-filters{flex-wrap:wrap}.acp-global-filter-field{flex:1 1 180px}.acp-global-filter-actions{width:100%;margin-left:0;justify-content:flex-end}.acp-global-filter-actions button{flex:0 0 auto}}
@media(max-width:520px){.acp-global-filter-field{flex:1 1 100%}.acp-global-filter-actions{justify-content:stretch}.acp-global-filter-actions button{flex:1}}

/* Fase 6 — centro documental */
.acp-document-library{box-sizing:border-box}.acp-document-library-heading{align-items:flex-end}.acp-document-view-toggle{display:flex;gap:6px}.acp-document-view-toggle a{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--acp-border);border-radius:8px;background:#fff;color:#333!important;text-decoration:none!important;font-size:18px}.acp-document-view-toggle a.is-active{border-color:var(--acp-primary);background:var(--acp-primary);color:#fff!important}
.acp-document-library-filters{display:grid;grid-template-columns:minmax(220px,1.4fr) repeat(6,minmax(120px,.75fr)) auto;gap:10px;align-items:end;margin:0 0 18px;padding:14px;border:1px solid var(--acp-border);border-radius:12px;background:#f8f8f8}.acp-document-library-filters>div{min-width:0}.acp-document-library-filters label{display:block;margin-bottom:5px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.acp-document-library-filters input,.acp-document-library-filters select{box-sizing:border-box;width:100%;min-width:0;height:40px;border:1px solid #ccc;border-radius:8px;padding:0 10px;background:#fff}.acp-document-library-filter-actions{display:flex;gap:7px;white-space:nowrap}.acp-document-results-summary{margin:0 0 12px;color:#666;font-size:13px}
.acp-document-items{display:grid;gap:16px}.acp-document-items-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.acp-document-items-list{grid-template-columns:1fr}.acp-document-item{position:relative;display:flex;min-width:0;border:1px solid var(--acp-border);border-radius:14px;background:#fff;overflow:hidden;box-shadow:0 7px 20px rgba(0,0,0,.035)}.acp-document-items-grid .acp-document-item{flex-direction:column}.acp-document-items-list .acp-document-item{min-height:170px}.acp-document-cover{display:block;flex:0 0 auto;background:#efefef;text-decoration:none!important}.acp-document-items-grid .acp-document-cover{height:220px}.acp-document-items-list .acp-document-cover{width:130px}.acp-document-cover img{width:100%;height:100%;object-fit:cover}.acp-document-generic-cover{display:grid;place-items:center;width:100%;height:100%;min-height:170px;background:linear-gradient(145deg,#111,#2d2d2d);color:#fff;text-align:center}.acp-document-generic-cover span{display:block;font-size:34px;font-weight:900;letter-spacing:.06em}.acp-document-generic-cover small{color:#bbb}.acp-document-item-content{display:flex;flex:1;flex-direction:column;min-width:0;padding:16px}.acp-document-item-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.acp-document-type{color:var(--acp-primary);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.acp-document-new{padding:3px 7px;border-radius:999px;background:#fff0f2;color:#b00018;font-size:10px;font-weight:800}.acp-document-item h3{margin:9px 0 7px;font-size:18px;line-height:1.25}.acp-document-item h3 a{color:#111!important;text-decoration:none!important}.acp-document-item p{margin:0 0 12px;color:#666;line-height:1.5}.acp-document-meta{display:flex;flex-wrap:wrap;gap:7px 14px;margin-top:auto;color:#777;font-size:12px}.acp-document-actions{display:flex;align-items:center;justify-content:space-between;gap:9px;margin-top:14px}.acp-document-actions button,.acp-document-favorite-button{border:1px solid #ddd;border-radius:8px;background:#fff;color:#777;cursor:pointer}.acp-document-actions button{width:38px;height:38px;font-size:19px}.acp-document-item.is-favorite .acp-document-actions button,.acp-document-favorite-button[aria-pressed="true"]{border-color:#e3a400;color:#c88c00;background:#fff9e8}.acp-document-item.is-unread{border-left:3px solid var(--acp-primary)}
.acp-document-pagination{display:flex;justify-content:center;gap:5px;margin-top:20px}.acp-document-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1px solid var(--acp-border);border-radius:7px;background:#fff;color:#333!important;text-decoration:none!important}.acp-document-pagination .current{border-color:var(--acp-primary);background:var(--acp-primary);color:#fff!important}
.acp-empty-state{padding:32px;border:1px dashed #ccc;border-radius:14px;background:#fafafa;text-align:center}.acp-empty-state h2,.acp-empty-state h3{margin-top:0}
.acp-document-back{display:inline-block;margin-bottom:18px;color:#555!important;text-decoration:none!important}.acp-document-detail{box-sizing:border-box}.acp-document-detail-layout{display:grid;grid-template-columns:minmax(180px,250px) minmax(0,1fr);gap:28px;align-items:start;padding:24px;border:1px solid var(--acp-border);border-radius:18px;background:#fff}.acp-document-detail-cover img,.acp-document-detail-cover .acp-document-generic-cover{width:100%;min-height:300px;max-height:360px;object-fit:cover;border-radius:10px}.acp-document-detail-content h1{margin:8px 0 14px;font-size:34px;line-height:1.15}.acp-document-detail-meta{display:flex;flex-wrap:wrap;gap:8px 20px;color:#666}.acp-document-detail-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.acp-document-favorite-button{min-height:42px;padding:0 14px;font-weight:700}.acp-document-detail-section{margin-top:18px;padding:24px;border:1px solid var(--acp-border);border-radius:14px;background:#fff}.acp-document-detail-section h2{margin-top:0}.acp-document-detail-section ul{margin-bottom:0}.acp-document-viewer-placeholder{background:#fafafa}.acp-document-key-points{display:grid;gap:8px;padding-left:20px}
@media(max-width:1400px){.acp-document-library-filters{grid-template-columns:repeat(4,minmax(130px,1fr))}.acp-document-library-filter-actions{grid-column:4;justify-self:end}.acp-document-items-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:980px){.acp-document-library-filters{grid-template-columns:repeat(2,minmax(140px,1fr))}.acp-document-library-filter-actions{grid-column:auto;justify-self:stretch}.acp-document-items-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.acp-document-detail-layout{grid-template-columns:180px minmax(0,1fr)}}
@media(max-width:650px){.acp-document-library-heading{align-items:flex-start;flex-direction:column}.acp-document-library-filters{grid-template-columns:1fr}.acp-document-library-filter-actions{display:grid;grid-template-columns:1fr 1fr}.acp-document-items-grid{grid-template-columns:1fr}.acp-document-items-list .acp-document-item{flex-direction:column}.acp-document-items-list .acp-document-cover{width:100%;height:190px}.acp-document-detail-layout{grid-template-columns:1fr}.acp-document-detail-cover{max-width:230px}.acp-document-detail-content h1{font-size:28px}.acp-document-detail-actions .acp-button,.acp-document-favorite-button{width:100%;text-align:center}}


/* v0.7.1 — alineación, filtros y estados del centro documental */
.acp-document-actions > .acp-button,
.acp-document-actions > button{
  box-sizing:border-box;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  height:42px;
}
.acp-document-actions > button{
  flex:0 0 42px;
  width:42px;
  padding:0;
  line-height:1;
}
.acp-document-library-filter-actions .acp-button{
  box-sizing:border-box;
  width:88px;
  min-width:88px;
  min-height:42px;
  height:42px;
  padding:0 12px;
}
.acp-document-detail-content{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  min-height:300px;
  min-width:0;
}
.acp-document-detail-actions{
  align-items:center;
}
.acp-document-detail-actions .acp-button,
.acp-document-detail-actions .acp-document-favorite-button{
  box-sizing:border-box;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  height:42px;
  padding:0 16px;
  line-height:1.2;
  white-space:nowrap;
}
.acp-document-read-button{
  border:0;
  background:#ededed;
  color:#333!important;
}
.acp-document-read-button:hover{
  background:#e2e2e2;
}
.acp-document-read-button[aria-pressed="true"]{
  background:var(--acp-secondary);
  color:#fff!important;
}
.acp-document-read-button[aria-pressed="true"]:hover{
  background:#050505;
}
.acp-document-download-button{
  min-width:0;
}
@media(max-width:650px){
  .acp-document-detail-content{min-height:0;justify-content:flex-start}
  .acp-document-library-filter-actions .acp-button{width:100%;min-width:0}
}

/* v0.7.2 — formatos de portada y acciones del detalle */
.acp-document-cover,
.acp-document-detail-cover{
  --acp-cover-ratio:.707071;
}
.acp-document-items-grid .acp-document-cover{
  height:auto;
  aspect-ratio:var(--acp-cover-ratio);
  overflow:hidden;
}
.acp-document-items-list .acp-document-cover{
  width:200px;
  height:auto;
  aspect-ratio:var(--acp-cover-ratio);
  align-self:center;
  overflow:hidden;
}
.acp-document-cover img,
.acp-document-detail-cover img{
  display:block;
  width:100%;
  height:100%;
  background:#fff;
}
.acp-cover-fit-contain img{object-fit:contain!important}
.acp-cover-fit-cover img{object-fit:cover!important}
.acp-document-detail-cover{
  width:100%;
  min-height:0;
  max-height:none;
  aspect-ratio:var(--acp-cover-ratio);
  overflow:hidden;
  align-self:end;
}
.acp-document-detail-cover img,
.acp-document-detail-cover .acp-document-generic-cover{
  width:100%;
  height:100%;
  min-height:0;
  max-height:none;
}
.acp-document-detail-actions{
  display:flex!important;
  align-items:center!important;
  gap:10px;
}
.acp-document-detail-actions > .acp-button,
.acp-document-detail-actions > .acp-document-favorite-button{
  box-sizing:border-box!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex:0 0 auto!important;
  align-self:center!important;
  height:44px!important;
  min-height:44px!important;
  margin:0!important;
  padding:0 16px!important;
  line-height:1!important;
  vertical-align:middle!important;
  white-space:nowrap;
}
.acp-document-detail-actions > .acp-document-download-button{
  border:0!important;
}
@media(max-width:650px){
  .acp-document-items-list .acp-document-cover{width:100%;height:auto;aspect-ratio:var(--acp-cover-ratio)}
  .acp-document-detail-cover{max-width:100%}
  .acp-document-detail-actions > .acp-button,
  .acp-document-detail-actions > .acp-document-favorite-button{width:100%!important}
}


/* v0.7.3 — biblioteca documental uniforme y controles móviles */
.acp-document-filter-toggle{
  display:none;
  box-sizing:border-box;
  width:100%;
  min-height:44px;
  margin:0 0 12px;
  border:1px solid var(--acp-border);
  border-radius:10px;
  padding:0 14px;
  background:#fff;
  color:#1b1b1b;
  font-weight:800;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  cursor:pointer;
}
.acp-document-filter-toggle.has-active-filters{border-color:var(--acp-primary)}
.acp-document-filter-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:24px;
  height:24px;
  margin-left:auto;
  border-radius:999px;
  padding:0 7px;
  background:var(--acp-primary);
  color:#fff;
  font-size:11px;
  line-height:1;
}
.acp-document-filter-chevron{display:inline-block;font-size:18px;line-height:1;transition:transform .18s ease}
.acp-document-filter-toggle.is-open .acp-document-filter-chevron{transform:rotate(180deg)}

/* Grid: todas las portadas usan el mismo recorte panorámico. */
.acp-document-items-grid .acp-document-cover{
  width:100%;
  height:auto!important;
  aspect-ratio:16 / 9!important;
  overflow:hidden;
  background:#efefef;
}
.acp-document-items-grid .acp-document-cover img{
  width:100%;
  height:100%;
  object-fit:cover!important;
  object-position:center;
}
.acp-document-items-grid .acp-document-generic-cover{min-height:0;height:100%}

/* Listado: miniatura cuadrada y contenido centrado a la derecha. */
.acp-document-items-list .acp-document-item{
  display:grid;
  grid-template-columns:190px minmax(0,1fr);
  min-height:190px;
  align-items:stretch;
}
.acp-document-items-list .acp-document-cover{
  width:190px!important;
  height:190px!important;
  aspect-ratio:1 / 1!important;
  align-self:stretch!important;
  overflow:hidden;
  background:#efefef;
}
.acp-document-items-list .acp-document-cover img{
  width:100%;
  height:100%;
  object-fit:cover!important;
  object-position:center;
}
.acp-document-items-list .acp-document-generic-cover{min-height:0;height:100%}
.acp-document-items-list .acp-document-item-content{
  min-width:0;
  justify-content:center;
  padding:18px 20px;
}
.acp-document-items-list .acp-document-item h3,
.acp-document-items-list .acp-document-item h3 a{
  white-space:normal;
  overflow:visible;
  text-overflow:clip;
  overflow-wrap:anywhere;
  word-break:normal;
}
.acp-document-items-list .acp-document-meta{margin-top:0}

@media(max-width:650px){
  .acp-document-filter-toggle{display:flex}
  .acp-document-library-filters{display:none!important;margin-bottom:14px}
  .acp-document-library-filters.is-open{display:grid!important}
  .acp-document-view-toggle{display:none!important}

  /* La vista guardada en escritorio no altera la presentación móvil. */
  .acp-document-items-list{grid-template-columns:1fr}
  .acp-document-items-list .acp-document-item{
    display:flex;
    flex-direction:column;
    min-height:0;
  }
  .acp-document-items-list .acp-document-cover{
    width:100%!important;
    height:auto!important;
    aspect-ratio:16 / 9!important;
  }
  .acp-document-items-list .acp-document-item-content{
    justify-content:flex-start;
    padding:16px;
  }
}


/* v0.7.4 — detalle documental móvil y toggle de filtros */
.acp-document-filter-chevron{
  display:inline-flex;
  flex:0 0 28px;
  width:28px;
  height:28px;
  margin-left:4px;
  align-items:center;
  justify-content:center;
  line-height:1;
  transform-origin:center;
  transition:transform .18s ease;
}
.acp-document-filter-chevron svg{
  display:block;
  width:24px;
  height:24px;
  fill:none;
  stroke:currentColor;
  stroke-width:2.4;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.acp-document-filter-toggle.is-open .acp-document-filter-chevron{transform:rotate(180deg)}

@media(max-width:650px){
  /* En el detalle móvil priorizamos el título, las acciones y el visor PDF. */
  body.acp-has-document-detail .acp-scope-bar,
  body:has(.acp-document-detail) .acp-scope-bar{display:none!important}
  body.acp-has-document-detail .acp-document-detail-cover,
  body:has(.acp-document-detail) .acp-document-detail-cover{display:none!important}
  body.acp-has-document-detail .acp-document-detail-layout{
    display:block;
    padding:18px;
  }
  body.acp-has-document-detail .acp-document-detail-content{
    width:100%;
    min-height:0;
  }
}

/* Phase 7: PDF viewer */
.acp-pdf-viewer{overflow:hidden;padding:0!important}.acp-pdf-viewer-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding:24px 24px 16px}.acp-pdf-viewer-heading h2{margin:3px 0 0}.acp-pdf-status{font-size:12px;color:#666}.acp-pdf-toolbar{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:12px 16px;background:#171719;color:#fff;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.08)}.acp-pdf-toolbar-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.acp-pdf-toolbar button{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;border:1px solid rgba(255,255,255,.16);border-radius:8px;background:#27272a;color:#fff;font-weight:600;cursor:pointer}.acp-pdf-toolbar button:hover,.acp-pdf-toolbar button:focus{background:#35353a;border-color:rgba(255,255,255,.3)}.acp-pdf-toolbar label{display:flex;align-items:center;gap:6px;font-size:13px}.acp-pdf-toolbar input{width:58px;height:36px;padding:5px 8px;border:1px solid rgba(255,255,255,.2);border-radius:7px;background:#fff;color:#111;text-align:center}.acp-pdf-stage{position:relative;display:flex;justify-content:center;align-items:flex-start;min-height:430px;max-height:78vh;overflow:auto;padding:16px;background:#e7e7e9;outline:none}.acp-pdf-stage canvas{display:block;max-width:none;background:#fff;box-shadow:0 8px 28px rgba(0,0,0,.18)}.acp-pdf-loading{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:rgba(247,247,248,.92)}.acp-pdf-loading[hidden]{display:none}.acp-pdf-loading span{width:32px;height:32px;border:3px solid #ccc;border-top-color:#e3001e;border-radius:50%;animation:acp-spin .8s linear infinite}.acp-pdf-loading p{margin:0;color:#444}.acp-pdf-error{margin:16px;padding:16px;border:1px solid #f0b8bf;border-radius:10px;background:#fff4f5;color:#8d0012}@keyframes acp-spin{to{transform:rotate(360deg)}}.acp-pdf-viewer:fullscreen{background:#111;padding:0}.acp-pdf-viewer:fullscreen .acp-pdf-stage{max-height:calc(100vh - 120px);min-height:calc(100vh - 120px)}

/* Phase 7: conversations */
.acp-comments{padding:24px}.acp-comments-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:20px}.acp-comments-heading h2{margin:3px 0 6px}.acp-comments-heading p{margin:0;color:#666}.acp-comments-count{flex:0 0 auto;padding:7px 10px;border-radius:999px;background:#f1f1f2;font-size:12px;font-weight:700}.acp-comment-form,.acp-comment-reply-form{display:grid;gap:10px;padding:16px;border:1px solid #dedee1;border-radius:12px;background:#fafafa}.acp-comment-form{margin-bottom:20px}.acp-comment-form label{font-weight:700}.acp-comment-form textarea,.acp-comment-reply-form textarea{width:100%;min-height:84px;resize:vertical;border:1px solid #cfcfd3;border-radius:9px;padding:12px;font:inherit;background:#fff}.acp-comment-form>div{display:flex;align-items:center;justify-content:space-between;gap:14px}.acp-comment-form small{color:#666}.acp-comment-feedback{margin:0 0 16px;padding:10px 12px;border-radius:8px;background:#e8f7ed;color:#146c2e}.acp-comment-feedback.is-error{background:#fff0f2;color:#9b0015}.acp-comment-thread{margin-top:16px;padding:18px;border:1px solid #dedee1;border-radius:14px;background:#fff}.acp-comment-thread>header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.acp-comment-status{display:inline-flex;padding:5px 9px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.acp-comment-status-open{background:#eef1f4;color:#39414a}.acp-comment-status-pending{background:#fff2d8;color:#8c5700}.acp-comment-status-answered{background:#e8f7ed;color:#146c2e}.acp-comment-status-closed{background:#ececef;color:#62626a}.acp-comment-item{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px}.acp-comment-item img{width:42px;height:42px;border-radius:50%;object-fit:cover;background:#eee}.acp-comment-body{min-width:0}.acp-comment-meta{display:flex;align-items:center;gap:9px;flex-wrap:wrap}.acp-comment-meta span{font-size:12px;color:#777}.acp-comment-content{margin-top:7px;color:#2d2d31}.acp-comment-content p:first-child{margin-top:0}.acp-comment-content p:last-child{margin-bottom:0}.acp-comment-actions{display:flex;gap:12px;margin-top:9px}.acp-comment-link{padding:0;border:0;background:transparent;color:#4057cf;font:inherit;font-size:12px;font-weight:700;cursor:pointer}.acp-comment-link.is-danger{color:#b30018}.acp-comment-replies{display:grid;gap:14px;margin:16px 0 0 38px;padding:16px 0 0 16px;border-left:2px solid #eee}.acp-comment-reply-form{grid-template-columns:minmax(0,1fr) auto;align-items:end;margin:16px 0 0 54px;padding:12px}.acp-comment-reply-form textarea{min-height:60px}.acp-comment-closed-note{margin:14px 0 0 54px;color:#777;font-size:13px}

@media(max-width:767px){.acp-pdf-viewer-heading{align-items:flex-start;padding:18px 16px 12px}.acp-pdf-toolbar{align-items:stretch;padding:10px}.acp-pdf-toolbar-group{width:100%;justify-content:center}.acp-pdf-toolbar button{height:36px;padding:0 10px}.acp-pdf-stage{min-height:360px;max-height:70vh;padding:8px}.acp-comments{padding:16px}.acp-comments-heading{display:block}.acp-comments-count{display:inline-flex;margin-top:10px}.acp-comment-form>div{align-items:flex-start;flex-direction:column}.acp-comment-form .acp-button{width:100%}.acp-comment-replies{margin-left:10px;padding-left:10px}.acp-comment-reply-form{grid-template-columns:1fr;margin-left:0}.acp-comment-reply-form .acp-button{width:100%}.acp-comment-closed-note{margin-left:0}}

/* v0.8.1 — visor robusto, cabecera compacta, comentarios y contexto global */
.acp-document-detail-layout{
  min-height:0!important;
  align-items:center!important;
}
.acp-document-detail-cover{
  align-self:center!important;
}
.acp-document-detail-content{
  min-height:0!important;
  height:auto!important;
  justify-content:center!important;
  align-self:center!important;
}
.acp-document-detail-actions{
  margin-top:20px;
}

.acp-pdf-stage canvas[hidden]{display:none!important}
.acp-pdf-stage.has-error{
  min-height:180px;
  background:#f6f6f7;
}
.acp-pdf-stage.has-error + .acp-pdf-error{display:block}

.acp-comment-form,
.acp-comment-reply-form{
  box-sizing:border-box;
  width:100%;
  max-width:none!important;
}
.acp-comment-form textarea,
.acp-comment-reply-form textarea,
.acp-mention-field{
  box-sizing:border-box;
  display:block;
  width:100%!important;
  max-width:none!important;
  min-width:0;
}
.acp-comment-form>div{
  width:100%;
}
.acp-comment-reply-form{
  grid-template-columns:1fr;
}
.acp-comment-reply-form .acp-button{
  justify-self:end;
}

.acp-mention-field{
  position:relative;
}
.acp-mention-list{
  position:absolute;
  z-index:120;
  top:calc(100% + 6px);
  left:0;
  right:0;
  max-height:280px;
  overflow:auto;
  border:1px solid #d8d8dc;
  border-radius:10px;
  padding:6px;
  background:#fff;
  box-shadow:0 14px 34px rgba(0,0,0,.14);
}
.acp-mention-list[hidden]{display:none!important}
.acp-mention-option{
  box-sizing:border-box;
  display:flex;
  width:100%;
  align-items:center;
  gap:10px;
  border:0;
  border-radius:8px;
  padding:9px 10px;
  background:transparent;
  color:#222;
  text-align:left;
  cursor:pointer;
}
.acp-mention-option:hover,
.acp-mention-option:focus,
.acp-mention-option[aria-selected="true"]{
  background:#f2f2f4;
  outline:none;
}
.acp-mention-option img{
  flex:0 0 34px;
  width:34px;
  height:34px;
  border-radius:50%;
  object-fit:cover;
  background:#eee;
}
.acp-mention-option span{
  display:flex;
  min-width:0;
  flex-direction:column;
}
.acp-mention-option strong{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.acp-mention-option small{color:#777}
.acp-mention-empty{padding:12px;color:#777;font-size:13px}

.acp-scope-bar-admin{
  justify-content:space-between;
}
.acp-scope-bar-admin .acp-scope-current{
  max-width:420px;
}
.acp-scope-bar-admin .acp-scope-form select{
  width:158px;
}

@media(max-width:1100px){
  .acp-scope-bar-admin{
    flex-direction:column;
    align-items:stretch;
  }
  .acp-scope-bar-admin .acp-scope-form{
    flex-wrap:wrap;
  }
}

@media(max-width:767px){
  .acp-document-detail-layout{
    align-items:start!important;
  }
  .acp-document-detail-content{
    align-self:start!important;
    justify-content:flex-start!important;
  }
  .acp-comment-reply-form .acp-button{
    width:100%;
  }
  .acp-mention-list{
    max-height:220px;
  }
}


/* v0.8.2 — zoom inicial responsive y formulario de respuesta contenido */
.acp-comment-thread,
.acp-comment-replies,
.acp-comment-reply-form{
  box-sizing:border-box;
  min-width:0;
  max-width:100%;
}
.acp-comment-reply-form{
  width:100%;
  margin:16px 0 0!important;
  overflow:visible;
}
.acp-comment-reply-form textarea,
.acp-comment-reply-form .acp-mention-field{
  box-sizing:border-box;
  width:100%;
  max-width:100%;
  min-width:0;
}
.acp-comment-reply-form .acp-button{
  max-width:100%;
}
@media(max-width:767px){
  .acp-comment-reply-form{
    margin-left:0!important;
    margin-right:0!important;
  }
}

/* Fase 8 — proyectos, hitos y programación */
.acp-programming,.acp-project-detail,.acp-milestone-detail,.acp-project-calendar{margin:24px 0}
.acp-project-front-filters{display:grid;grid-template-columns:minmax(180px,1.15fr) minmax(190px,.95fr) minmax(160px,.75fr) auto auto;gap:10px;align-items:end;margin:0 0 20px;padding:14px;border:1px solid #e4e4e6;border-radius:14px;background:#fafafa}.acp-project-front-filters input,.acp-project-front-filters select{box-sizing:border-box;width:100%;height:44px;border:1px solid #d8d8dc;border-radius:9px;background:#fff;padding:0 12px}.acp-project-front-filters .acp-button{height:44px;display:inline-flex;align-items:center;justify-content:center}
.acp-project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.acp-project-card{display:flex;min-width:0;flex-direction:column;gap:14px;padding:20px;border:1px solid #e3e3e5;border-radius:16px;background:#fff;box-shadow:0 10px 28px rgba(17,17,17,.05)}.acp-project-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.acp-project-card h3{margin:0;font-size:22px;line-height:1.15}.acp-project-card p{margin:0;color:#666;line-height:1.55}.acp-project-status,.acp-milestone-status,.acp-milestone-type{display:inline-flex;align-items:center;min-height:26px;padding:4px 9px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.03em}.acp-project-status.is-planning{background:#edf2f7;color:#354052}.acp-project-status.is-active{background:#e8f7ed;color:#12642d}.acp-project-status.is-paused{background:#fff2d8;color:#825200}.acp-project-status.is-completed{background:#111;color:#fff}.acp-project-status.is-cancelled{background:#f2f2f4;color:#777}.acp-project-scope{overflow:hidden;color:#777;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.acp-project-progress{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px}.acp-project-progress>div{height:8px;overflow:hidden;border-radius:999px;background:#ececef}.acp-project-progress>div span{display:block;height:100%;border-radius:inherit;background:#e3001e}.acp-project-progress strong{font-size:13px}.acp-project-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#777;font-size:12px}.acp-project-card>.acp-button{align-self:flex-start;margin-top:auto}
.acp-back-link{display:inline-flex;margin:0 0 18px;color:#222;font-weight:700;text-decoration:none}.acp-project-detail-header{display:grid;grid-template-columns:minmax(0,1fr) 150px;gap:24px;align-items:center;padding:26px;border:1px solid #e3e3e5;border-radius:18px;background:#fff}.acp-project-detail-header h1,.acp-milestone-detail header h1{margin:10px 0 8px;font-size:clamp(30px,4vw,48px);line-height:1.05}.acp-project-detail-header p{max-width:850px;margin:0;color:#666}.acp-project-detail-meta{display:flex;flex-wrap:wrap;gap:16px;margin-top:16px;color:#666;font-size:13px}.acp-project-progress-circle{display:grid;place-items:center;width:130px;height:130px;border:10px solid #f0f0f1;border-top-color:#e3001e;border-radius:50%;text-align:center}.acp-project-progress-circle strong{font-size:28px}.acp-project-progress-circle span{font-size:11px;color:#777}.acp-project-description,.acp-project-resources,.acp-project-timeline,.acp-milestone-resources,.acp-milestone-locked{margin-top:20px;padding:24px;border:1px solid #e3e3e5;border-radius:16px;background:#fff}.acp-project-description p:first-child{margin-top:0}.acp-project-description p:last-child{margin-bottom:0}
.acp-project-document-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.acp-project-document-list a{display:flex;min-width:0;flex-direction:column;gap:4px;padding:14px;border:1px solid #dedee1;border-radius:12px;color:#111;text-decoration:none}.acp-project-document-list a:hover{border-color:#e3001e}.acp-project-document-list span{color:#e3001e;font-size:10px;font-weight:800;text-transform:uppercase}.acp-project-document-list strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acp-milestone-list{position:relative;display:grid;gap:14px;margin-top:18px}.acp-milestone-list:before{position:absolute;top:10px;bottom:10px;left:13px;width:2px;background:#e4e4e6;content:""}.acp-milestone-card{position:relative;display:grid;grid-template-columns:28px minmax(0,1fr);gap:14px}.acp-milestone-marker{position:relative;z-index:1;width:16px;height:16px;margin:15px 0 0 6px;border:4px solid #fff;border-radius:50%;background:#9a9aa1;box-shadow:0 0 0 2px #ddd}.acp-milestone-card.is-completed .acp-milestone-marker{background:#111;box-shadow:0 0 0 2px #111}.acp-milestone-card.is-active .acp-milestone-marker,.acp-milestone-card.is-in_progress .acp-milestone-marker{background:#e3001e;box-shadow:0 0 0 2px #e3001e}.acp-milestone-content{min-width:0;padding:16px 18px;border:1px solid #e3e3e5;border-radius:14px;background:#fff}.acp-milestone-card-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.acp-milestone-type{background:#f2f2f4;color:#5a5a63}.acp-milestone-status.is-pending{background:#edf2f7;color:#354052}.acp-milestone-status.is-blocked{background:#fde9ec;color:#a10018}.acp-milestone-status.is-available{background:#eaf2ff;color:#164f9c}.acp-milestone-status.is-in_progress{background:#fff0d7;color:#8a5600}.acp-milestone-status.is-completed{background:#e8f7ed;color:#12642d}.acp-milestone-status.is-delayed{background:#fff2d8;color:#825200}.acp-milestone-status.is-cancelled{background:#f2f2f4;color:#777}.acp-milestone-content h3{margin:10px 0 6px;font-size:20px}.acp-milestone-content p{margin:0 0 12px;color:#666}.acp-milestone-meta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:12px;color:#777;font-size:12px}.acp-milestone-reason{margin:0 0 12px;padding:10px 12px;border-left:3px solid #e3001e;background:#fff5f6;color:#7c1623;font-size:13px}.acp-milestone-content .acp-button{display:inline-flex}
.acp-milestone-detail>header{padding:24px;border:1px solid #e3e3e5;border-radius:16px;background:#fff}.acp-milestone-detail>header p{margin:0;color:#666}.acp-milestone-locked{border-color:#f0c2c9;background:#fff8f9}.acp-milestone-locked strong{color:#b4001b}.acp-resource-links{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.acp-resource-links a{padding:10px 13px;border:1px solid #ddd;border-radius:9px;color:#111;text-decoration:none}.acp-resource-links a:hover{border-color:#e3001e;color:#e3001e}
.acp-project-calendar{padding:22px;border:1px solid #e3e3e5;border-radius:16px;background:#fff}.acp-project-calendar-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.acp-project-calendar-heading h2{margin:4px 0 0}.acp-calendar-nav{display:inline-grid;width:38px;height:38px;margin-left:6px;place-items:center;border:1px solid #ddd;border-radius:9px;color:#111;text-decoration:none}.acp-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.acp-calendar-weekdays>div{padding:8px;color:#777;font-size:11px;font-weight:800;text-align:center;text-transform:uppercase}.acp-calendar-day{min-height:118px;padding:8px;border-top:1px solid #eee;border-left:1px solid #eee;background:#fff}.acp-calendar-day:nth-child(7n){border-right:1px solid #eee}.acp-calendar-day:nth-last-child(-n+7){border-bottom:1px solid #eee}.acp-calendar-day.is-outside{background:#fafafa;color:#aaa}.acp-calendar-day.is-today{box-shadow:inset 0 0 0 2px #e3001e}.acp-calendar-date{display:block;margin-bottom:7px;font-size:12px;font-weight:800}.acp-calendar-event{display:block;margin:0 0 5px;padding:6px;border-radius:7px;background:#f2f2f4;color:#111;font-size:11px;line-height:1.25;text-decoration:none}.acp-calendar-event small{display:block;color:#e3001e;font-size:8px;font-weight:800;text-transform:uppercase}
@media(max-width:1100px){.acp-project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.acp-project-front-filters{grid-template-columns:1fr 1fr}.acp-project-front-filters .acp-button{width:100%}.acp-project-document-list{grid-template-columns:repeat(2,minmax(0,1fr))}.acp-calendar-day{min-height:95px}}
@media(max-width:767px){.acp-project-grid,.acp-project-document-list,.acp-project-front-filters{grid-template-columns:1fr}.acp-project-detail-header{grid-template-columns:1fr}.acp-project-progress-circle{width:100px;height:100px}.acp-project-meta,.acp-project-detail-meta{align-items:flex-start;flex-direction:column}.acp-project-calendar{overflow-x:auto}.acp-calendar-weekdays,.acp-calendar-days{min-width:720px}.acp-project-calendar-heading{position:sticky;left:0}.acp-milestone-card-top{align-items:flex-start;flex-direction:column}}


/* v0.9.1 — gestión de hitos desde el portal */
.acp-milestone-status-control{display:flex;align-items:end;gap:10px;flex-wrap:wrap;margin:14px 0}.acp-milestone-status-control label{display:grid;gap:5px;min-width:210px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.03em}.acp-milestone-status-control select{box-sizing:border-box;width:100%;height:42px;border:1px solid #d8d8dc;border-radius:8px;background:#fff;padding:0 10px}.acp-milestone-status-control .acp-button{height:42px}.acp-calendar-event.is-project{border-left-color:#111;background:#e8e8ea}.acp-calendar-event.is-project_end{border-left-color:#e3001e;background:#fff1f3}
@media(max-width:1100px){.acp-project-front-filters{grid-template-columns:repeat(3,minmax(150px,1fr))}.acp-project-front-filters .acp-button{width:100%}}
@media(max-width:767px){.acp-milestone-status-control{align-items:stretch;flex-direction:column}.acp-milestone-status-control label{min-width:0}.acp-milestone-status-control .acp-button{width:100%}}

/* v0.9.2 — filtros y controles de estado */
.acp-project-front-filters{align-items:stretch}
.acp-project-front-filters>input,
.acp-project-front-filters>select,
.acp-project-front-filters>.acp-button{box-sizing:border-box;height:44px!important;min-height:44px;margin:0!important;align-self:stretch}
.acp-project-front-filters>.acp-button{display:inline-flex!important;align-items:center!important;justify-content:center!important;line-height:1!important;padding:0 18px!important;white-space:nowrap}
.acp-project-front-filters select,
.acp-milestone-status-control select,
.acp-project-status-control select{
  appearance:none;
  -webkit-appearance:none;
  padding-right:38px!important;
  background-color:#fff;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2332353b' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-size:16px 16px;
}
.acp-project-status-control{display:flex;align-items:end;gap:10px;flex-wrap:wrap;margin:18px 0 0}
.acp-project-status-control label{display:grid;gap:5px;min-width:250px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.03em}
.acp-project-status-control select{box-sizing:border-box;width:100%;height:42px;border:1px solid #d8d8dc;border-radius:8px;padding:0 38px 0 10px}
.acp-project-status-control .acp-button{box-sizing:border-box;height:42px;margin:0;display:inline-flex;align-items:center;justify-content:center}
@media(max-width:767px){
  .acp-project-status-control{align-items:stretch;flex-direction:column}
  .acp-project-status-control label{min-width:0}
  .acp-project-status-control .acp-button{width:100%}
}


/* v0.9.3 — alineación uniforme de los controles de estado */
.acp-project-status-control,
.acp-milestone-status-control{
  align-items:end!important;
}

.acp-project-status-control label,
.acp-milestone-status-control label{
  box-sizing:border-box;
  margin:0!important;
}

.acp-project-status-control select,
.acp-milestone-status-control select{
  box-sizing:border-box;
  height:44px!important;
  min-height:44px!important;
  margin:0!important;
  line-height:1.2!important;
}

.acp-project-status-control .acp-button,
.acp-milestone-status-control .acp-button{
  box-sizing:border-box;
  height:44px!important;
  min-height:44px!important;
  margin:0!important;
  padding:0 20px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  align-self:end!important;
  line-height:1!important;
  white-space:nowrap;
}

@media (min-width:768px){
  .acp-project-status-control{
    display:grid!important;
    grid-template-columns:minmax(250px,1fr) auto;
    gap:10px;
    align-items:end!important;
  }
}


/* v0.9.4 — ancho compacto del selector de estado del proyecto */
@media (min-width:768px){
  .acp-project-status-control{
    display:grid!important;
    grid-template-columns:minmax(250px,25%) auto!important;
    justify-content:start!important;
    width:100%;
    max-width:100%;
    align-items:end!important;
  }

  .acp-project-status-control label{
    width:100%;
    max-width:none;
  }

  .acp-project-status-control select{
    width:100%!important;
    max-width:100%!important;
  }
}


/* Fase 9 — centro de notificaciones */
.acp-notification-center{position:relative;display:flex;align-items:center}
.acp-notification-toggle{position:relative;width:42px;height:42px;border:1px solid #dedede;border-radius:12px;background:#fff;color:#161616;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.acp-notification-toggle:hover,.acp-notification-toggle:focus-visible{border-color:#E3001E;color:#E3001E}
.acp-notification-toggle svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.acp-notification-count{position:absolute;top:-6px;right:-6px;min-width:19px;height:19px;padding:0 5px;border-radius:999px;background:#E3001E;color:#fff;font-size:10px;font-weight:800;line-height:19px;text-align:center;box-shadow:0 0 0 2px #fff}
.acp-notification-panel{position:absolute;z-index:1200;top:calc(100% + 12px);right:0;width:min(390px,calc(100vw - 28px));max-height:520px;background:#fff;border:1px solid #dedede;border-radius:16px;box-shadow:0 22px 60px rgba(0,0,0,.18);overflow:hidden}
.acp-notification-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid #ececec}
.acp-notification-panel-header strong{font-size:16px}
.acp-notification-panel-header button{border:0;background:transparent;color:#E3001E;font-size:12px;font-weight:700;cursor:pointer}
.acp-notification-list{max-height:440px;overflow:auto}
.acp-notification-item{display:grid;grid-template-columns:9px 1fr;gap:11px;padding:15px 18px;color:#181818;text-decoration:none;border-bottom:1px solid #f0f0f0;background:#fff}
.acp-notification-item:hover{background:#fafafa}
.acp-notification-item.is-unread{background:#fff8f9}
.acp-notification-dot{width:8px;height:8px;border-radius:50%;background:#d7d7d7;margin-top:6px}
.acp-notification-item.is-unread .acp-notification-dot{background:#E3001E}
.acp-notification-copy{display:flex;flex-direction:column;gap:4px;min-width:0}
.acp-notification-copy strong{font-size:14px;line-height:1.35}
.acp-notification-copy small{color:#666;line-height:1.4}
.acp-notification-copy time{color:#969696;font-size:11px}
.acp-notification-empty,.acp-notification-loading{padding:28px 18px;text-align:center;color:#777}
.acp-nav-zone-right{gap:10px}
@media(max-width:767px){
  .acp-notification-panel{position:fixed;top:76px;right:14px;left:14px;width:auto;max-height:calc(100vh - 96px)}
  .acp-notification-list{max-height:calc(100vh - 160px)}
}


/* v1.0.1 — campana estable y estados de notificación en tiempo real */
.acp-notification-center{overflow:visible!important;flex:0 0 auto;z-index:20}
.acp-notification-toggle{box-sizing:border-box!important;flex:0 0 44px!important;width:44px!important;min-width:44px!important;max-width:44px!important;height:44px!important;min-height:44px!important;padding:0!important;margin:0!important;overflow:visible!important;border-radius:12px!important;line-height:1!important;z-index:2}
.acp-notification-icon{display:flex!important;align-items:center!important;justify-content:center!important;width:22px!important;height:22px!important;color:#171717!important;pointer-events:none}
.acp-notification-toggle:hover .acp-notification-icon,.acp-notification-toggle:focus-visible .acp-notification-icon{color:#E3001E!important}
.acp-notification-icon svg{display:block!important;visibility:visible!important;opacity:1!important;width:22px!important;height:22px!important;min-width:22px!important;max-width:22px!important;fill:currentColor!important;stroke:none!important;overflow:visible!important}
.acp-notification-icon svg path{display:block!important;fill:currentColor!important;stroke:none!important}
.acp-notification-count{box-sizing:border-box!important;display:flex;align-items:center;justify-content:center;top:-7px!important;right:-7px!important;z-index:5!important;min-width:21px!important;height:21px!important;padding:0 5px!important;border-radius:999px!important;background:#E3001E!important;color:#fff!important;font-size:10px!important;font-weight:800!important;line-height:1!important;overflow:visible!important}
.acp-notification-count[hidden]{display:none!important}
.acp-comment-thread.is-notification-target{outline:3px solid rgba(227,0,30,.3);box-shadow:0 0 0 7px rgba(227,0,30,.08);transition:outline-color .25s ease,box-shadow .25s ease}


/* v1.0.2 — ajustes de menciones, navegación, filtros, notificaciones y acceso */
.acp-login-form,.acp-login-form .acp-form-field,.acp-login-form .acp-form-field>input,.acp-login-form .acp-password-field{box-sizing:border-box;width:100%;max-width:none}
.acp-password-strength{margin-top:7px;padding:7px 10px;border-radius:7px;background:#eee;color:#555;font-size:12px;font-weight:700}
.acp-password-strength[data-score="1"]{background:#fde7ea;color:#9d1b1b}.acp-password-strength[data-score="2"]{background:#fff2db;color:#8a5700}.acp-password-strength[data-score="3"]{background:#fff7cf;color:#715d00}.acp-password-strength[data-score="4"],.acp-password-strength[data-score="5"]{background:#e7f7ed;color:#176b35}
.acp-password-help{margin:4px 0 0;color:#666;font-size:12px;line-height:1.5}
.acp-project-filter-toggle{display:none;box-sizing:border-box;width:100%;min-height:44px;margin:0 0 10px;border:1px solid #ddd;border-radius:10px;padding:0 14px;background:#fff;color:#171717;font-weight:800;align-items:center;justify-content:space-between;cursor:pointer}
.acp-project-filter-toggle svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;transition:transform .2s ease}.acp-project-filter-toggle[aria-expanded="true"] svg{transform:rotate(180deg)}.acp-project-filter-toggle.is-active{border-color:var(--acp-primary);color:var(--acp-primary)}
#acp-project-calendar{scroll-margin-top:110px}
.acp-notification-row{position:relative;display:grid;grid-template-columns:minmax(0,1fr) 42px;border-bottom:1px solid #f0f0f0;background:#fff}.acp-notification-row.is-unread{background:#fff8f9}.acp-notification-row .acp-notification-item{border-bottom:0;background:transparent;min-width:0}.acp-notification-delete{align-self:center;justify-self:center;display:grid;place-items:center;width:34px;height:34px;border:0;border-radius:8px;background:transparent;color:#8a8a8a;cursor:pointer}.acp-notification-delete:hover,.acp-notification-delete:focus-visible{background:#f3f3f3;color:#E3001E}.acp-notification-delete svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:1000px){.acp-nav-zone-right{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:10px!important}.acp-nav-toggle,.acp-notification-toggle{box-sizing:border-box!important;flex:0 0 44px!important;width:44px!important;min-width:44px!important;max-width:44px!important;height:44px!important;min-height:44px!important;margin:0!important;border-radius:12px!important;align-self:center!important}.acp-nav-toggle{padding:0 11px!important}}
@media(max-width:767px){.acp-project-filter-toggle{display:flex}.acp-project-front-filters[data-acp-programming-filters]{display:none!important}.acp-project-front-filters[data-acp-programming-filters].is-open{display:grid!important;grid-template-columns:1fr!important}.acp-project-front-filters[data-acp-programming-filters] .acp-button{width:100%}.acp-notification-row{grid-template-columns:minmax(0,1fr) 46px}}
