:root{--lctn-badge-bg:#1fc5c2;--lctn-badge-text:#ffffff;--lctn-bar-bg:#ffffff;--lctn-text:#111;--lctn-speed:40s;}
.lctn-ticker{display:flex;align-items:center;gap:12px;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--lctn-bar-bg);}
.lctn-badge{background:var(--lctn-badge-bg);color:var(--lctn-badge-text);padding:.75rem 1rem;border-radius:8px;font-weight:700;letter-spacing:.4px;white-space:nowrap;}
.lctn-viewport{overflow:hidden;flex:1;line-height:1;}
.lctn-track{display:inline-flex;gap:16px;white-space:nowrap;animation:lctn-scroll var(--lctn-speed) linear infinite;padding:8px 0;}
.lctn-item{display:inline-flex;align-items:baseline;gap:8px;text-decoration:none;color:var(--lctn-text);opacity:.95}
.lctn-item:hover{text-decoration:underline;}
.lctn-title{font-size:15px}
.lctn-date{font-size:12px;opacity:.7}
.lctn-sep{opacity:.5}
.lctn-empty{opacity:.7}
@keyframes lctn-scroll{
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
/* Duplicate content for seamless loop via JS is avoided; we use long speed and whitespace. */
