:root{--blue:#1A4E8A;--saff:#F4A300;--ink:#0f2136;--muted:#6a7a91;--shadow:0 10px 28px rgba(14,33,54,.18);--r:22px}
*{box-sizing:border-box}html,body{margin:0;height:100%}
body{height:100dvh;overflow:hidden;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial;color:var(--ink);
  background:radial-gradient(120% 120% at 0 0, rgba(26,78,138,.06),transparent 55%),radial-gradient(120% 120% at 100% 0, rgba(244,163,0,.06),transparent 55%),conic-gradient(from 210deg at 50% 50%, #fff 0, #fbfdff 120deg, #f6fbff 240deg, #fff 360deg)}
header{position:relative;z-index:5;height:56px}
.bar{position:absolute;inset:0 0 auto 0;height:56px;display:flex;align-items:center;gap:10px;padding:8px 14px;background:rgba(255,255,255,.86);backdrop-filter:saturate(150%) blur(6px);border-bottom:1px solid rgba(26,78,138,.08)}
.logo img{height:34px;mix-blend-mode:multiply}.spacer{flex:1}
.cta{background:var(--blue);color:#fff;border:none;border-radius:999px;padding:9px 14px;font-weight:700;cursor:pointer}
.cta.alt{background:var(--saff);color:#2a1a00}
.account{position:relative;display:flex;align-items:center;gap:8px}
.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--blue),#2b6cb0);cursor:pointer}
.avatar img{width:34px;height:34px;border-radius:50%;object-fit:cover}
.menu{position:absolute;right:0;top:44px;background:#fff;border:1px solid rgba(26,78,138,.12);border-radius:12px;box-shadow:var(--shadow);min-width:260px;display:none}
.menu.open{display:block}.menu button{display:block;width:100%;text-align:left;background:#fff;border:none;padding:10px 12px;cursor:pointer}
.menu button:hover{background:#f4f7fb}

.viewport{position:absolute;top:56px;left:0;right:0;bottom:56px;display:grid;grid-template-columns:280px 1fr;gap:14px;padding:12px}
@media (max-width:980px){.viewport{grid-template-columns:1fr}.legend{display:none}.deck-wrap{height:calc(100dvh - 120px);display:flex;align-items:center;justify-content:center}}
.legend{border:1px solid rgba(26,78,138,.12);border-radius:16px;padding:12px;background:#fff;box-shadow:var(--shadow);display:grid;gap:8px}
.legend-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:12px;background:#fbfdff}
.tag{font-weight:900;font-size:12px;color:#fff;padding:6px 10px;border-radius:999px}
.right{background:var(--blue)}.left{background:#b00020}.up{background:#5c5c5c}.down{background:#888}
.meter{height:6px;flex:1;background:linear-gradient(90deg,rgba(26,78,138,.1),rgba(244,163,0,.1));border-radius:999px;overflow:hidden}
.fill{height:100%;width:8%;background:linear-gradient(90deg,var(--saff),var(--blue));transition:width .12s ease}
.headline{margin:2px 2px 4px;color:var(--blue);font-weight:800;font-size:18px}
.subtitle{margin:0;color:var(--muted);font-size:13px}

.deck-wrap{border:1px solid rgba(26,78,138,.12);border-radius:22px;background:#fff;box-shadow:var(--shadow);display:grid;grid-template-rows:1fr auto;padding:10px;position:relative;overflow:hidden}
.deck{position:relative;width:min(100%,560px);height:100%;margin:0 auto}
.card{position:absolute;inset:auto 0 0 0;margin:auto;width:100%;height:92%;border-radius:var(--r);background:#fff;box-shadow:var(--shadow);display:grid;grid-template-rows:4fr auto auto;overflow:hidden;touch-action:none;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .25s ease,opacity .25s ease}
.imgbox{position:relative;overflow:hidden}.card img{width:100%;height:100%;object-fit:cover;object-position:center 18%}.veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5),rgba(0,0,0,0) 40%)}
.meta{padding:10px 12px 6px;display:flex;align-items:center;gap:10px}.name{font-weight:800;font-size:18px}.chip{margin-left:auto;background:#eef4fb;color:#1a3c6b;padding:6px 10px;border-radius:999px;font-weight:700;font-size:12px;border:1px solid rgba(26,78,138,.18)}
.bio{padding:0 12px 10px;color:#4c5d77;font-size:14px;min-height:38px}
.deck-ctrls{display:flex;justify-content:center;gap:8px;padding:6px 0 0}
.ctrl{border:1px solid rgba(26,78,138,.18);background:#fff;border-radius:999px;padding:8px 12px;font-weight:800;cursor:pointer}.ctrl.primary{background:var(--blue);color:#fff;border-color:transparent}

.loadingMore{position:absolute;inset:0;display:none;align-items:center;justify-content:center;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.85) 40%,rgba(255,255,255,.95));font-weight:800;color:#365079}
.teaser{position:absolute;inset:0;display:none;align-items:center;justify-content:center;background:rgba(255,255,255,.94);z-index:3}
.tspin{width:36px;height:36px;border-radius:50%;border:4px solid #dfe7f3;border-top-color:#1A4E8A;animation:spin 1s linear infinite;margin:10px auto}@keyframes spin{to{transform:rotate(360deg)}}

footer{position:absolute;left:0;right:0;bottom:0;height:56px;display:flex;align-items:center;justify-content:center;gap:16px;border-top:1px solid rgba(26,78,138,.12);background:#fbfdff;color:#4b5b75;padding:0 12px}
footer a{color:var(--blue);text-decoration:none;font-size:14px}

/* to avoid menu links feel “dead” on mobile */
.footer, .footer a, .footer .pill {
  pointer-events: auto;
  position: relative;
  z-index: 2;
}

/* prevent duplicates wrapping into a second row off-screen */
.footer .links {
  overflow-x: auto;
  white-space: nowrap;
}


dialog{border:none;border-radius:18px;padding:0;width:min(96vw,840px);box-shadow:0 40px 80px rgba(0,0,0,.35)}
.modal{padding:18px;background:#fff}
.closebar{display:flex;justify-content:flex-end;padding:10px}
.x{border:none;background:transparent;font-size:20px;cursor:pointer}
.modal h2{margin:0 0 6px;color:var(--blue)}
.row{display:grid;gap:10px}
@media (min-width:620px){.row{grid-template-columns:1fr 1fr}}
input,textarea,select{width:100%;border:1px solid rgba(26,78,138,.25);border-radius:12px;padding:12px;font-size:15px}
textarea{min-height:90px;resize:vertical}.full{grid-column:1/-1}.sub{color:#4a5a74;font-size:15px;line-height:1.55}
.modal p,.modal li,.modal ol{font-size:15px;line-height:1.55;color:#31455f}
.submitFull{width:100%;margin-top:8px}
.socials{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0}
.sbtn{flex:1 1 30%;border:1px solid rgba(26,78,138,.2);background:#fff;border-radius:12px;padding:12px;font-weight:800;cursor:pointer}

.rank-actions{display:flex;gap:10px;align-items:center;margin:0 0 10px}
.share-pills{display:flex;gap:8px;flex-wrap:wrap}
.pill{border:1px solid rgba(26,78,138,.18);border-radius:999px;padding:6px 10px;font-weight:700;background:#fff;cursor:pointer}
.rank-scroll{max-height:60dvh;overflow:auto}
#rankTable{width:100%;border-collapse:separate;border-spacing:0 8px}
#rankTable thead th{position:sticky;top:0;background:#fff;padding:10px 12px;text-align:left;font-size:13px;color:#365079;cursor:pointer;box-shadow:0 1px 0 rgba(26,78,138,.12);white-space:nowrap}
#rankTable tbody tr{background:#fff;box-shadow:var(--shadow)}
#rankTable td{padding:10px 12px;text-align:left;vertical-align:top}
#rankTable td:nth-child(2){white-space:normal;max-width:260px;word-wrap:break-word}
#rankTable tbody td:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}
#rankTable tbody td:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}

.toast{position:fixed;bottom:70px;right:16px;background:#111;color:#fff;padding:10px 14px;border-radius:12px;opacity:0;transform:translateY(10px);transition:all .25s ease;z-index:999}
.toast.show{opacity:1;transform:translateY(0)}
.voteCounter{background:#F4A300;color:#fff;padding:6px 14px;border-radius:16px;font-weight:800;font-size:16px;box-shadow:0 2px 6px rgba(0,0,0,.2);white-space:nowrap}
#internalPanel{position:fixed;z-index:40;right:10px;top:62px;background:#fff;border:1px solid rgba(26,78,138,.18);box-shadow:var(--shadow);border-radius:12px;padding:8px 10px;display:none}
#internalPanel label{display:flex;align-items:center;justify-content:flex-start;gap:6px;font-size:12px;color:#365079}
.toggle{appearance:none;width:36px;height:20px;border-radius:999px;background:#e7eef8;position:relative;outline:none;cursor:pointer;transition:background .2s}
.toggle::after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:left .2s}
.toggle:checked{background:#1A4E8A}.toggle:checked::after{left:18px}
.pwd-meter{height:6px;background:#e9eef7;border-radius:999px;margin-top:6px;overflow:hidden}
.pwd-meter>i{display:block;height:100%;width:0;background:linear-gradient(90deg,#f37373,#f4a300,#4caf50);transition:width .25s}
.gate{padding:16px}

.avatar img, .card img {
  object-fit: cover;
  image-rendering: auto;
}


/* Crisp avatars without distortion */
.avatar img { width:34px; height:34px; border-radius:50%; object-fit:cover; image-rendering:-webkit-optimize-contrast; }



/* Additional fixes */
:root { --blue:#1A4E8A; --saff:#F4A300; }

/* --- Header brand text next to logo (added) --- */
.bar .logo{display:flex;align-items:center;gap:8px;text-decoration:none}
.brand-name{font-weight:800;font-size:18px;line-height:1;color:#1A4E8A;white-space:nowrap}
.brand-tag{font-size:11px;line-height:1;color:#6a7a91;white-space:nowrap;margin-left:4px}
@media (max-width:768px){
  .brand-tag{display:none} /* keep header compact on mobile */
  .brand-name{font-size:16px}
}

/* Hide mobile menu by default */
.mobile-menu {
  display: none;
}

/* Show only on small screens (mobile) */
@media (max-width: 768px) {
  .mobile-menu {
    display: block;
  }
}

/* Desktop nav visible by default */
.desktop-nav {
  display: block;
}

/* Hide desktop nav on small screens */
@media (max-width: 768px) {
  .desktop-nav {
    display: none;
  }
}

/* Hide mobile menu by default (desktop and tablet) */
.mobileMenu {
  display: none;
}

/* Show only on small screens (phones) */
@media (max-width: 768px) {
  .mobileMenu {
    display: flex;          /* or block, depending on your layout */
    flex-direction: column; /* makes menu items stack */
    background: #fff;
    position: absolute;
    top: 56px;  /* height of header bar */
    left: 0;
    right: 0;
    border-top: 1px solid #ddd;
    z-index: 1000;
  }
  .mobileMenu a {
    padding: 12px 16px;
    border-bottom: 1px solid #eee;
    color: #1A4E8A;
    text-decoration: none;
  }
}


/* Ranking modal ticker links styled */
.rankLink {
  color: inherit;
  text-decoration: none;
  font-weight: 600;
  cursor: pointer;
  padding: 0 2px;
}
.rankLink:hover {
  text-decoration: underline;
}

/* Hide any legacy country UI under ticker */
#rankDlg .rank-filterbar, #rankDlg #ticker select { display:none !important; }
#rankDlg #ticker label, #rankDlg #ticker .country-label { display:none !important; }

/* === Rankings: country filter controls === */
.rank-controls{display:none;gap:10px;align-items:center;justify-content:flex-end;margin:-6px 0 10px 0;flex-wrap:wrap}
.rank-filt-label{font-size:12px;color:#55627a}
.rank-country{min-width:240px;font-size:12px;padding:6px 10px;border:1px solid #d6dfeb;border-radius:8px;background:#fff;outline:none}
.rank-country:focus{border-color:#1A4E8A}
.rank-stats{font-size:12px;color:#1A4E8A;font-weight:600;white-space:nowrap}
@media (max-width:768px){
  .rank-controls{justify-content:space-between}
  .rank-country{min-width:56%}
}
/* clickable ticker pills (if present) */
.linkpill{background:transparent;border:none;color:#1A4E8A;font-weight:600;cursor:pointer;padding:2px 6px;border-radius:8px}
.linkpill:hover{background:#e9f3ff}


/* Honesty map tooltip styling */
.leaflet-tooltip.honesty-tip{
  background: rgba(26,78,138,0.95);
  color: #fff;
  border: 0;
  border-radius: 10px;
  padding: 8px 10px;
  box-shadow: 0 6px 18px rgba(26,78,138,0.25);
  font-size: 12px;
}
.leaflet-tooltip.honesty-tip b{
  font-size: 12px;
  display:block;
  margin-bottom:2px;
}

.share-capsule{
  display:inline-flex; align-items:center; gap:4px; padding:4px;
  border-radius:999px;
  background: linear-gradient(145deg,#dfe3e6,#bfc6cc);
  box-shadow: inset 2px 2px 4px rgba(255,255,255,.6),
              inset -3px -3px 6px rgba(0,0,0,.08),
              0 4px 12px rgba(0,0,0,.10);
}
.capsule-pill{
  font: 600 12px/1.2 system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial;
  color:#1A4E8A; letter-spacing:.2px;
  padding:8px 4px; border-radius:999px; border:0; background:transparent; cursor:pointer;
  transition: all .18s ease-in-out;
}
.capsule-pill.active{
  background: linear-gradient(145deg,#ffffff,#e6ebf0);
  box-shadow: 0 1px 4px rgba(0,0,0,.08), inset 0 1px 0 #fff;
}
.share-btn{
  border:0; background:transparent; padding:6px; cursor:pointer; border-radius:10px;
}
.share-btn:focus-visible, .capsule-pill:focus-visible{ outline:2px solid #1A4E8A; outline-offset:2px; }
.map-callout.leaflet-tooltip{ 
  background:rgba(255,255,255,.95); color:#0f172a; border:1px solid #e5e7eb; border-radius:10px; padding:6px 8px;
  box-shadow: 0 6px 16px rgba(0,0,0,.12);
}

/* minimal mobile fix: no sideways scroll */
html, body { max-width: 100vw; overflow-x: hidden; }


/* Mobile stability & perf */
* { -webkit-tap-highlight-color: transparent; }
html, body { overscroll-behavior: contain; }
body, .deck, header, .viewport { touch-action: pan-y; user-select: none; }
