/* M.A.R. — Archivo Digital | styles.css | v7 */

:root{
  --bg:#111009;--bg2:#1a190f;--bg3:#252418;--border:#333220;
  --acc:#F4821A;--acc2:#F4C820;--txt:#ede5d4;--txt2:#9c9278;--txt3:#5c5644;
  --cream:#f5efdf;--grn:#44B840;--red:#E84848;
  --fh:'Playfair Display',serif;--fb:'Crimson Pro',serif;--fm:'DM Mono',monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg);color:var(--txt);font-family:var(--fb);overflow:hidden}
#app{display:flex;flex-direction:column;height:100vh}

/* TOPBAR */
#topbar{display:flex;align-items:center;background:var(--bg2);border-bottom:1px solid var(--border);height:44px;flex-shrink:0;z-index:200}
.logo{font-family:var(--fh);font-size:12px;letter-spacing:.1em;color:var(--acc2);padding:0 16px;border-right:1px solid var(--border);height:100%;display:flex;align-items:center;white-space:nowrap;font-style:italic;min-width:172px}
#topbar nav{display:flex;height:100%}
#topbar nav button{font-family:var(--fm);font-size:9px;letter-spacing:.13em;text-transform:uppercase;background:none;border:none;border-right:1px solid var(--border);color:var(--txt2);cursor:pointer;padding:0 14px;height:100%;transition:all .2s;white-space:nowrap}
#topbar nav button:hover{color:var(--txt);background:var(--bg3)}
#topbar nav button.active{color:var(--acc2);background:var(--bg3);border-bottom:2px solid var(--acc)}
.meta{margin-left:auto;font-family:var(--fm);font-size:7.5px;color:#bfaa88;padding:0 12px;letter-spacing:.05em;text-align:right;line-height:1.5}

/* PAGES */
.page{display:none;flex:1;overflow:hidden}
.page.active{display:flex}

/* ── HOME ── */
#page-home{flex-direction:column;align-items:stretch;justify-content:flex-start;background:var(--bg);position:relative;overflow-y:auto;overflow-x:hidden;background-image:radial-gradient(ellipse 70% 50% at 50% 55%,rgba(196,113,58,.07) 0%,transparent 65%)}
.grid-bg{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:40px 40px;opacity:.4}
.big-r{position:absolute;font-family:var(--fh);font-size:min(55vw,400px);font-weight:700;color:rgba(196,113,58,.035);bottom:-10%;right:-5%;line-height:1;user-select:none;pointer-events:none}
.hc{position:relative;z-index:1;text-align:center;padding:clamp(16px,4vh,40px) 20px clamp(100px,18vh,160px);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;}
.eyebrow{font-family:var(--fm);font-size:8px;letter-spacing:.28em;text-transform:uppercase;color:var(--acc);margin-bottom:14px}
.ht{font-family:var(--fh);font-size:clamp(40px,6vw,80px);font-weight:400;line-height:1.05;color:var(--cream);margin-bottom:6px}
.ht em{font-style:italic;color:var(--acc2)}
.hsub{font-family:var(--fb);font-size:14px;color:var(--txt2);font-weight:300;margin-bottom:40px;letter-spacing:.03em}
.hstats{display:flex;gap:48px;justify-content:center;margin-bottom:40px}
.stn{font-family:var(--fh);font-size:44px;color:#F4C820;display:block;line-height:1}
.stl{font-family:var(--fm);font-size:7px;letter-spacing:.16em;text-transform:uppercase;color:#d4c4a0;margin-top:3px;display:block}
.hnav{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.hnav button{font-family:var(--fm);font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;background:none;border:1px solid var(--border);color:var(--txt2);padding:10px 20px;cursor:pointer;transition:all .22s}
.hnav button:hover{border-color:var(--acc);color:var(--acc2);background:rgba(196,113,58,.06)}
.hnav button.p{border-color:var(--acc);color:var(--acc2);background:rgba(196,113,58,.1)}
.hnav button.p:hover{background:rgba(196,113,58,.2)}

/* ── DASHBOARD ── */
#page-dash{
  flex-direction:column;overflow-y:auto;overflow-x:hidden;
  background:var(--bg);gap:0;
}

/* FILTER BAR */
#filter-bar{
  display:none;align-items:center;gap:10px;
  padding:7px 14px;background:rgba(244,130,26,.08);
  border-bottom:1px solid rgba(244,200,32,.3);flex-shrink:0;
}
#filter-bar.visible{display:flex}
#filter-label{font-family:var(--fm);font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:#F4C820}
#filter-val{font-family:var(--fh);font-size:13px;color:var(--cream);font-style:italic}
#filter-clear{
  margin-left:auto;font-family:var(--fm);font-size:7.5px;letter-spacing:.12em;text-transform:uppercase;
  background:none;border:1px solid rgba(196,113,58,.3);color:var(--acc);padding:4px 10px;cursor:pointer;
  transition:all .2s;
}
#filter-clear:hover{background:rgba(196,113,58,.15);border-color:var(--acc)}
#filter-count{font-family:var(--fm);font-size:8px;color:var(--txt3);letter-spacing:.08em}

/* DASHBOARD GRID */
.dgrid{
  display:grid;gap:10px;padding:10px;flex-shrink:0;
}
.dgrid.top{grid-template-columns:1.6fr 1fr 0.8fr}
.dgrid.mid{grid-template-columns:1fr}
.dgrid.bot{grid-template-columns:1fr}

.cc{background:var(--bg2);border:1px solid var(--border);padding:12px;display:flex;flex-direction:column;min-height:0;cursor:default;transition:border-color .2s}
.cc.interactive{cursor:pointer}
.cc.interactive:hover{border-color:rgba(196,113,58,.35)}
.cc.has-filter{border-color:rgba(196,113,58,.5);background:rgba(196,113,58,.04)}
.ct{font-family:var(--fm);font-size:7px;letter-spacing:.18em;text-transform:uppercase;color:#e0d4c0;margin-bottom:8px;padding-bottom:7px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px}
.ct-hint{font-size:6.5px;color:#c0ad95;opacity:1;margin-left:auto;letter-spacing:.05em}
.cw{flex:1;position:relative}

/* HEATMAP */
.hmwrap{overflow-x:auto;flex:1}
.hmt{width:100%;border-collapse:collapse;font-family:var(--fm);font-size:8px}
.hmt th{font-size:6.5px;letter-spacing:.07em;text-transform:uppercase;color:#d8cbb4;padding:3px 4px;text-align:center;font-weight:400;white-space:nowrap}
.hmt td{padding:4px 3px;text-align:center;border:1px solid var(--bg);transition:filter .12s,transform .12s;cursor:default;font-size:8px}
.hmt td:first-child{font-size:7.5px;color:#e8dcc8;text-align:left;padding-left:8px;background:var(--bg2)!important;white-space:nowrap;border-left:none;font-weight:500}
.hmt td:hover:not(:first-child){filter:brightness(1.5);transform:scale(1.05)}

/* ── MAP PAGES ── */
#page-world,#page-cordoba{flex-direction:row}
.mapwrap{flex:1;position:relative}
.lmap{width:100%;height:100%}

/* SCHEDA */
.sp{width:355px;flex-shrink:0;background:var(--bg2);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.sph{padding:11px 16px 9px;border-bottom:1px solid var(--border);flex-shrink:0}
.sphl{font-family:var(--fm);font-size:7px;letter-spacing:.2em;text-transform:uppercase;color:#d8cbb4;margin-bottom:2px}
.spht{font-family:var(--fh);font-size:10px;color:#F4C820;font-style:italic}
.spb{flex:1;overflow-y:auto;min-height:0}
.sempty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;gap:10px;padding:20px}
.seico{font-size:34px;opacity:.15;margin-bottom:2px}
.setxt{font-family:var(--fm);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--txt3);line-height:1.9;max-width:170px}
.imgwrap{position:relative;width:100%;height:196px;overflow:hidden;flex-shrink:0;background:var(--bg3)}
.imgwrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.imgwrap:hover img{transform:scale(1.04)}
.imgph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;font-family:var(--fm);font-size:8px;color:var(--txt3);text-transform:uppercase}
.imgph span:first-child{font-size:26px;opacity:.2}
.imglbl{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(10,9,5,.88));padding:22px 14px 9px}
.imglbl-dest{font-family:var(--fm);font-size:6.5px;letter-spacing:.14em;text-transform:uppercase;color:#F4C820}
.scc{padding:14px 16px}
.scname{font-family:var(--fh);font-size:16px;line-height:1.25;color:var(--cream);margin-bottom:9px;font-weight:400}
.scst{display:inline-flex;align-items:center;gap:5px;font-family:var(--fm);font-size:7px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.scst .dot{width:5px;height:5px;border-radius:50%}
.scst.si .dot{background:#F4821A}.scst.si{color:#F4821A}
.scst.no .dot{background:#4090e8}.scst.no{color:#4090e8}
.scdiv{border:none;border-top:1px solid var(--border);margin:10px 0}
.scrow{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.scf{display:flex;flex-direction:column;gap:2px}
.sfl{font-family:var(--fm);font-size:6.5px;letter-spacing:.18em;text-transform:uppercase;color:#cfc0a0}
.sfv{font-family:var(--fb);font-size:13px;color:var(--txt);line-height:1.4}
.sfv.yr{font-family:var(--fm);font-size:19px;color:#F4C820;font-weight:300}
.sfv.desc{font-size:12px;color:var(--txt2);line-height:1.7}
.slnks{padding:9px 16px 12px;display:flex;gap:8px;flex-shrink:0;border-top:1px solid var(--border)}
.slnk{flex:1;font-family:var(--fm);font-size:7.5px;letter-spacing:.1em;text-transform:uppercase;padding:9px 6px;border:1px solid var(--border);background:none;color:var(--txt2);text-align:center;transition:all .18s;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:4px}
.slnk.off{opacity:.22;cursor:not-allowed;pointer-events:none}
.slnk:not(.off):hover{border-color:var(--acc);color:var(--acc2);background:rgba(196,113,58,.09)}
.slnk.has360{border-color:#F4C820;color:#F4C820}

/* MARKER */
.rm{width:11px;height:11px;border-radius:50%;background:#F4821A;border:2px solid rgba(255,200,80,.9);box-shadow:0 0 10px rgba(244,130,26,.8);cursor:pointer;transition:transform .12s}
.rm:hover,.rm.sel{transform:scale(1.7);background:#F4C820;box-shadow:0 0 14px rgba(244,200,32,.9)}
.rm.no{background:#2060c8;border-color:rgba(100,160,255,.85);box-shadow:0 0 10px rgba(60,120,255,.65)}
.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background:rgba(244,130,26,.2)!important}
.marker-cluster-small div,.marker-cluster-medium div,.marker-cluster-large div{background:rgba(244,130,26,.85)!important;color:#fff!important;font-family:var(--fm)!important;font-size:9px!important}
.leaflet-popup-content-wrapper{background:var(--bg2)!important;color:var(--txt)!important;border:1px solid var(--border)!important;border-radius:0!important;box-shadow:0 4px 24px rgba(0,0,0,.7)!important;min-width:180px}
.leaflet-popup-tip{background:var(--bg2)!important}
.leaflet-popup-content{font-family:var(--fm);font-size:9px;color:var(--txt2);line-height:1.6}
.leaflet-popup-content strong{color:#F4C820;font-size:10px;display:block;margin-bottom:2px}
.ppimg{width:100%;height:86px;object-fit:cover;margin-bottom:6px;display:block}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border)}

/* ── LAYER SWITCHER ────────────────────────────────────────────────── */
.layer-switcher{
  position:absolute;top:10px;left:10px;z-index:1000;
  display:flex;flex-direction:column;gap:4px;
}
.ls-btn{
  font-family:var(--fm);font-size:7.5px;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 10px;border:none;cursor:pointer;transition:all .2s;
  display:flex;align-items:center;gap:6px;white-space:nowrap;
  background:rgba(17,16,9,.85);color:var(--txt2);
  border:1px solid rgba(255,255,255,.1);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.ls-btn:hover{background:rgba(17,16,9,.95);color:var(--txt)}
.ls-btn.active{
  background:rgba(244,130,26,.15);color:#F4821A;
  border-color:rgba(244,130,26,.5);
}
.ls-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ── MARCADOR SELECCIONADO ─────────────────────────────────────────── */
.rm-sel-wrap{
  position:relative;
  width:28px;height:28px;
  transform:translate(-50%,-50%);
  /* el div icon se posiciona con su propio iconAnchor */
}
.rm-selected{
  width:28px;height:28px;border-radius:50%;
  background:transparent;
  border:2.5px solid #F4C820;
  box-shadow:0 0 0 3px rgba(244,200,32,.25), 0 0 18px rgba(244,200,32,.7);
  animation:pulse-sel 1.6s ease-in-out infinite;
  position:relative;
}
.rm-selected::after{
  content:'';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:10px;height:10px;border-radius:50%;
  background:#F4C820;
  box-shadow:0 0 8px rgba(244,200,32,.9);
}
@keyframes pulse-sel{
  0%,100%{box-shadow:0 0 0 3px rgba(244,200,32,.25),0 0 18px rgba(244,200,32,.7)}
  50%     {box-shadow:0 0 0 7px rgba(244,200,32,.08),0 0 28px rgba(244,200,32,.5)}
}


/* ── Sankey label override ─────────────────────────────────────────── */
#ch-sankey{color:#e0d4c0}


/* ── HOME FOOTER ─────────────────────────────────────────────────── */
.home-footer{
  position:sticky;bottom:0;left:0;right:0;
  display:flex;flex-direction:column;align-items:center;
  gap:12px;padding:14px 24px 20px;
  background:linear-gradient(rgba(17,16,9,0),rgba(17,16,9,.96) 30%);
  z-index:10;pointer-events:none;
  margin-top:auto;
}
.home-footer-logos{
  display:flex;align-items:center;justify-content:center;
  gap:32px;pointer-events:all;
}
.home-footer-logo{
  display:flex;align-items:center;justify-content:center;
  height:58px;opacity:.82;transition:opacity .2s;
}
.home-footer-logo:hover{opacity:1}
.home-footer-logo img{
  max-height:58px;max-width:130px;
  object-fit:contain;filter:brightness(1);
}
.home-footer-logo.frammet img{
  max-height:64px;max-width:64px;
  border-radius:10px;
}
.home-footer-copy{
  font-family:var(--fm);font-size:7.5px;letter-spacing:.12em;
  color:#c8a84a;text-align:center;pointer-events:none;
}


/* ── RESPONSIVE HOME ─────────────────────────────────────────────── */
@media (max-height: 640px){
  .ht{font-size:clamp(32px,5vw,56px)}
  .hstats{gap:24px;margin-bottom:20px}
  .stn{font-size:32px}
  .hsub{margin-bottom:20px}
}
@media (max-width: 500px){
  .hstats{gap:20px}
  .stn{font-size:34px}
  .home-footer-logos{gap:20px}
  .home-footer-logo img{max-height:44px;max-width:90px}
  .home-footer-logo.frammet img{max-height:48px;max-width:48px}
}
@media (max-width: 360px){
  .ht{font-size:clamp(28px,9vw,44px)}
  .hstats{gap:12px}
  .stn{font-size:28px}
  .hnav{flex-direction:column;align-items:center}
  .hnav button{width:220px}
}


.home-footer-logo.light-bg img{
  background:rgba(255,255,255,.92);
  border-radius:8px;
  padding:4px;
}
