/* =========================================================
   Buzón Único Digital — CSS consolidado y depurado
   ========================================================= */

/* ---------- 1) Tokens / Variables ---------- */
:root{
  /* Institucional */
  --orange:#e67425;   /* acento */
  --green:#408740;
  --pink:#df1783;
  --blue:#0b3b60;     /* primario corporativo */
  --navy:#27323f;     /* texto principal */

  /* Neutros */
  --bg:#f6f8fb;
  --surface:#ffffff;
  --muted:#6b7785;

  /* Semánticos */
  --success: var(--green);
  --danger:#dc3545;

  /* Alias (compat con tu CSS anterior) */
  --navy-deep: var(--navy);
  --blue-primary-subtle: var(--navy);
  --blue-accent-subtle: var(--navy);
  --blue-light-subtle:#eef1f5;

  --gray-dark:#333;
  --gray-medium:#555;
  --gray-light:#d6dbe3;
  --gray-bg: var(--bg);

  /* Uso UI */
  --color-primario: var(--blue);
  --color-acento:   var(--orange);
  --color-texto-principal: var(--navy);
  --color-texto-secundario: var(--muted);
  --color-fondo: var(--bg);
  --color-superficie: var(--surface);
  --color-borde: var(--gray-light);
  --color-flecha: var(--navy);

  /* Layout + efectos */
  --ring: color-mix(in oklab, var(--blue) 40%, transparent);
  --shadow: 0 8px 24px rgba(13,38,76,.10);
  --radius:12px;
  --sombra-suave:0 3px 10px rgba(39,50,63,.08);
  --sombra-profunda:0 5px 18px rgba(39,50,63,.12);

  /* Topbar real */
  --topbar-h: calc(90px + env(safe-area-inset-top,0px));

  /* Carrusel */
  --ring-size: clamp(260px, min(56vw, 60vh), 640px);
  --rim-gap:  clamp(86px, 12vw, 210px);
  --item-size: calc(var(--ring-size) - var(--rim-gap));
  --arrow-between: clamp(22px, 4vw, 44px);
  --arrow-y: 50%;
  --side-scale: .85;
}

/* ---------- 2) Reset / Base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ height:100%; margin:0; padding:0; }
body{
  font-family:'Poppins',system-ui,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--color-texto-principal);
  line-height:1.7;
  min-height:100dvh;
  background:var(--color-fondo);
}
.hidden{ display:none !important; }

/* ---------- 3) Layout app ---------- */
.buzon-app{
  min-height:100dvh;
  display:grid;
  grid-template-rows:auto 1fr;
}

