/* ============================================================
   Buscador Legislativo — Legislatura de Tierra del Fuego
   Diseño moderno/editorial · acento celeste institucional
   ============================================================ */
:root{
  --c:#2ba0d6; --c-d:#1c7ba6; --c-dd:#155f82; --c-l:#edf7fc; --c-l2:#d4ecf8; --c-bar:#2ba0d6;
  --ink:#16212e; --muted:#586672; --faint:#93a0ac; --line:#e7ebef; --line2:#f1f4f6; --bg:#f7f9fb; --card:#fff;
  --ok-fg:#137a45; --ok-bg:#e7f6ed; --no-fg:#b4291d; --no-bg:#fcebe9; --warn-fg:#8a5a12; --warn-bg:#fbf1dd;
  --mark:#fff0b8; --mark-fg:#5b4500;
  --r:10px; --r-lg:14px; --r-xl:20px;
  --sh:0 1px 2px rgba(22,42,62,.05); --sh-2:0 6px 22px rgba(22,42,62,.08); --sh-c:0 8px 24px rgba(43,160,214,.18);
  --ff:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
body{font-family:var(--ff);margin:0;background:var(--bg);color:var(--ink);line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:16.5px}
img,svg{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.layout>*{min-width:0}
::selection{background:var(--c-l2)}

/* ---------- Topbar ---------- */
.topbar{background:var(--c-bar);color:#fff}
.topbar-in{display:flex;align-items:center;gap:14px;height:62px}
.home-link{display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;cursor:pointer;border-radius:10px}
.home-link:hover{opacity:.9}
.topbar .escudo{width:42px;height:42px;border-radius:9px;background:#fff;padding:3px;object-fit:contain}
.topbar .brand{display:flex;flex-direction:column;line-height:1.25}
.topbar .brand strong{font-size:15px;font-weight:600;letter-spacing:.1px}
.topbar .brand span{font-size:11px;opacity:.85;letter-spacing:.2px}
.topbar-tag{margin-left:auto;font-size:11.5px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;
  background:rgba(255,255,255,.16);padding:6px 14px;border-radius:999px}
/* selector de tema */
.tema-toggle{display:flex;gap:2px;background:rgba(255,255,255,.16);border-radius:999px;padding:3px;margin-left:auto}
.tt-btn{background:none;border:0;color:#fff;font-family:inherit;font-size:12px;font-weight:500;padding:6px 13px;
  border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .14s,color .14s}
.tt-btn:hover{background:rgba(255,255,255,.12)}
.tt-btn.activo{background:#fff;color:var(--c-d)}
/* tema blanco (vista relajada) */
html.tema-blanco{--c:#5b6a78;--c-d:#46535e;--c-dd:#333f49;--c-l:#f0f3f6;--c-l2:#e1e7ec;--c-bar:#ffffff}
html.tema-blanco .topbar{color:var(--ink);border-bottom:1px solid var(--line)}
html.tema-blanco .topbar .brand span{opacity:.65}
html.tema-blanco .tema-toggle{background:var(--c-l)}
html.tema-blanco .tt-btn{color:var(--muted)}
html.tema-blanco .tt-btn:hover{background:#fff}
html.tema-blanco .tt-btn.activo{background:#fff;color:var(--ink)}
/* tema oscuro (descanso visual) */
html.tema-oscuro{
  --bg:#15181c; --card:#1f2329; --ink:#e7eaee; --muted:#9aa4af; --faint:#6c7681;
  --line:#2c323a; --line2:#23282f; --c-bar:#1f2329;
  --c:#3db4e6; --c-d:#62c4ed; --c-dd:#8fd6f3; --c-l:#16323f; --c-l2:#1d4252;
  --ok-fg:#5fcf8f; --ok-bg:#173021; --no-fg:#f08e85; --no-bg:#321a18; --warn-fg:#e0b46a; --warn-bg:#2f2611;
  --mark:#4a3d10; --mark-fg:#ffe6a0;
  --sh:0 1px 2px rgba(0,0,0,.4); --sh-2:0 6px 22px rgba(0,0,0,.45); --sh-c:0 8px 24px rgba(0,0,0,.5);
}
html.tema-oscuro body{background:var(--bg)}
html.tema-oscuro .topbar{color:var(--ink);border-bottom:1px solid var(--line)}
html.tema-oscuro .topbar .escudo{background:#fff}
html.tema-oscuro .topbar .brand span{opacity:.72}
html.tema-oscuro #q{color:var(--ink)}
html.tema-oscuro #q::placeholder{color:#73808c}
html.tema-oscuro .orden select,html.tema-oscuro .avanzada input[type=number]{background:var(--card);color:var(--ink)}
html.tema-oscuro .tema-toggle{background:rgba(255,255,255,.08)}
html.tema-oscuro .tt-btn{color:var(--muted)}
html.tema-oscuro .tt-btn:hover{background:rgba(255,255,255,.06)}
html.tema-oscuro .tt-btn.activo{background:var(--c);color:#0f1418}
html.tema-oscuro .modal{background:rgba(0,0,0,.65)}
html.tema-oscuro .vacio,html.tema-oscuro .paginado button,html.tema-oscuro .suger,
html.tema-oscuro .modal-box,html.tema-oscuro .cat-tile,html.tema-oscuro .pie,
html.tema-oscuro .modal-x{background:var(--card)}
html.tema-oscuro .opcion .cuenta,html.tema-oscuro .tab .cuenta{background:var(--line2);color:var(--muted)}

/* ---------- Hero / búsqueda ---------- */
.hero{background:var(--card);border-bottom:1px solid var(--line)}
.hero-in{padding:48px 0 40px;max-width:780px}
.hero h1{margin:0 0 12px;font-size:32px;font-weight:700;letter-spacing:-.5px;line-height:1.18;color:var(--ink)}
.hero-sub{margin:0 0 26px;font-size:16px;color:var(--muted);max-width:620px}
.searchbox{display:flex;align-items:center;gap:8px;background:var(--card);border:1.5px solid var(--line);
  border-radius:var(--r-lg);padding:6px 6px 6px 16px;transition:border-color .15s,box-shadow .15s}
.searchbox:focus-within{border-color:var(--c);box-shadow:0 0 0 4px var(--c-l)}
.searchbox .s-icon{color:var(--c);flex-shrink:0}
.searchbox .s-icon svg{width:21px;height:21px}
.q-wrap{position:relative;flex:1;min-width:0}
#q{width:100%;border:0;outline:0;font-size:16px;color:var(--ink);background:transparent;padding:12px 6px;font-family:inherit}
#q::placeholder{color:#9aa6b1}
.btn-buscar{flex-shrink:0;background:var(--c);color:#fff;border:0;padding:12px 26px;border-radius:var(--r);
  font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}
.btn-buscar:hover{background:var(--c-d)}
.btn-buscar.sm{padding:9px 18px;font-size:13.5px}
.btn-avanzada{margin-top:14px;display:inline-flex;align-items:center;gap:7px;background:none;border:0;
  color:var(--c-d);cursor:pointer;font-size:13.5px;font-weight:600;font-family:inherit;padding:4px 0}
.btn-avanzada:hover{color:var(--c-dd);text-decoration:underline}
.btn-link{background:none;border:0;color:var(--c-d);cursor:pointer;font-size:13px;font-weight:600;padding:0;font-family:inherit}
.btn-link:hover{text-decoration:underline}
.avanzada{margin-top:16px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:18px 20px;display:flex;flex-direction:column;gap:14px;max-width:680px}
.avanzada .campo{display:flex;flex-wrap:wrap;gap:16px;align-items:center;font-size:13.5px;color:var(--muted)}
.avanzada label{display:flex;align-items:center;gap:7px}
.avanzada .chk{cursor:pointer;color:var(--ink)}
.avanzada input[type=number]{width:108px;border:1.5px solid var(--line);border-radius:var(--r);padding:8px 10px;font-size:14px;font-family:inherit;outline:0}
.avanzada input[type=number]:focus{border-color:var(--c)}
.avanzada input[type=checkbox]{width:17px;height:17px;accent-color:var(--c)}

/* ---------- Layout ---------- */
.layout{display:grid;grid-template-columns:248px minmax(0,1fr);gap:30px;align-items:start;padding:34px 0 56px}
body.modo-portada .layout{grid-template-columns:minmax(0,1fr)}
body.modo-portada .facetas,body.modo-portada #tabs,body.modo-portada .toolbar,
body.modo-portada #activos,body.modo-portada #results,body.modo-portada #paginado{display:none}
body:not(.modo-portada) #novedades{display:none}

/* ---------- Facetas ---------- */
.facetas{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;position:sticky;top:20px}
.facetas-head{display:flex;justify-content:space-between;align-items:center;padding:15px 18px;
  font-size:14px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--line2)}
.faceta{padding:16px 18px;border-bottom:1px solid var(--line2)}
.faceta:last-child{border-bottom:0}
.faceta h3{margin:0 0 11px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--faint)}
.opciones{display:flex;flex-direction:column;gap:2px}
.opciones.scroll{max-height:208px;overflow-y:auto;margin-right:-8px;padding-right:5px}
.opciones.scroll::-webkit-scrollbar{width:6px}
.opciones.scroll::-webkit-scrollbar-thumb{background:#d8e0e6;border-radius:6px}
.opcion{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink);cursor:pointer;
  padding:5px 8px;border-radius:8px;transition:background .12s;overflow-wrap:anywhere}
.opcion:hover{background:var(--c-l)}
.opcion input{width:16px;height:16px;accent-color:var(--c);flex-shrink:0}
.opcion .cuenta{margin-left:auto;background:var(--line2);color:var(--muted);font-size:11px;font-weight:600;padding:1px 8px;border-radius:999px;flex-shrink:0}
.vacia-faceta{font-size:13px;color:var(--faint);padding:2px 8px}

/* ---------- Pestañas ---------- */
.tabs{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:22px}
.tab{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line);
  padding:8px 15px;font-size:13.5px;color:var(--muted);cursor:pointer;font-weight:500;border-radius:999px;
  font-family:inherit;transition:all .14s;white-space:nowrap}
.tab:hover{border-color:var(--c-l2);color:var(--c-d)}
.tab.activo{background:var(--c);border-color:var(--c);color:#fff}
.tab .cuenta{font-size:11px;font-weight:600;background:var(--line2);color:var(--muted);padding:1px 7px;border-radius:999px}
.tab.activo .cuenta{background:rgba(255,255,255,.22);color:#fff}

/* ---------- Toolbar ---------- */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.status{font-size:14.5px;color:var(--muted)}
.status strong{color:var(--ink);font-weight:600}
.orden{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px}
.orden select{border:1px solid var(--line);border-radius:var(--r);padding:8px 11px;font-size:13.5px;background:#fff;color:var(--ink);font-family:inherit;cursor:pointer;outline:0}
.orden select:focus{border-color:var(--c)}

/* Chips activos */
.activos{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.activos:empty{display:none}
.chip-activo{display:inline-flex;align-items:center;gap:6px;background:var(--c-l);color:var(--c-dd);border:1px solid var(--c-l2);
  padding:5px 12px;border-radius:999px;font-size:12.5px;font-weight:500;cursor:pointer;font-family:inherit;max-width:100%;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chip-activo:hover{background:var(--c-l2)}
.chip-activo::after{content:"✕";font-size:11px;flex-shrink:0}

/* ---------- Tarjetas ---------- */
.results{display:flex;flex-direction:column;gap:20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 28px;
  transition:border-color .15s,box-shadow .15s,transform .15s;overflow:hidden}
.card:hover{border-color:var(--c-l2);box-shadow:var(--sh-2);transform:translateY(-1px)}
.card .linea-tipo{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--faint);margin-bottom:9px;flex-wrap:wrap}
.badge{background:var(--c-l);color:var(--c-dd);padding:3px 11px;border-radius:999px;font-weight:600;font-size:11px;letter-spacing:.02em}
.card h2{margin:0 0 10px;font-size:19px;font-weight:600;line-height:1.45;overflow-wrap:anywhere}
.card h2 a{color:var(--c-d);text-decoration:none;cursor:pointer}
.card h2 a:hover{color:var(--c-dd);text-decoration:underline}
.sumario{font-size:15px;line-height:1.65;color:var(--muted);margin:0 0 15px;overflow-wrap:anywhere;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.sumario mark,.card h2 mark,.ficha-prev mark{background:var(--mark);color:var(--mark-fg);padding:0 3px;border-radius:3px}
.card .pie-card{display:flex;align-items:center;gap:14px;font-size:12.5px;color:var(--faint);border-top:1px solid var(--line2);padding-top:13px;flex-wrap:wrap}
.card .acciones{margin-left:auto;display:flex;gap:8px}
.card .acciones a{font-size:12.5px;color:var(--c-d);text-decoration:none;border:1px solid var(--line);padding:6px 14px;border-radius:999px;font-weight:500;transition:all .12s;white-space:nowrap}
.card .acciones a:hover{border-color:var(--c);background:var(--c-l)}
.card .acciones a.primario{background:var(--c);color:#fff;border-color:var(--c)}
.card .acciones a.primario:hover{background:var(--c-d)}
.vig{font-size:11px;font-weight:600;padding:2px 9px;border-radius:999px}
.vig-ok{color:var(--ok-fg);background:var(--ok-bg)}
.vig-no{color:var(--no-fg);background:var(--no-bg)}
.sin-texto{font-size:11px;font-weight:500;color:var(--warn-fg);background:var(--warn-bg);padding:2px 9px;border-radius:999px}
.tema{font-size:11px;font-weight:500;color:var(--c-dd);background:var(--c-l);padding:2px 9px;border-radius:999px}
.puntos{align-self:center;color:var(--faint)}
.vacio{text-align:center;color:var(--muted);padding:64px 24px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg)}
.vacio .big{font-size:44px;margin-bottom:12px}
.vacio p{margin:4px 0}
.sugerencia{font-size:15px;color:var(--muted);margin-bottom:16px;padding:13px 17px;background:var(--c-l);border:1px solid var(--c-l2);border-radius:var(--r-lg)}
.sug-link{background:none;border:0;color:var(--c-d);font-weight:600;font-size:15px;cursor:pointer;font-family:inherit;text-decoration:underline;padding:0}
.sug-link:hover{color:var(--c-dd)}

/* ---------- Paginado ---------- */
.paginado{display:flex;justify-content:center;gap:7px;margin:34px 0 0;flex-wrap:wrap}
.paginado button{min-width:40px;height:40px;border:1px solid var(--line);background:#fff;color:var(--c-d);border-radius:var(--r);cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;transition:all .12s}
.paginado button:hover:not(:disabled){border-color:var(--c);background:var(--c-l)}
.paginado button.actual{background:var(--c);color:#fff;border-color:var(--c)}
.paginado button:disabled{color:#c2cdd5;cursor:default}

/* ---------- Autocompletado ---------- */
.suger{position:absolute;top:calc(100% + 12px);left:-16px;right:-16px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);box-shadow:var(--sh-2);z-index:40;overflow:hidden;padding:6px}
.suger .sug{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%;text-align:left;
  background:none;border:0;padding:10px 12px;cursor:pointer;font-size:13.5px;border-radius:9px;font-family:inherit}
.suger .sug:hover{background:var(--c-l)}
.suger .sug-n{color:var(--ink);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.suger .sug-c{color:var(--c-dd);font-size:11px;font-weight:600;white-space:nowrap;flex-shrink:0;background:var(--c-l);padding:2px 9px;border-radius:999px}

/* ---------- Ficha (modal) ---------- */
.modal{position:fixed;inset:0;background:rgba(16,33,46,.5);display:flex;align-items:flex-start;justify-content:center;padding:52px 16px;z-index:60;overflow-y:auto}
.modal[hidden]{display:none}
.modal-box{position:relative;background:#fff;border-radius:var(--r-xl);max-width:700px;width:100%;padding:32px 34px;box-shadow:var(--sh-2);animation:pop .16s ease}
@keyframes pop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.modal-x{position:absolute;top:18px;right:20px;background:var(--bg);border:0;width:34px;height:34px;border-radius:50%;font-size:16px;color:var(--muted);cursor:pointer;line-height:1;transition:background .12s}
.modal-x:hover{background:var(--c-l);color:var(--c-dd)}
.ficha-tipo{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--faint);margin-bottom:9px;flex-wrap:wrap}
.ficha-tit{margin:0 0 20px;font-size:22px;font-weight:600;letter-spacing:-.2px;color:var(--ink);padding-right:36px;line-height:1.32;overflow-wrap:anywhere}
.ficha-tabla{width:100%;border-collapse:collapse;margin-bottom:22px}
.ficha-tabla th{text-align:left;width:150px;color:var(--faint);font-weight:500;font-size:13px;padding:8px 12px 8px 0;vertical-align:top}
.ficha-tabla td{padding:8px 0;font-size:14px;color:var(--ink);border-bottom:1px solid var(--line2);overflow-wrap:anywhere}
.ficha-h3{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin:0 0 10px}
.ficha-rel{font-size:13.5px;color:var(--ink);line-height:1.65;background:var(--c-l);border:1px solid var(--c-l2);border-radius:var(--r);padding:14px 16px;margin-bottom:22px;overflow-wrap:anywhere}
.ficha-prev{font-size:13.5px;color:var(--muted);line-height:1.7;max-height:240px;overflow-y:auto;background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:15px 17px;margin-bottom:22px;white-space:pre-wrap;overflow-wrap:anywhere}
.ficha-noprev{color:var(--faint);font-size:13.5px;margin-bottom:22px}
.ficha-acc{display:flex;gap:10px;flex-wrap:wrap}
.ficha-acc a{font-size:14px;color:var(--c-d);text-decoration:none;border:1px solid var(--line);padding:11px 20px;border-radius:var(--r);font-weight:500;transition:all .12s}
.ficha-acc a:hover{border-color:var(--c);background:var(--c-l)}
.ficha-acc a.primario{background:var(--c);color:#fff;border-color:var(--c)}
.ficha-acc a.primario:hover{background:var(--c-d)}

/* ---------- Portada ---------- */
.novedades{padding-top:4px}
.novedades[hidden]{display:none}
.nov-stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:30px}
.nov-stats .stat{flex:1;min-width:150px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 20px}
.nov-stats .stat b{display:block;color:var(--ink);font-weight:700;font-size:26px;line-height:1.1;letter-spacing:-.5px}
.nov-stats .stat span{font-size:13px;color:var(--muted)}
.nov-stats .stat.nuevo{background:var(--c-l);border-color:var(--c-l2)}
.nov-stats .stat.nuevo b{color:var(--c-d)}
.nov-head h2{margin:0;font-size:19px;font-weight:600;color:var(--ink);letter-spacing:-.2px}
.nov-head p{margin:5px 0 16px;font-size:14px;color:var(--muted)}
.nov-head-2{margin-top:36px}
.nov-row{display:flex;gap:14px;overflow-x:auto;padding:2px 2px 14px;scroll-snap-type:x proximity}
.nov-row::-webkit-scrollbar{height:8px}
.nov-row::-webkit-scrollbar-thumb{background:#d3dde4;border-radius:6px}
.nov-card{scroll-snap-align:start;flex:0 0 236px;display:flex;flex-direction:column;gap:10px;text-align:left;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:17px;cursor:pointer;font-family:inherit;transition:border-color .14s,box-shadow .14s,transform .14s}
.nov-card:hover{border-color:var(--c-l2);box-shadow:var(--sh-2);transform:translateY(-2px)}
.nov-cat{align-self:flex-start;font-size:10.5px;font-weight:600;letter-spacing:.02em;color:var(--c-dd);background:var(--c-l);padding:3px 10px;border-radius:999px}
.nov-nom{font-size:13.5px;font-weight:500;color:var(--ink);line-height:1.45;overflow-wrap:anywhere;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:58px}
.nov-fecha{font-size:11.5px;color:var(--faint);font-weight:500;margin-top:auto}
.nov-fecha::before{content:"🕒 "}
.grupo{margin-bottom:26px}
.grupo-tit{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--c-dd);
  margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.grupo-tit::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--c);flex-shrink:0}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(206px,1fr));gap:12px}
.cat-tile{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:15px 17px;cursor:pointer;font-family:inherit;text-align:left;transition:border-color .14s,box-shadow .14s,transform .14s}
.cat-tile:hover{border-color:var(--c-l2);box-shadow:var(--sh-2);transform:translateY(-2px)}
.cat-ic{font-size:20px;flex-shrink:0;line-height:1;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--c-l);border-radius:11px}
.cat-nom{flex:1;font-size:13px;font-weight:500;color:var(--ink);line-height:1.3}
.cat-n{font-size:12px;font-weight:700;color:var(--c-d);flex-shrink:0}

/* ---------- Pie ---------- */
.pie{border-top:1px solid var(--line);background:#fff}
.pie .wrap{display:flex;align-items:center;gap:13px;padding-top:24px;padding-bottom:24px}
.pie img{border-radius:8px}
.pie strong{display:block;font-size:13.5px;color:var(--ink);font-weight:600}
.pie span{font-size:12px;color:var(--faint)}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .layout{grid-template-columns:minmax(0,1fr);gap:22px}
  .facetas{position:static;order:2}
  .contenido{order:1}
  .hero h1{font-size:25px}
  .hero-in{padding:34px 0 30px}
  .wrap{padding:0 16px}
}

/* ============================================================
   Accesibilidad (Ley 26.653 / WCAG) — colocado al final para
   que sus overrides ganen sobre el tema oscuro.
   ============================================================ */

/* Saltar al contenido (visible al tabular) */
.skip-link{position:absolute;left:-9999px;top:0;z-index:1000;background:var(--c);color:#fff;
  padding:10px 16px;border-radius:0 0 var(--r) 0;font-weight:600;font-family:var(--ff)}
.skip-link:focus{left:0}
.exp-chip{display:inline-block;font-size:12.5px;font-weight:600;color:var(--c-dd);background:var(--c-l);
  border:1px solid var(--c-l2);padding:1px 9px;border-radius:999px;margin-left:6px;vertical-align:middle}

/* Barra de accesibilidad desplegable: vive en el flujo (empuja el contenido, NO lo tapa) */
.a11y-top{margin-left:auto;display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.16);
  color:#fff;border:0;border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;
  font-family:var(--ff);transition:background .15s;flex-shrink:0}
.a11y-top:hover{background:rgba(255,255,255,.28)}
.a11y-top.abierto{background:rgba(255,255,255,.34)}
html.tema-oscuro .a11y-top{background:rgba(255,255,255,.10)}
html.tema-oscuro .a11y-top:hover{background:rgba(255,255,255,.18)}
.a11y-bar{background:var(--c-l);border-bottom:1px solid var(--line)}
.a11y-bar-in{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:12px 24px}
.a11y-grp{display:flex;align-items:center;gap:7px}
.a11y-lbl{font-size:13.5px;font-weight:600;color:var(--ink)}
.a11y-grp button{width:36px;height:34px;border:1px solid var(--line);background:var(--card);color:var(--ink);
  border-radius:8px;cursor:pointer;font-weight:700;font-family:var(--ff);font-size:14px}
.a11y-grp button:hover{border-color:var(--c);color:var(--c)}
.a11y-chip{border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:999px;
  padding:8px 16px;font-size:13.5px;font-weight:600;cursor:pointer;font-family:var(--ff);transition:all .12s}
.a11y-chip:hover{border-color:var(--c)}
.a11y-chip[aria-pressed="true"]{background:var(--c);color:#fff;border-color:var(--c)}
.a11y-reset{margin-left:auto;color:var(--muted);font-weight:500}
@media(max-width:700px){ .a11y-top span{display:none} .a11y-reset{margin-left:0} }

/* Foco visible para navegación por teclado */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,
[tabindex]:focus-visible,.card:focus-within{outline:3px solid var(--c);outline-offset:2px}

/* Botón flotante + panel */
.a11y-btn{position:fixed;right:18px;bottom:18px;z-index:900;width:52px;height:52px;border-radius:50%;
  border:0;background:var(--c);color:#fff;cursor:pointer;box-shadow:var(--sh-2);
  display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s}
.a11y-btn:hover{background:var(--c-d);transform:translateY(-2px)}
.a11y-btn.abierto{background:var(--c-dd)}
.a11y-panel{position:fixed;right:18px;bottom:80px;z-index:900;width:206px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-2);padding:11px;
  display:flex;flex-direction:column;gap:6px;font-family:var(--ff)}
.a11y-head{font-weight:700;font-size:14px;color:var(--ink);padding:1px 1px 6px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between}
.a11y-x{background:none;border:0;color:var(--muted);font-size:16px;line-height:1;cursor:pointer;padding:2px 4px;border-radius:6px}
.a11y-x:hover{background:var(--line2);color:var(--ink)}
.a11y-row{display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--muted);font-size:13px}
.a11y-fs{display:flex;gap:4px}
.a11y-fs button{width:34px;height:32px;border:1px solid var(--line);background:var(--bg);color:var(--ink);
  border-radius:8px;cursor:pointer;font-weight:700;font-family:var(--ff)}
.a11y-fs button:hover{border-color:var(--c);color:var(--c)}
.a11y-opt,.a11y-reset{text-align:left;padding:9px 11px;border:1px solid var(--line);background:var(--bg);
  color:var(--ink);border-radius:8px;cursor:pointer;font-size:13.5px;font-weight:500;font-family:var(--ff)}
.a11y-opt:hover,.a11y-reset:hover{border-color:var(--c)}
.a11y-opt[aria-pressed="true"]{background:var(--c);color:#fff;border-color:var(--c)}
.a11y-reset{text-align:center;color:var(--muted);margin-top:3px}

/* Tamaño de texto (zoom global, refluye bien con layouts en px) */
html.a11y-fsm1{zoom:.9}  html.a11y-fsm2{zoom:.82}
html.a11y-fs1{zoom:1.15} html.a11y-fs2{zoom:1.3} html.a11y-fs3{zoom:1.45} html.a11y-fs4{zoom:1.6}

/* Resaltar enlaces y elementos clicables */
html.a11y-enlaces a,html.a11y-enlaces .btn-link{text-decoration:underline !important;text-underline-offset:3px;
  text-decoration-thickness:2px;font-weight:600}
html.a11y-enlaces .card,html.a11y-enlaces .tab,html.a11y-enlaces .cat-tile,
html.a11y-enlaces .opcion{outline:2px solid var(--c);outline-offset:1px}

/* Fuente legible (más espaciada, sin depender de fuentes externas) */
html.a11y-legible{--ff:Verdana,Tahoma,"Segoe UI",sans-serif}
html.a11y-legible body{letter-spacing:.4px;word-spacing:1.5px;line-height:1.85}

/* Reducir movimiento */
html.a11y-mov *,html.a11y-mov *::before,html.a11y-mov *::after{
  animation-duration:.001s !important;transition-duration:.001s !important;scroll-behavior:auto !important}

/* Alto contraste (gana sobre tema oscuro) */
html.a11y-contraste{
  --bg:#000;--card:#000;--ink:#fff;--muted:#fff;--faint:#e0e0e0;
  --line:#fff;--line2:#fff;--c:#ffea00;--c-d:#fff36b;--c-dd:#fff89e;
  --c-l:#000;--c-l2:#1a1a1a;--c-bar:#000;--mark:#ffea00;--mark-fg:#000;
}
html.a11y-contraste body{background:#000;color:#fff}
html.a11y-contraste .topbar,html.a11y-contraste .hero,html.a11y-contraste .pie,
html.a11y-contraste .card,html.a11y-contraste .modal-box,html.a11y-contraste .cat-tile,
html.a11y-contraste .suger,html.a11y-contraste .paginado button,html.a11y-contraste .a11y-panel,
html.a11y-contraste .facetas{background:#000 !important;border:1px solid #fff !important}
html.a11y-contraste a,html.a11y-contraste .btn-link,html.a11y-contraste h1,
html.a11y-contraste h2,html.a11y-contraste h3,html.a11y-contraste .card *{color:#fff !important}
html.a11y-contraste a,html.a11y-contraste .btn-link{color:#ffea00 !important;text-decoration:underline !important}
html.a11y-contraste .btn-buscar,html.a11y-contraste .tab.activo,
html.a11y-contraste .a11y-opt[aria-pressed="true"]{background:#ffea00 !important;color:#000 !important;border:1px solid #fff !important}
html.a11y-contraste mark{background:#ffea00 !important;color:#000 !important}

/* Panel desplazable + perfiles (estilo accedeME) */
.a11y-panel{max-height:min(78vh,560px);overflow-y:auto}
.a11y-sub{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--faint);
  font-weight:700;margin:7px 2px 1px}
.a11y-prof{text-align:left;border:1px solid var(--line);background:var(--bg);border-radius:9px;
  padding:9px 12px;cursor:pointer;font-family:var(--ff);display:flex;flex-direction:column;gap:1px;transition:border-color .15s,background .15s}
.a11y-prof strong{font-size:13.5px;color:var(--ink);font-weight:600;line-height:1.2}
.a11y-prof small{font-size:11px;color:var(--muted);line-height:1.25}
.a11y-prof:hover{border-color:var(--c)}
.a11y-prof[aria-pressed="true"]{background:var(--c);border-color:var(--c)}
.a11y-prof[aria-pressed="true"] strong,.a11y-prof[aria-pressed="true"] small{color:#fff}

/* Más espaciado (lectura) */
html.a11y-espaciado body{letter-spacing:.4px;word-spacing:2px;line-height:1.95}
html.a11y-espaciado p,html.a11y-espaciado li,html.a11y-espaciado .card,
html.a11y-espaciado td,html.a11y-espaciado .ficha-prev{line-height:1.95}

/* Reducir color (escala de grises del contenido; deja el panel a color) */
html.a11y-gris .topbar,html.a11y-gris .hero,html.a11y-gris .layout,
html.a11y-gris .pie,html.a11y-gris .modal-box{filter:grayscale(1)}

/* Botón "Escuchar" (lectura en voz alta) en la ficha */
.tts-btn{display:inline-flex;align-items:center;gap:6px;background:var(--c-l);color:var(--c-d);
  border:1px solid var(--c);padding:10px 18px;border-radius:var(--r);font-weight:600;font-size:14px;
  cursor:pointer;font-family:var(--ff);transition:background .15s}
.tts-btn:hover{background:var(--c-l2)}
.tts-btn.hablando{background:var(--c);color:#fff;border-color:var(--c)}
html.a11y-contraste .tts-btn{background:#000 !important;color:#ffea00 !important;border:1px solid #fff !important}
/* Botón "Escuchar" dentro de cada tarjeta de resultados (estilo pill, como las acciones) */
.card .acciones .tts-card{font:500 12.5px var(--ff);color:var(--c-d);background:transparent;border:1px solid var(--line);
  padding:6px 14px;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;
  transition:all .12s;white-space:nowrap}
.card .acciones .tts-card:hover{border-color:var(--c);background:var(--c-l)}
.card .acciones .tts-card.hablando{background:var(--c);color:#fff;border-color:var(--c)}
html.a11y-contraste .card .acciones .tts-card{background:#000 !important;color:#ffea00 !important;border:1px solid #fff !important}

/* Al abrir el panel, corre el contenido a la izquierda para que no tape el texto */
@media(min-width:861px){ body.a11y-abierto{padding-right:236px;transition:padding-right .2s} }

@media(max-width:860px){
  .a11y-btn{right:12px;bottom:12px}
  .a11y-panel{right:12px;bottom:72px;width:min(86vw,260px)}
}