/* ---------- 4) Topbar ---------- */
.app-topbar{
  position:sticky; top:0; z-index:1001;
  background:#f6f8fb;
  color:#27323f;
  border-bottom:1px solid #e0e4e9;
}
.app-topbar .topbar-inner{
  height:var(--topbar-h);
  padding:max(8px,env(safe-area-inset-top,0px)) 16px 8px;
  display:flex; align-items:center; justify-content:space-between; gap:15px;
  transition: all .3s ease-in-out;
}
.app-topbar .brand{
  display:flex; align-items:center;
  color:#27323f; text-decoration:none; font-weight:700; letter-spacing:.2px;
  font-size:1.2rem; transition:opacity .2s ease;
}
.app-topbar .brand:hover{ opacity:.8; }
.topbar-logo{ height:80px; width:auto; display:block; margin-right:10px; }
.menu-btn{
  width:40px; height:40px; border-radius:8px;
  border:1px solid rgba(39,50,63,.2);
  background:rgba(39,50,63,.08);
  display:grid; place-items:center; cursor:pointer;
}
.menu-btn-bar{ display:block; width:16px; height:2px; background:#27323f; margin:2px 0; }
/* =========================================================
   🌊 Header con burbujas — versión compacta (como tu ejemplo)
   Adaptado a #main-header-bar y a tus variables actuales
   ========================================================= */

/* 1) Gradiente de fondo igual al de tu snippet */
:root{
  --grad:
    radial-gradient(1200px 400px at 10% -10%, color-mix(in oklab, var(--color-primario) 18%, #fff) 0%, transparent 60%),
    radial-gradient(900px 380px at 90% 0%, color-mix(in oklab, var(--pink, #df1783) 10%, #fff) 0%, transparent 55%),
    linear-gradient(180deg,#fff 0%,#f7f9fc 100%);
}

/* 2) Contenedor del header */
#main-header-bar{
  position: relative;
  overflow: hidden;
  background: var(--grad);         /* ← igual que tu ejemplo */
  border-bottom: 1px solid var(--bd-hero, #e9eef5);
  min-height: 220px;
}

/* 3) Burbujas (antes estaban en .hero, ahora en #main-header-bar) */
#main-header-bar::before,
#main-header-bar::after{
  content:"";
  position:absolute;
  inset:auto;
  border-radius:50%;
  pointer-events:none;
  filter:blur(6px);
  opacity:.55;
}

/* Burbuja azul (sup-izq) */
#main-header-bar::before{
  width:38vmin; height:38vmin; left:6%; top:6%;
  background:radial-gradient(circle, rgba(11,59,96,.10) 0 60%, transparent 62%);
  animation:bubbleA 3s ease-in-out infinite alternate;
}

/* Burbuja rosa (sup-der) */
#main-header-bar::after{
  width:32vmin; height:32vmin; right:8%; top:10%;
  background:radial-gradient(circle, rgba(248,84,113,.10) 0 60%, transparent 62%);
  animation:bubbleB 6s ease-in-out infinite alternate;
}

/* Tercera burbuja (abajo-centro). 
   Usamos un hijo real para mantener compatibilidad: 
   añade este div en tu HTML dentro del header si no existe. */
#main-header-bar .bubble-c{
  position:absolute;
  width:26vmin; height:26vmin;
  left:48%; bottom:-4%; transform:translateX(-50%);
  border-radius:50%; filter:blur(6px);
  background:radial-gradient(circle, rgba(14,160,132,.10) 0 60%, transparent 62%);
  animation:bubbleC 7s ease-in-out infinite alternate;
  pointer-events:none;
  z-index:0;
}

/* 4) Animaciones */
@keyframes bubbleA{ to{ transform:translate(12vmin,7vmin) scale(1.05) } }
@keyframes bubbleB{ to{ transform:translate(-10vmin,9vmin) scale(1.04) } }
@keyframes bubbleC{ to{ transform:translate(6vmin,-10vmin) scale(1.06) } }

/* 5) Respeta preferencias */
@media (prefers-reduced-motion:reduce){
  #main-header-bar::before,
  #main-header-bar::after,
  #main-header-bar .bubble-c{ animation:none !important }
}


/* Header textual */
.header-bar{
  background:#f6f8fb !important; color:#27323f !important;
  border-bottom:3px solid #27323f !important;
  padding:clamp(12px,1.6vw,18px) clamp(16px,4vw,36px);
  text-align:center; margin-bottom:3px;
}
.header-bar h1,.header-bar h2{
  margin:0; font-size:clamp(1.6rem,4.8vw,2.3rem);
  font-weight:700; letter-spacing:.3px; color:#27323f !important;
}
.header-bar h1::after,.header-bar h2::after{
  content:""; display:block; width:40px; height:2px; margin:6px auto 0; background:#27323f; border-radius:2px;
}
.header-bar .header-subtitle{
  margin-top:4px; font-weight:400; font-size:clamp(.9rem,3.2vw,1.1rem); color:rgba(39,50,63,.85);
}

/* Título colapsado en topbar */
.collapsed-header-title{
  display:flex !important; align-items:center; gap:8px; margin-left:15px; flex-grow:1; overflow:hidden;
  opacity:0; transform:translateY(-6px); pointer-events:none;
  transition:opacity .28s ease, transform .28s ease;
}
.collapsed-header-title .topbar-title{
  margin:0; font-weight:700; color:#27323f; font-size:clamp(1rem,2.6vw,1.25rem); letter-spacing:.2px;
}
.collapsed-header-title .header-subtitle{
  margin:0; font-size:.8rem; color:rgba(39,50,63,.8);
}
body.scrolled .collapsed-header-title{ opacity:1; transform:translateY(0); pointer-events:auto; }
body.scrolled #main-header-bar{ opacity:0; transform:translateY(-8px) scale(.98); padding-block:8px !important; }
body.scrolled .app-topbar .topbar-inner { padding-block: max(8px, env(safe-area-inset-top, 0px)); }
[id] { scroll-margin-top: calc(var(--topbar-h) + 12px); }

/* ---------- 6) Selector / Carrusel ---------- */
#selector-container{
  width:100%; margin:0; background:var(--color-superficie);
  display:grid; grid-template-rows:auto auto auto;
}
.carousel-wrapper{
  display:grid; place-items:start center; width:100%;
  padding-block: clamp(6px,1.2vw,12px);
  perspective:1200px;
}
.carousel-container{
  position:relative; display:grid; place-items:center;
  width:min(100%,1100px);
  min-height:var(--ring-size);
  margin:0 auto;
  padding-inline: calc(var(--arrow-between) + clamp(20px, 4vw, 30px));
  overflow:visible;
  isolation:isolate; /* control del z-index interno */
}

/* Anillo */
.carousel{
  position:relative;
  width:var(--ring-size); height:var(--ring-size);
  transform-style:preserve-3d;
  transition:transform .7s cubic-bezier(.77,0,.175,1);
  will-change:transform;
}
.carousel-items{
  position:absolute; inset:0;
  transform-style:preserve-3d;
  pointer-events:none;
}

/* Faces */
.carousel-item{
  position:absolute;
  width:var(--item-size); height:var(--item-size);
  top:  calc((var(--ring-size) - var(--item-size)) / 2);
  left: calc((var(--ring-size) - var(--item-size)) / 2);
  border-radius:50%; background:transparent; border:0;
  backface-visibility:hidden; transform-origin:50% 50%;
  z-index:1; pointer-events:auto;
}
.carousel-item .carousel-inner-item{
  width:100%; height:100%; border-radius:50%;
  background:#fff; border:2px solid var(--color-acento);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  box-shadow:var(--sombra-suave);
  will-change:transform;
  transition:transform .25s ease, box-shadow .25s ease, opacity .25s ease, filter .25s ease, border-color .25s ease;
}
.carousel-item i{
  font-size: clamp(2.6rem, 9vw, 4.8rem);
  color:var(--color-primario);
  transition:transform .25s ease;
}

/* Activo */
.carousel-item.active{ z-index:5; }
.carousel-item.active .carousel-inner-item{
  transform: translateZ(8px) scale(1.12) !important;
  border-width:4px; border-color:var(--color-primario);
  box-shadow:0 0 0 4px rgba(39,50,63,.12), 0 14px 34px rgba(0,0,0,.08);
}
.carousel-item.active .carousel-inner-item i{
  font-size: clamp(3.4rem, 10.5vw, 6.2rem) !important; color:var(--color-primario);
}
.carousel-item.active .carousel-inner-item::before{
  content:""; position:absolute; inset: clamp(6px, 1.4vw, 12px);
  border-radius:50%; background:var(--color-superficie); z-index:0; pointer-events:none;
}

/* Vecinos */
.carousel-item:not(.active) .carousel-inner-item{
  opacity:1 !important; transform: translateZ(0) scale(var(--side-scale,.85)) !important;
  border-color: transparent; box-shadow: inset 0 0 0 2px rgba(0,0,0,.08);
}
.carousel-item:not(.active) .carousel-inner-item i{ color:var(--color-borde); opacity:.9; }
.carousel-item .carousel-inner-item > *{ position:relative; z-index:1; }

/* Texto dentro del disco */
.carousel-inner-item :is(.carousel-label, .carousel-title, span, p){
  display:block; max-width:82%; margin:.35rem auto 0; text-align:center;
  white-space:normal; overflow-wrap:anywhere; word-break:break-word; hyphens:auto;
  line-height:1.2;
}

/* Flechas */
.nav-arrow{
  position:absolute; top:var(--arrow-y); transform:translateY(-50%);
  z-index:999; display:grid; place-items:center; cursor:pointer;
  width:clamp(36px,7vw,48px); height:clamp(36px,7vw,48px);
  font-size:clamp(.9rem,3vw,1.3rem);
  color:#27323f; background:#fff; border:1px solid var(--color-borde);
  border-radius:999px;
  box-shadow:0 6px 20px rgba(0,0,0,.08), 0 0 0 6px #fff;
  transition:transform .2s ease, color .2s ease, background .2s ease, box-shadow .2s ease;
  touch-action:manipulation;
}
.nav-arrow:hover{
  background:var(--color-fondo); color:var(--color-acento);
  transform:translateY(-50%) scale(1.1);
}
#prev-btn{ left:  calc(50% - (var(--item-size)/2) - var(--arrow-between)); }
#next-btn{ right: calc(50% - (var(--item-size)/2) - var(--arrow-between)); }

/* Título + CTA */
.carousel-title-container,.button-container{ padding:8px clamp(12px,4vw,28px); text-align:center; }
#carousel-item-title{
  margin:0; color:var(--color-primario); font-weight:600;
  font-size:clamp(.95rem, 2.7vw, 1.1rem); padding-top:6px; text-wrap:balance;
}
.button-container{ padding-bottom:clamp(8px,1.2vw,12px); }

/* ---------- 7) Botones ---------- */
.submit-btn{
  display:block; width:100%; padding:14px 16px;
  background:#27323f; color:#fff; border:0; border-radius:10px;
  font-size:1rem; font-weight:600; cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  box-shadow:0 4px 14px rgba(39,50,63,.18); letter-spacing:.1px; text-transform:capitalize;
}
.submit-btn:hover{ background:#1f2a36; transform:translateY(-1px); }
.submit-btn:disabled{ background:#27323f; opacity:.8; cursor:wait; }
.back-btn{
  background:transparent; border:none; color:var(--color-primario); font-weight:500; cursor:pointer;
  margin-bottom:20px; font-size:.98rem; padding:5px; display:inline-flex; align-items:center; gap:8px; transition:color .2s ease;
}
.back-btn:hover{ color:var(--color-acento); }

/* ---------- 8) Formularios / Genéricos ---------- */
.content-padding{ padding:24px clamp(16px,4vw,36px) 32px; }
.form-section{ margin-bottom:24px; }
.form-group{ margin-bottom:18px; }
label{
  color:var(--color-texto-principal); font-weight:500; display:block; margin-bottom:8px; font-size:.98rem; letter-spacing:.1px;
}
.input-with-icon{ position:relative; display:flex; align-items:center; }
.input-with-icon i{
  position:absolute; left:14px; color:var(--color-texto-secundario); opacity:.5; transition:color .2s ease, opacity .2s ease; z-index:1; font-size:1rem;
}
.input-with-icon input{ padding-left:40px !important; }
input,select,textarea{
  width:100%; padding:12px 14px; border:1px solid var(--color-borde); border-radius:8px;
  background:#fff; font-family:'Poppins',sans-serif; font-size:.98rem;
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease; color:var(--navy);
}
input:hover,select:hover,textarea:hover{ border-color:var(--color-texto-secundario); }
input:focus,select:focus,textarea:focus{
  border-color:#27323f; box-shadow:0 0 0 3px rgba(39,50,63,.15); outline:none;
}

h3{
  color:var(--color-primario); font-size:clamp(1.1rem,3.2vw,1.3rem);
  margin:20px 0 16px; padding-bottom:10px; border-bottom:1px solid var(--color-borde);
  display:flex; align-items:center; gap:10px; font-weight:600;
}
.form-step-number{
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; background-color:var(--color-acento); color:#fff;
  border-radius:50%; font-size:.95rem; font-weight:600; margin-right:10px; box-shadow:0 2px 6px rgba(58,124,200,.2);
}
small{ color:var(--color-texto-secundario); font-size:.88rem; margin-top:4px; }

/* Upload */
.file-drop-area{
  position:relative; border:1px dashed var(--color-borde); border-radius:8px;
  padding:16px; text-align:center; background:#fff; cursor:pointer;
  transition:border-color .2s ease, background-color .2s ease, transform .2s ease;
}
.file-drop-area:hover{ border-color:#27323f; background:#eef1f5; }
.file-drop-area.is-dragging{ background:#eef1f5; border-color:#27323f; border-style:solid; transform:scale(1.02); }
.file-drop-area input[type="file"]{ position:absolute; inset:0; opacity:0; cursor:pointer; z-index:2; }
.file-drop-message{ display:flex; flex-direction:column; align-items:center; color:var(--color-texto-secundario); transition:all .2s ease-in-out; }
.file-drop-message i{ font-size:clamp(1.3rem,4vw,1.8rem); color:#27323f; margin-bottom:6px; }
#file-name{ margin-top:5px; font-size:.85rem; color:var(--color-texto-principal); font-weight:500; }

.file-preview{
  margin-top:10px; border-radius:8px; overflow:hidden; border:1px solid var(--color-borde);
  background:#fff; padding:10px; box-shadow:var(--sombra-suave);
}
.file-preview-header{ display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
#file-card-name{ font-size:.95rem; color:var(--color-texto-principal); }
.remove-file-btn{ background:transparent; border:0; color:var(--color-texto-secundario); font-size:1rem; cursor:pointer; transition:color .2s ease; }
.remove-file-btn:hover{ color:var(--danger); }
.file-preview-content iframe,.file-preview-content img{
  width:100%; height:300px; border:none; border-radius:8px; object-fit:contain; box-shadow:var(--sombra-suave);
}

/* ---------- 9) Sección genérica ---------- */
.section{ padding:3rem 1.5rem; background:var(--color-fondo); text-align:center; }
.section h2{ font-size:clamp(1.3rem,4.4vw,2.1rem); font-weight:700; color:var(--color-texto-principal); margin-bottom:1rem; }
.btn-primary{
  display:inline-block; padding:12px 20px; background:var(--color-acento); color:#fff; border:0; border-radius:8px;
  font-size:.98rem; font-weight:600; cursor:pointer; transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  box-shadow:0 3px 10px rgba(58,124,200,.2); letter-spacing:.1px; text-transform:capitalize;
}
.btn-primary:hover{ background:var(--blue-primary-subtle); box-shadow:0 5px 15px rgba(26,90,143,.25); transform:translateY(-1px); }

/* ---------- 10) Modal ---------- */
.skin-modal{ position:fixed; inset:0; display:none; z-index:1002; }
.skin-modal[aria-hidden="false"]{ display:block; }
.skin-modal__backdrop{ position:absolute; inset:0; background:rgba(10,25,41,.3); }
.skin-modal__dialog{
  position:relative; width:min(640px,92vw); max-height:85dvh; margin:6dvh auto;
  background:var(--color-superficie); border:1px solid var(--color-borde); border-radius:12px;
  box-shadow:var(--sombra-profunda); overflow:hidden; outline:none; display:flex; flex-direction:column;
}
.skin-modal__header{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; border-bottom:1px solid var(--color-borde); background:var(--color-superficie); flex-shrink:0;
}
.skin-modal__header h3{ margin:0; font-size:clamp(.95rem,3vw,1.15rem); border:0; padding:0; color:var(--color-primario); font-weight:600; }
.skin-modal__close{ background:transparent; border:0; cursor:pointer; color:var(--color-texto-secundario); font-size:.9rem; }
.skin-modal__close:hover{ color:var(--color-acento); }
.skin-modal__body{ padding:18px; overflow:auto; color:var(--color-texto-secundario); flex-grow:1; }
.skin-modal__meta{ display:grid; gap:10px; margin:10px 0 6px; }
.skin-modal__meta .meta-item{
  display:grid; grid-template-columns:20px 1fr; gap:10px; align-items:start;
  border:1px solid var(--color-borde); border-radius:8px; padding:10px 12px; background:#fff;
}
.skin-modal__meta .meta-item i{ color:var(--color-acento); margin-top:2px; font-size:.95rem; }
.skin-modal__hint{ margin-top:8px; display:grid; grid-template-columns:20px 1fr; gap:8px; align-items:start; color:var(--color-texto-secundario); }
.skin-modal__footer{ display:flex; justify-content:flex-end; gap:8px; border-top:1px solid var(--color-borde); padding:10px 14px; background:var(--color-superficie); flex-shrink:0; }

/* ---------- 11) Loaders ---------- */
#page-loader,#submit-overlay{
  position:fixed; inset:0; display:grid; place-items:center; background:rgba(10,12,16,.4); backdrop-filter:blur(3px); z-index:99999;
}
#page-loader.hidden,#submit-overlay.hidden{ display:none; }
.spinner,.bud-spinner{ width:30px; height:30px; border:2px solid rgba(255,255,255,.15); border-top-color:var(--color-acento); border-radius:50%; animation:fa-spin 1s infinite linear; }
.bud-spinner{ width:28px; height:28px; border-width:2px; }
.loader-text{ color:#fff; margin-top:6px; font-size:.85rem; font-weight:300; }
.bud-overlay-card{
  min-width:220px; max-width:90vw; background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.15); border-radius:14px; padding:14px 16px; color:#fff; text-align:center; box-shadow:0 4px 10px rgba(0,0,0,.1);
}
.bud-overlay-title{ font-size:1rem; font-weight:500; margin-bottom:4px; }
.bud-overlay-msg{ font-size:.85rem; opacity:.7; }
@keyframes fa-spin{ 0%{transform:rotate(0);} 100%{transform:rotate(360deg);} }

/* ---------- 12) Mensaje Éxito ---------- */
#success-container .header-bar{ background:var(--success); border-bottom-color:#1e7e34; }
#success-container .header-bar h2{ color:#fff; }
#success-container .header-bar .header-subtitle{ color:rgba(255,255,255,.85); }
#success-container .content-padding{ padding-top:30px; padding-bottom:40px; }
.success-icon{ font-size:6rem; color:var(--success); margin-bottom:25px; display:block; }
.success-title{ font-size:1.8rem; border:0; padding:0; margin-bottom:16px; color:var(--color-primario); font-weight:700; }
.success-message{ font-size:1.1rem; max-width:600px; margin:0 auto 35px; color:var(--color-texto-secundario); line-height:1.7; }
.success-message strong{ color:var(--color-primario); font-weight:600; }

/* ---------- 13) Accesibilidad ---------- */
.skip-link{
  position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; z-index:9999;
}
.skip-link:focus{
  left:8px; top:8px; width:auto; height:auto; padding:.6rem 1rem;
  background:#fff; border:2px solid var(--color-acento); border-radius:8px; outline:none;
}
:focus-visible{ outline:3px solid #27323f; outline-offset:2px; }
.visually-hidden{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.nav-arrow:focus-visible,.submit-btn:focus-visible,.back-btn:focus-visible,button:focus-visible{
  box-shadow:0 0 0 3px rgba(58,124,200,.2); outline:none;
}

/* ---------- 14) Menú lateral ---------- */
.menu-panel{
  position:fixed; top:0; left:0; width:280px; height:100vh; background:var(--color-superficie);
  box-shadow:var(--sombra-profunda); transform:translateX(-100%); transition:transform .3s ease-in-out, opacity .3s ease-in-out, visibility .3s ease-in-out;
  z-index:999; padding-top:calc(56px + env(safe-area-inset-top,0px)); overflow-y:auto; visibility:hidden; opacity:0;
}
body.menu-open .menu-panel{ transform:translateX(0); visibility:visible; opacity:1; }
body.menu-open .buzon-app{ position:relative; }
body.menu-open .buzon-app::before{
  content:""; position:fixed; inset:0; background:rgba(10,25,41,.3); z-index:998; opacity:1; visibility:visible; transition:opacity .3s ease-in-out, visibility .3s ease-in-out;
}
.menu-list{ list-style:none; padding:0; margin:0; }
.menu-list li{ border-bottom:1px solid var(--color-borde); }
.menu-list li:last-child{ border-bottom:none; }
.menu-list a,.menu-list button{
  display:flex; align-items:center; gap:12px;
  padding:12px 20px; color:var(--color-texto-principal); text-decoration:none; font-weight:500;
  transition:background-color .2s ease, color .2s ease; position:relative; overflow:hidden;
}
.menu-list a:hover,.menu-list button:hover,.menu-list a:focus,.menu-list button:focus{ background:var(--color-fondo); color:var(--color-primario); }
.menu-list a::after,.menu-list button::after{
  content:""; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--color-primario); transition:width .3s ease-in-out;
}
.menu-list a:hover::after,.menu-list button:hover::after,.menu-list a:focus::after,.menu-list button:focus::after{ width:100%; }

/* ---------- 15) Sección informativa / Decor ---------- */
.innovative-info-container{
  position:relative; background:var(--color-fondo);
  padding:60px clamp(20px,5vw,60px); overflow:hidden; color:var(--color-texto-principal);
}
.info-content-wrapper{ max-width:1200px; margin:0 auto; position:relative; z-index:2; }
.info-columns{ display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:30px; text-align:center; }
.info-column{ display:flex; flex-direction:column; align-items:center; }
.column-icon{
  font-size:3rem; color:var(--color-primario); margin-bottom:15px; padding:15px;
  background-color:rgba(39,50,63,.08); border-radius:15px;
}

/* Triángulos / círculos difusos */
.decor-triangle,
.decor-circle{ position:absolute; background-color: rgba(39,50,63,.06); z-index:1; filter:blur(50px); border-radius:40%; }
.decor-triangle.t1{ top:5%; left:5%; width:180px; height:180px; }
.decor-triangle.t2{ bottom:15%; right:8%; width:220px; height:220px; }
.decor-triangle.t3{ top:40%; left:45%; width:150px; height:150px; background-color:rgba(11,59,96,.05); }

/* ---------- 16) FAQ ---------- */
.faq-container{ background:var(--color-superficie); padding:60px clamp(20px,5vw,60px); color:var(--color-texto-principal); }
.faq-container .info-content-wrapper{ max-width:800px; margin:0 auto; position:relative; z-index:2; }
.faq-header{ text-align:center; margin-bottom:40px; }
.faq-header h2{ font-size:2rem; color:var(--color-primario); margin-bottom:10px; }
.faq-header p{ font-size:1rem; color:var(--color-texto-secundario); line-height:1.7; max-width:550px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--color-borde); margin-bottom:10px; }
.faq-item:last-child{ border-bottom:none; }
.faq-question{
  width:100%; background:none; border:none; padding:18px 15px; text-align:left; color:var(--color-texto-principal);
  font-size:1.1rem; font-weight:500; cursor:pointer; display:flex; justify-content:space-between; align-items:center; transition:color .2s ease;
}
.faq-question:hover,.faq-question:focus{ color:var(--color-primario); }
.faq-question i{ font-size:1.1rem; transition:transform .3s ease; }
.faq-item .faq-answer{
  display:none; max-height:0; overflow:hidden;
  padding:0 15px 0; color:var(--color-texto-secundario); font-size:.98rem; line-height:1.7;
  transition:max-height .3s ease-out, padding .3s ease-out;
}
.faq-item .faq-answer.active{
  display:block; max-height:1000px; padding-top:10px; padding-bottom:20px;
}

/* ---------- 17) Tablas / Expedientes públicos ---------- */
#expedientes-publicos-container{}
.expedientes-controls{
  display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; flex-wrap:wrap; gap:16px;
}
.expedientes-search, .expedientes-filters{ display:flex; align-items:center; gap:10px; }
.expedientes-search input[type="text"]{
  padding:8px 12px; border:1px solid #ccc; border-radius:6px; min-width:200px;
}
.expedientes-search .search-btn{
  padding:8px 15px; background-color:#007bff; color:#fff; border:none; border-radius:6px; cursor:pointer; transition:background-color .2s ease;
}
.expedientes-search .search-btn:hover{ background-color:#0056b3; }
.expedientes-filters select{ padding:8px 12px; border:1px solid #ccc; border-radius:6px; }

.expedientes-table-wrapper{ overflow-x:auto; }
.data-table{ width:100%; border-collapse:collapse; margin-bottom:24px; }
.data-table th, .data-table td{ padding:12px 15px; text-align:left; border-bottom:1px solid #eee; }
.data-table th{ background:#f8f9fa; font-weight:600; color:#27323f; }
.data-table tbody tr:nth-child(even){ background:#f8f9fa; }
.data-table tbody tr:hover{ background:#e9ecef; }
.data-table .action-btn{ background:none; border:none; color:#007bff; cursor:pointer; font-size:.9rem; display:inline-flex; align-items:center; gap:5px; }
.data-table .action-btn:hover{ text-decoration:underline; }

/* Paginación */
.pagination-controls{
  display:flex; justify-content:center; align-items:center; margin-top:24px; gap:15px;
}
.pagination-controls button{
  padding:8px 15px; border:1px solid #ccc; border-radius:6px; background:#fff; cursor:pointer; transition: all .2s ease;
}
.pagination-controls button:disabled{ opacity:.5; cursor:not-allowed; }
.pagination-controls button:not(:disabled):hover{ background:#e9ecef; }
.pagination-controls #page-info{ font-weight:500; }

/* KPIs */
.stats-grid{ display:grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap:16px; }
.stat-card{ background:#fff; border:1px solid var(--color-borde); border-radius:12px; padding:16px; box-shadow: var(--sombra-suave); }
.stat-label{ color:var(--color-texto-secundario); font-size:.92rem; margin-bottom:6px; }
.stat-value{ font-size:1.8rem; font-weight:700; color:var(--color-primario); }
.stats-placeholder{
  margin-top:22px; border:1px dashed var(--color-borde); border-radius:12px; padding:24px; text-align:center; color:var(--color-texto-secundario);
}
.stats-placeholder i{ font-size:1.6rem; display:block; margin-bottom:8px; }

/* ---------- 18) Utilidades ---------- */
.form-note.text-danger{ color:#d32f2f; font-size:.9rem; margin-top:.25rem; }
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip: rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ---------- 19) Breakpoints ---------- */
@media (min-width:480px){ :root{ --rim-gap: clamp(86px, 14vw, 190px); } }
@media (min-width:768px){
  :root{ --rim-gap: clamp(110px, 12vw, 210px); }
  .header-bar{ padding:24px 36px; }
  .skin-modal__dialog{ margin-top:6dvh; max-height:88dvh; }
}
@media (min-width:1024px){ :root{ --rim-gap: clamp(120px, 10vw, 220px); } }
@media (max-width:768px){
  .info-columns{ grid-template-columns:1fr; gap:20px; }
  .decor-triangle.t1,.decor-triangle.t2,.decor-triangle.t3{ width:120px; height:120px; }
  .decor-triangle.t1{ top:2%; left:2%; }
  .decor-triangle.t2{ bottom:10%; right:4%; }
  .decor-triangle.t3{ top:35%; left:40%; }
  .faq-header h2{ font-size:1.8rem; }
  .faq-question{ font-size:1rem; }
  .decor-circle{ width:150px; height:150px; }
}
@media (max-width:520px){
  .carousel-item.active .carousel-inner-item :is(.carousel-label,.carousel-title,span,p){
    font-size: clamp(11px, 2.8vw, 13px) !important;
  }
}

/* ---------- 20) Motion preference global ---------- */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
}
/* =========================================================
   PATCH: Cambiar texto “azul marino” a #0b3b60
   Pegar al FINAL del CSS
   ========================================================= */

/* 1) Actualiza la variable de texto principal */
:root{
  --navy:#0b3b60;                   /* ← nuevo “azul marino” */
  --color-texto-principal: var(--navy);
  --color-flecha: var(--navy);
  /* Si quieres que el ring siga el nuevo navy (opcional) */
  --ring: color-mix(in oklab, var(--navy) 40%, transparent);
}

/* 2) Lugares donde pusiste #27323f directo: forzamos a usar --navy */
.app-topbar{ color: var(--navy) !important; }
.app-topbar .brand{ color: var(--navy) !important; }
.menu-btn{ border-color: color-mix(in oklab, var(--navy) 20%, transparent) !important;
           background: color-mix(in oklab, var(--navy) 8%, #fff) !important; }
.menu-btn-bar{ background: var(--navy) !important; }

/* Header textual */
.header-bar{
  color: var(--navy) !important;
  border-bottom-color: var(--navy) !important;
}
.header-bar h1, .header-bar h2{ color: var(--navy) !important; }
.header-bar h1::after, .header-bar h2::after{ background: var(--navy) !important; }
.header-bar .header-subtitle{
  color: color-mix(in oklab, var(--navy) 85%, #000) !important;
}

/* Título colapsado en topbar */
.collapsed-header-title .topbar-title{ color: var(--navy) !important; }
.collapsed-header-title .header-subtitle{
  color: color-mix(in oklab, var(--navy) 80%, #000) !important;
}

/* Inputs y focos que usaban #27323f / rgba(39,50,63,…) */
input:hover, select:hover, textarea:hover{
  border-color: var(--color-texto-secundario);
}
input:focus, select:focus, textarea:focus{
  border-color: var(--navy) !important;
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--navy) 15%, transparent) !important;
}

/* Botón principal oscuro (antes #27323f) ahora navy */
.submit-btn{
  background: var(--navy) !important;
  box-shadow: 0 4px 14px color-mix(in oklab, var(--navy) 18%, transparent) !important;
}
.submit-btn:hover{ background: color-mix(in oklab, var(--navy) 85%, #000) !important; }
.submit-btn:disabled{ background: var(--navy) !important; }

/* Drop area y elementos que usaban el azul marino fijo */
.file-drop-area:hover{ border-color: var(--navy) !important; background:#eef1f5; }
.file-drop-area.is-dragging{ background:#eef1f5; border-color: var(--navy) !important; }
.file-drop-message i{ color: var(--navy) !important; }

/* Nav arrows que tenían color fijo */
.nav-arrow{
  color: var(--navy) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,.08), 0 0 0 6px #fff;
}

/* Accesibilidad: outlines y focus ring al nuevo navy */
:focus-visible{ outline:3px solid var(--navy) !important; }
.nav-arrow:focus-visible, .submit-btn:focus-visible, .back-btn:focus-visible, button:focus-visible{
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--navy) 20%, transparent) !important;
}

/* Column icons y otros acentos que dependían del “oscuro” */
.column-icon{
  color: var(--navy) !important;
  background-color: color-mix(in oklab, var(--navy) 8%, #fff) !important;
}
/* === Botón "Escuchar esta sección" — fix de visibilidad === */
/* Cubre los casos más comunes sin saber tu clase exacta */
.header-bar .listen-btn,
.hero .listen-btn,
button[aria-label*="Escuchar"],
a[aria-label*="Escuchar"],
button[data-action*="escuchar"],
a[data-action*="escuchar"]{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;

  /* Variante sólida (recomendada) */
  background: var(--navy) !important;     /* #0b3b60 tras tu patch */
  color: #fff !important;

  /* Si prefieres borde + fondo blanco, comenta lo de arriba y usa:
  background:#fff !important;
  color: var(--navy) !important;
  border: 1px solid var(--navy) !important;
  */

  border: 0;
  font-weight: 600;
  font-size: .95rem !important;            /* evita font-size:0 heredado */
  line-height: 1;
  box-shadow: 0 6px 14px rgba(0,0,0,.08);
  opacity: 1 !important;                   /* evita estados con poca opacidad */
  filter: none !important;                  /* por si hay filtros raros */
  text-shadow: none !important;
}

.header-bar .listen-btn:hover,
.hero .listen-btn:hover,
button[aria-label*="Escuchar"]:hover,
a[aria-label*="Escuchar"]:hover{
  transform: translateY(-1px);
  background: color-mix(in oklab, var(--navy) 85%, #000) !important;
}

.header-bar .listen-btn svg,
.hero .listen-btn svg,
button[aria-label*="Escuchar"] svg,
a[aria-label*="Escuchar"] svg{
  width: 18px; height: 18px;
  stroke: currentColor; fill: none;
}

/* Evita que en móvil alguien lo deje “solo icono” */
@media (max-width: 480px){
  .header-bar .listen-btn,
  .hero .listen-btn,
  button[aria-label*="Escuchar"],
  a[aria-label*="Escuchar"]{
    font-size: .95rem !important;
  }
}
/* Estilos visibles para el botón TTS generado por JS */
.tts-inline{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--navy) !important;
  color: #fff !important;
  border: 0;
  font-weight: 600;
  font-size: .95rem !important;
  line-height: 1;
  box-shadow: 0 6px 14px rgba(0,0,0,.08);
  opacity: 1 !important;
  filter: none !important;
  text-shadow: none !important;
}
.tts-inline:hover{
  transform: translateY(-1px);
  background: color-mix(in oklab, var(--navy) 85%, #000) !important;
}
/* === Campo de Firma Digital === */
.form-group {
  margin-top: 16px;
  display: grid;
  gap: 8px;
}

.form-group label {
  font-weight: 600;
  color: #0b3b60;
  font-family: 'Poppins', system-ui, sans-serif;
}

/* Contenedor del canvas y el botón */
.signature-pad-container {
  position: relative;
  display: grid;
  gap: 8px;
}

/* Área de dibujo (canvas) */
.signature-pad {
  width: 100%;
  height: 220px;
  background: #fff;
  border: 2px dashed rgba(0, 0, 0, 0.15);
  border-radius: 12px;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.05);
  cursor: crosshair;
  touch-action: none; /* evita scroll al firmar en móvil */
  transition: border-color 0.2s ease;
}

.signature-pad:hover {
  border-color: var(--blue, #0076aa);
}

/* Botón para limpiar firma */
.clear-btn {
  align-self: end;
  justify-self: end;
  border: none;
  border-radius: 999px;
  padding: 8px 14px;
  background: #eef4fb;
  color: #0b3b60;
  font-weight: 600;
  font-family: 'Poppins', system-ui, sans-serif;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.08);
}

.clear-btn:hover {
  background: var(--blue, #0076aa);
  color: #fff;
  box-shadow: 0 4px 12px rgba(0, 118, 170, 0.25);
  transform: translateY(-1px);
}

/* Responsivo para móvil */
@media (max-width: 600px) {
  .signature-pad {
    height: 180px;
  }
  .clear-btn {
    width: 100%;
    justify-self: stretch;
  }
}

/* Separador “o” */
.u-sep{display:flex;align-items:center;gap:.5rem;margin:.75rem 0}
.u-sep::before,.u-sep::after{content:"";flex:1;height:1px;background:#e0e6ef}
.u-sep>span{font-size:.85rem;color:var(--muted,#6b7785)}

/* Dropzone genérico (igual que evidencias) */
.u-drop{
  border:2px dashed #cdd6e3;border-radius:10px;
  padding:18px;text-align:center;background:#f8fafc;cursor:pointer;outline:none;
}
.u-drop:focus{box-shadow:0 0 0 3px rgba(0,118,170,.2)}
.u-drop.is-dragover{background:#eef6fb;border-color:#0076aa}
.u-drop__icon{font-size:2rem;margin-bottom:.25rem}
.u-drop__text{font-weight:600}
.u-drop__btn{color:#0076aa;text-decoration:underline}
.u-drop__hint{font-size:.85rem;color:#6b7785;margin-top:.25rem}

/* Lista de archivos */
.u-file-list{display:grid;gap:.5rem;margin-top:.75rem}
.u-file{
  display:flex;justify-content:space-between;align-items:center;
  border:1px solid #e0e6ef;border-radius:10px;background:#fff;padding:.6rem .75rem;
}
.u-file__left{display:flex;gap:.6rem;align-items:center}
.u-file__badge{font-size:1.15rem}
.u-file__name{font-weight:600}
.u-file__meta{font-size:.85rem;color:#6b7785}
.u-file__right{display:flex;gap:.5rem;align-items:center}
.u-chip{
  font-size:.75rem;background:#eef6fb;color:#0076aa;border-radius:999px;padding:.15rem .5rem
}
.u-file__remove{border:0;background:#fff;color:#dc3545;cursor:pointer}
.u-file__remove:hover{text-decoration:underline}

/* Botonera auxiliar */
.btn-ghost, .btn-blue{
  background:transparent;border:1px solid #e0e6ef;color:var(--navy,#27323f);
  padding:.5rem .75rem;border-radius:.6rem;cursor:pointer
}
.btn-ghost:hover{background:#f5f7fb}
.bcb-subtitle {
  margin-bottom: 8px;
  line-height: 1.3;
  color: #333; /* O el color principal de tu diseño */
}

.bcb-description {
  font-size: 0.9rem; /* Un poco más pequeño para jerarquía */
  line-height: 1.4;
  opacity: 0.85;
  margin-bottom: 20px;
}